表单发布请求返回错误419未知状态laravel

时间:2019-03-14 11:06:29

标签: php laravel post laravel-5 laravel-blade

我想用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">&times;</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');
}

3 个答案:

答案 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'); 
}