我尝试使用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>
如果你想看到过程和错误我提供的小视频,你可以看到。
任何想法为什么会这样?
答案 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',
];
}