ThinkPHP6 利用中间件实现跨域

  • Post author:
  • Post category:php


今天使用 Vue 加 axios,做一个小应用,向 ThinkPHP6 的后台发起请求,但是在控制器里加 header 参数,跨域一直不成功,十分郁闷,于是自己写了一个单独的文件测试,在 header 里配置响应头是有用的,如下:

header('Access-Control-Allow-Origin: *');
header('Access-Control-Allow-Headers: Content-Type, Authorization');

所以估计是在 ThinkPHP6 控制器之前,header 设置已经被拦截。

于是把响应头配置放在入口文件的头部,也是可以的,但是带来的问题是,所有控制器都开启跨域,这个肯定是不行的,所以在网上查找,可以利用 ThinkPHP6 的中间件来实现跨域,这样就比较好控制那些控制器开放跨域了,实现如下:

首先是要生成中间件,在命令行模式下输入:

php think make:middleware Cores

如果是多应用模式,还可以在应用里生成

在最末的控制层创建文件。middleware.php和mimiddleware文件夹


一定要在最后的控制层,否则不生效

定义中间件

<?php
// 全局中间件定义文件
return [
    // 全局请求缓存
    // \think\middleware\CheckRequestCache::class,
    // 多语言加载
    // \think\middleware\LoadLangPack::class,
    // Session初始化
    // \think\middleware\SessionInit::class
    app\api\middleware\Cores::class,
];

在middleware目录创建Cores.php

<?php
namespace app\api\middleware;

class Cores
{
    public function handle($request, \Closure $next)
    {
        $response = $next($request);
        $origin = $request->header('Origin', '');

        //OPTIONS请求返回204请求
        if ($request->method(true) === 'OPTIONS') {
            $response->code(204);
        }
        $response->header([
            'Access-Control-Allow-Origin'      => $origin,
            'Access-Control-Allow-Methods'     => 'GET,POST,PUT',
            'Access-Control-Allow-Credentials' => 'true',
            'Access-Control-Allow-Headers'     => '*',
        ]);

        return $response;
    }
    /*
     * 中间结束调度
     */
}

以上是多应用下的使用方法,

也可以使用官方的配置,就更简单了,直接在

pp\middleware.php

文件中,引入内置中间件即可

<?php
// 全局中间件定义文件
return [
    // 全局请求缓存
    // \think\middleware\CheckRequestCache::class,
    // 多语言加载
    // \think\middleware\LoadLangPack::class,
    // Session初始化
    // \think\middleware\SessionInit::class,

    // 允许跨域请求
    \think\middleware\AllowCrossDomain::class
];

跨域请求成功。

官方文档里还可以在路由里实现跨域,暂时没有测试!



版权声明:本文为hoocool原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。