laravel 在ajax发出的请求经过中间件路由重定向失败
2018-02-15 11:14
465 查看
今天在处理ajax发出的请求经过中间件路由重定向失败,在网上搜了很多的材料最终发现这样的一段解释:”我们使用传统的表单来发送数据到应用。然而,很多应用使用AJAX请求。在AJAX请求中使用validate方法时,Laravel不会生成重定向响应。取而代之的,Laravel生成一个包含验证错误信息的JSON响应。该JSON响应会带上一个HTTP状态码422。”并且这个返回的消息不能够ajax的success(data)获取,laravel 不走这个地方。要这样做才可以获取的返回的数据:
其实我们可以判断是否是AJAX发出的请求如果是的话我们就在重定向的地方返回JSON数据而不是HTML数据,我们可以自定义JSON数据的内容返回后交给AJAX来进行跳转。
在网上找到这样一种说法:'先说前端使用jQuery时怎么区分:
jQuery发出ajax请求时,会在请求头部添加一个名为X-Requested-With的信息,信息内容为:XMLHttpRequest
在后端可以使用$ _SERVER [“HTTP_X_REQUESTED_WITH”]来获取。(注意:中划线换成了下划线,不区分大小写)
“
这样的话我们就可以在重定向后的方法中进行判断如果是阿贾克斯则:
从而返回给前端来进行重定向请求。
$.ajax({ url: "这里填写请求地址", type:"post", //请求类型 data:data.field, //请求的数据 dataType:"json", //数据类型 success: function(data){ //laravel返回的数据是不经过这里的 }, error: function(msg) { var json=JSON.parse(msg.responseText); alert(json.name); //到这里终于拿到返回name字段的错误信息了 }, })
其实我们可以判断是否是AJAX发出的请求如果是的话我们就在重定向的地方返回JSON数据而不是HTML数据,我们可以自定义JSON数据的内容返回后交给AJAX来进行跳转。
在网上找到这样一种说法:'先说前端使用jQuery时怎么区分:
jQuery发出ajax请求时,会在请求头部添加一个名为X-Requested-With的信息,信息内容为:XMLHttpRequest
在后端可以使用$ _SERVER [“HTTP_X_REQUESTED_WITH”]来获取。(注意:中划线换成了下划线,不区分大小写)
“
isset($_SERVER["HTTP_X_REQUESTED_WITH"]) && strtolower($_SERVER["HTTP_X_REQUESTED_WITH"])=="xmlhttprequest"
这样的话我们就可以在重定向后的方法中进行判断如果是阿贾克斯则:
if(isset($_SERVER["HTTP_X_REQUESTED_WITH"]) && strtolower($_SERVER["HTTP_X_REQUESTED_WITH"])=="xmlhttprequest"){ $message_result = new MessageResult; $message_result->URL = '目标url'; $message_result->message = 'ajax请求'; return json_encode($message_result); }
从而返回给前端来进行重定向请求。
相关文章推荐
- 解决ajax请求filter重定向失败
- AJAX 请求中多出了一次 OPTIONS 请求 导致 Laravel 中间件无法对 Header 传入的 Token 无法获取
- 解决ajax请求filter重定向失败
- 同一个页面,发出ajax请求,经过controller,返回ModelAndView,数据显示不了
- 解决ajax请求filter重定向失败
- ajax 请求失败的原因
- 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求
- laravel框架下 前后端分离开发时 通过AJax请求单独获取加密后的csrf_token
- 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求
- 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求
- 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求
- Ajax发送POST请求SpringMVC页面跳转失败
- 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求
- Ajax跨域请求失败
- laravel 创建路由失败原因
- 发出 Ajax 请求
- 使用 JavaScript 和 Ajax 发出异步请求
- 身份验证拦截,Ajax请求跨域重定向到页面后不加载,场景分析
- 关于laravel发送ajax请求带headers头时(防止csrf),报错Warning: Cannot modify header information - headers already se
- 使用 JavaScript 和 Ajax 发出异步请求