php - laravel 为什么会重定向两次?
曾经蜡笔没有小新
曾经蜡笔没有小新 2017-06-20 10:07:24
0
1
1169

目前在做微信登录的网页,使用的是微信提供的接口,用户访问的index/index的时候,跳转到微信指定的url上:

function index(){
    $wxService = \App::make('App\Http\Service\WXActivityService');
    $target_url = route('Index/Activity');
    $redirect_url = $wxService->getWxRedirectUrl($target_url);
    return redirect()->intended($redirect_url);
}

这段代码很简单,就是根据微信指定的url格式来拼接url,然后重定向到这个url($target_url)上.微信会根据其中的redirect_uri来重定向回我设置的$target_url 页面.
但是现在的问题是,微信那边带着code重定向回我的页面以后,我这边服务器会收到两次同样的请求,这就很奇怪,请问大神这是什么情况?是不是laravel的跨站重定向有问题?header函数来重定向也不能实现,实在是非常郁闷...
我记录了日志,发现index方法是只执行了一次的,但是$target_url 却被访问了两次...

曾经蜡笔没有小新
曾经蜡笔没有小新

全部回复(1)
滿天的星座

检查一下,两次请求分别的 Request Method:
因为是跨域请求,客户端发先发送一个OPTIONS 请求
Preflighted Requests是CORS中一种透明服务器验证机制。预检请求首先需要向另外一个域名的资源发送一个 HTTP OPTIONS 请求头,其目的就是为了判断实际发送的请求是否是安全的。

很有可能是这个问题,
我现在用axios 作为我的网络请求库,也遇到了这个问题,跨域访问的时候 ,都会先发送一个OPTIONS请求,用来判断接下来的请求是否安全和被允许

我现在的做法是,在index.php 入口文件中,检测,是否为OPTIONS 请求,如果是就返回一个状态
具体代码

if ($_SERVER['REQUEST_METHOD']=='OPTIONS') {
    header("Access-Control-Allow-Origin: *");
    header("Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept, Authorization");
    header('Access-Control-Allow-Methods: GET, POST, PUT,DELETE,OPTIONS,PATCH');
    return;
}
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板