您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關thinkphp6如何通過全局中間件解決跨域問題,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
tp6 通過全局中間件 解決跨域問題
tp6官網有提供跨域決絕方法,當我直接使用無法用。(可能我用的姿勢不對)。
前端在Hbuildert中發送ajax請求,發生跨域。
get請求:可以通過后臺設置解決。
'Access-Control-Allow-Origin: *'。
post請求:會發生OPTIONS請求。在ajax請求中添加一個header頭信息。
header:{ 'Content-Type':'application/x-www-form-urlencoded' }
<?php declare (strict_types = 1); namespace app\middleware; use think\Response; /** * 全局跨域請求處理 * Class CrossDomain * @package app\middleware */ class CrossDomain { public function handle($request, \Closure $next) { header('Access-Control-Allow-Origin: *'); header('Access-Control-Max-Age: 1800'); header('Access-Control-Allow-Methods: GET, POST, PATCH, PUT, DELETE'); header('Access-Control-Allow-Headers: Authorization, Content-Type, If-Match, If-Modified-Since, If-None-Match, If-Unmodified-Since, X-CSRF-TOKEN, X-Requested-With, Token'); if (strtoupper($request->method()) == "OPTIONS") { return Response::create()->send(); } return $next($request); } }
然后跨域就好使了!
關于thinkphp6如何通過全局中間件解決跨域問題就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。