因此,我试图将我的新统计信息发送到我的CharactersController中的更新函数,但它显示此错误:'MethodNotAllowedHttpException'。我尝试了方法欺骗,但这没有用。
这是我要编辑角色的索引($ tet是我正在观看的角色的行函数):
{!! Form::open(['action' => ['CharactersController@update', $tet->id], 'method' => 'POST','id'=>'form1', 'enctype' => 'multipart/form-data']) !!}
<tr>
<td>HP:</td>
<td>{{$tet->hp}}</td>
<td><button class="btn btn-primary" onclick="addValue(1)">+</button></td>
<td><p>-></p></td>
<td><input id="jedna" class="edit" name="hodnota" type="number" disabled="true" value={{$tet->hp}}></td>
</tr>
<tr>
<td>ATTACK:</td>
<td>{{$tet->attack}}</td>
<td><button class="btn btn-primary" onclick="addValue(2)">+</button></td>
<td><p>-></p></td>
<td><input id="dva" class="edit" name="hodnota" type="number" disabled="true" value={{$tet->attack}}></td>
</tr>
<tr>
<td>LUCK:</td>
<td>{{$tet->luck}}</td>
<td><button class="btn btn-primary" onclick="addValue(3)">+</button></td>
<td><p>-></p></td>
<td><input id="tri" class="edit" name="hodnota" type="number" disabled="true" value={{$tet->luck}}></td>
</tr>
<tr>
<td>AGILITY:</td>
<td>{{$tet->agility}}</td>
<td><button class="btn btn-primary" onclick="addValue(4)">+</button></td>
<td><p>-></p></td>
<td><input id="ctyri" class="edit" name="hodnota" type="number" disabled="true" value={{$tet->agility}}></td>
</tr>
<button onclick="uloz()">SAVE ALL</button>
{{Form::hidden('_method','PUT')}}
{{Form::close()}}
在“ uloz()”函数中,我启用所有数字输入并提交表格。 这是我的CharactersContrller:
public function update(Request $request, $id)
{
$character = Character::find($id);
$character->hp=$request->input('jedna');
$character->attack=$request->input('dva');
$character->luck=$request->input('tri');
$character->agility=$request->input('ctyri');
$character->save();
return redirect('/character');
}
答案 0 :(得分:1)
好吧,我明白了,请注意您的HTML结构,我的表单位于<table>
内部,但必须位于外部。仅此而已,不需要CSRF令牌。
答案 1 :(得分:0)
您应该尝试以下操作:
您的查看文件是这样的:
{!! Form::model($tet, ['route' => ['characters.update', $tet->id], 'class' => 'form-horizontal', 'role' => 'form', 'method' => 'post']) !!}
您的路线:
Route::post('characters/update/{id}', 'CharactersController@update')->name('characters.update');
更新后的答案
请在您的表单中添加CSRF
令牌,例如:
<meta name="csrf-token" content="{{ csrf_token() }}">
在ajax中添加csrf令牌:
$.ajaxSetup({
headers: {
'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
}
});