[英]How to use @csrf to String in blade.php page from Laravel controller?
After Click on Delete button showing error 419 |
单击删除按钮后显示错误 419 | PAGE EXPIRED
页已过期
'<form class="delete_form" action="psize/'.$psize->id.'" method="post">
@csrf
<input type="hidden" name="_method" value="DELETE" />
<button type="submit" class="btn btn-danger mx-2" onclick="return confirm("Are you sure?")">Del</button>
</form>'
You need to concat @csrf你需要连接@csrf
'<form class="delete_form" action="psize/'.$psize->id.'" method="post">
' . @csrf . '
<input type="hidden" name="_method" value="DELETE" />
<button type="submit" class="btn btn-danger mx-2" onclick="return confirm("Are you sure?")">Del</button>
</form>'
From what I can see, you are doing @csrf in PHP code which is not parsed by blade.据我所见,您正在使用不被刀片解析的 PHP 代码中的 @csrf。 You should instead use function
csrf_token()
您应该改用函数
csrf_token()
'<form class="delete_form" action="psize/'.$psize->id.'" method="post">
' . csrf_token() . '
<input type="hidden" name="_method" value="DELETE" />
<button type="submit" class="btn btn-danger mx-2" onclick="return confirm("Are you sure?")">Del</button>
</form>'
Yes, It is solved by replacing @csrf with <input type="hidden" name="_token" value="'.csrf_token().'" />
是的,通过用
<input type="hidden" name="_token" value="'.csrf_token().'" />
替换 @csrf 来解决
'<form class="delete_form" action="psize/'.$psize->id.'" method="post">
<input type="hidden" name="_token" value="'.csrf_token().'" />
<input type="hidden" name="_method" value="DELETE" />
<button type="submit" class="btn btn-danger mx-2" onclick="return confirm("Are you sure?")">Del</button>
</form>'
In Controller Function Destory()在控制器函数 Destory()
function destroy(Request $request, $id)
{
$token = $request->session()->token();
//....
}
Thanks Laravel Docs感谢Laravel 文档
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.