我想用id_ward创建新用户,但是当我发布提交表单时,它返回错误419(未知状态)
请帮助我
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalCenterTitle">Thêm user</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">×</span>
</button>
</div>
<div class="modal-body">
<form action="./admin/users/add_user" method="post" id="form-add-user">
<input type="hidden" name="_token" value="{{csrf_token() }}" />
<div class="form-group row">
<div class="col-md-6">
<label for="add_user_area">Phường/xã:</label>
<select id="add_user_area" class="form-control" name="id_ward">
@foreach ($areas as $area)
<option value={{$area->id}}>{{$area->name}}</option>
@endforeach
</select>
</div>
</div>
</form>
</div>
<div class="modal-footer">
<button type="button" onclick="document.getElementById('form-add-user').submit()"
class="btn btn-primary">Thêm
</button>
<button type="button" class="btn btn-secondary" data-dismiss="modal">Đóng</button>
</div>
</div>
这是我的控制器
function postAddUser(Request $request)
{
$user = new User;
$user->id_ward = $request->id_ward;
$user->save();
return redirect('admin/users/list_user');
}
答案 0 :(得分:0)
如果您使用devtools检查表单,那么令牌是否具有任何价值?还是有一个空值?
在显示包含以下形式的视图之前,请尝试将此行request()->session()->regenerateToken();
添加到控制器中:
public function showAddUserForm()
{
request()->session()->regenerateToken();
return view('user.create');
}
答案 1 :(得分:-1)
我遇到了同样的问题,因为我试图向带有表单的页面添加带有表单的模式。为了解决这个问题,我给了表单唯一的ID,然后在form属性的帮助下,将表单ID添加到了所有输入中,包括csrf输入。下面是一个例子。我希望它能解决您的问题
<form action="{{route('template.update')}}" id="edit_template_{{$template->id}}" method="post">
<input type="hidden" name="_token" value="{{csrf_token() }}" form="edit_template_{{$template->id}}">
<input type="number" name = "unit_price" form="edit_template_{{$template->id}}">
<button form="edit_template_{{$template->id}}">Save</button>
</form>
答案 2 :(得分:-2)
尝试更换
./test.sh chk
Invalid input
Did you mean checkout or checkin ?
./test.sh ts
Invalid input
Did you mean destroy or status ?
./test.sh ec
Invalid input
Did you mean checkout or checkin or create?
->
<input type="hidden" name="_token" value="{{csrf_token() }}" />
它将帮助https://laravel.com/docs/5.8/csrf
如果那没有帮助 让我们来了解。 我们在路线中写了什么?一定有类似的东西。
@csrf
在控制器中
Route::post('/users/add_user', 'UsersController@postAddUser')->name('postAddUser');
可见
public function postAddUser() {
$user = new User();
$user->id_ward = request()->id_ward;
$user->save();
return redirect('admin/users/list_user');
}