溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

ThinkPHP 5.1.37中怎么解決跨域問題

發(fā)布時(shí)間:2021-07-30 14:34:26 來源:億速云 閱讀:146 作者:Leah 欄目:大數(shù)據(jù)

ThinkPHP 5.1.37中怎么解決跨域問題,針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡單易行的方法。

1.查閱 ThinkPHP 的文檔,文檔給出的例子:

Route::get('new/:id', 'News/read')
    ->ext('html')
    ->allowCrossDomain();

只需要在路由的尾部添加 allowCrossDomain() 即可實(shí)現(xiàn)跨域請(qǐng)求,所以我在每個(gè)需要進(jìn)行跨域訪問的路由后都添加了 ->allowCrossDomain(),一般的跨域問題得以解決。但是有的路由還是跨域失?。?/p>

另外的問題

2.經(jīng)過百度搜索,找到原因是由于前端的 AJAX 請(qǐng)求通常需要攜帶 token 驗(yàn)證,所以還需要將 token 添加到 Access-Control-Allow-Headers

文檔的例子是:

Route::get('new/:id', 'News/read')
    ->ext('html')
    ->header('Access-Control-Allow-Origin','thinkphp.cn')
    ->header('Access-Control-Allow-Credentials', 'true')
    ->allowCrossDomain();

按照上面的方法添加 ->header('Access-Control-Allow-Headers','token') ->allowCrossDomain();代碼如下:

Route::get('your route', 'News/read')
    ->header('Access-Control-Allow-Headers', 'token')
    ->allowCrossDomain();

關(guān)于ThinkPHP 5.1.37中怎么解決跨域問題問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI