laravel中的x-editable错误419

时间:2018-02-17 06:45:21

标签: javascript php laravel x-editable

我尝试使用x-editable更改用户表中我的列的值,并在网络上收到419错误。

这是我的CONTROLLER

public function changeprimaryaddress(Request $request){
      try {
          $id = $request->input('pk');
          $field = $request->input('name');
          $value = $request->input('value');

          $user = User::findOrFail($id);
          $user->{$field} = $value;
          $user->save();
      } catch (Exception $e) {
          return response($e->getMessage(), 400);
}

我的ROUTE

Route::post('/changeprimaryaddress','UserController@changeprimaryaddress')->name('changeprimaryaddress');

我的HTML代码

<a href="#"
class="change"
data-type="select"
data-name="address_id"
data-pk="{{ $user->id }}"
data-value="{{ $user->address_id }}"
data-title="Select New Primary Address"
data-url="{{ route('changeprimaryaddress') }}">Change</a>

我的JAVASCRIPT

<script type="text/javascript">
$(function() {
    $('.change').editable({
        source: [
            @foreach($addresses as $address)
                { value: '{{ $address->id }}', text: '{{ $address->address }} - {{$address->city->name}}, {{$address->state->name}}, {{$address->country->name}}, {{$address->postalcode}}' }
                @unless ($loop->last)
                    ,
                @endunless
            @endforeach
        ]
    });
});
</script>

screenvideo

如果你想看到过程和错误我提供的小视频,你可以看到。

result

任何想法为什么会这样?

2 个答案:

答案 0 :(得分:1)

感谢@SagarGautam。我添加了

$.ajaxSetup({
  headers: { 'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content') }
});

现在正在工作。

答案 1 :(得分:0)

这是因为您没有向控制器发送csrf令牌。要么发送令牌,要么执行以下操作以将其排除。

打开您的app/Http/Middleware/VerifyCsrfToken.php文件,然后输入以下代码:

class VerifyCsrfToken extends Middleware
{
    /**
     * The URIs that should be excluded from CSRF verification.
     *
     * @var array
     */
    protected $except = [
        'changeprimaryaddress',
    ];
}