php & vue 跨域问题解决方案

方案1:在服务端配置指定的域名

   (注:在vue中无需设置;'Access-Control-Allow-Origin'如果为*则依然会报错,必须得是指定的域名)

 

 

 

    /**
     * 设置能访问的域名
     *
     * @var array
     */
    static public $originarr = [
        'http://lc.vue.com:82', // 前端本地测试域名
        'http://127.0.0.1:82', // 前端本地测试域名
        'http://localhost:8066', // 前端本地测试域名
        'http://localhost:8067', // 前端本地测试域名
        'http://127.0.0.1:8066', // 前端本地测试域名
        'http://127.0.0.1:8067', // 前端本地测试域名
        'http://192.168.0.100:8066', // 前端本地测试域名
    ];

    /**
     * 允许多个域名访问  TODO 暂时对于非访问的域名不做其他处理.
     *
     */
    static function set_header()
    {
        // 获取当前跨域域名
        $origin = isset($_SERVER['HTTP_ORIGIN']) ? $_SERVER['HTTP_ORIGIN'] : '';
        if (in_array($origin, self::$originarr)) {
            // 允许 $originarr 数组内的 域名跨域访问
            header('Access-Control-Allow-Origin:' . $origin);
            // 响应类型
            header('Access-Control-Allow-Methods:POST,GET');
            // 带 cookie 的跨域访问
            header('Access-Control-Allow-Credentials: true');
            // 响应头设置
            header('Access-Control-Allow-Headers:x-requested-with,Content-Type,X-CSRF-Token');
        }
    }

 

 

方案2:...

posted on 2020-03-30 15:17  shenzen_小白  阅读(2429)  评论(0编辑  收藏  举报

导航