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:...


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM