Thinkphp6使用中间件解决跨域cors

本文详细介绍如何在ThinkPHP框架中使用命令行生成中间件,包括创建必要的文件和目录,定义中间件处理逻辑,以及如何在全局中间件定义文件中注册自定义中间件。文章还提供了中间件代码示例,展示如何处理跨域请求。
摘要由CSDN通过智能技术生成

生成中间件
命令行输入

php think make:middleware Check

在最末的控制层创建文件。middleware.php和mimiddleware文件夹
一定要在最后的控制层,否则不生效
在这里插入图片描述
定义中间件

<?php
// 全局中间件定义文件
return [
    // 全局请求缓存
    // \think\middleware\CheckRequestCache::class,
    // 多语言加载
    // \think\middleware\LoadLangPack::class,
    // Session初始化
    // \think\middleware\SessionInit::class
    app\api\middleware\Cores::class,
/*    app\api\middleware\Check::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;
    }
    /*
     * 中间结束调度
     */

}

### 解决ThinkPHP6框架中的问题 在ThinkPHP6中配置CORS源资源共享),可以通过多种方式实现,其中一种有效的方法是通过中间件来处理。以下是具体的操作方法: #### 使用全局中间件解决问题 为了使整个应用程序都能处理请求,在`application/middleware.php`文件中定义一个全局中间件用于设置CORS头部信息。 ```php <?php // 全局中间件定义文件 return [ // 注册自定义的CORS中间件 app\middleware\Cors::class, ]; ``` 接着,在项目的`app/middleware/`目录下新建名为`Cors.php`的类文件,编写如下代码以完成对HTTP响应头的相关设定[^5]。 ```php <?php namespace app\middleware; use Closure; use think\Response; class Cors { /** * Handle an incoming request. * * @param \think\Request $request * @param \Closure $next * @return mixed */ public function handle($request, Closure $next): Response { header("Access-Control-Allow-Origin: *"); header("Access-Control-Allow-Methods: POST, GET, OPTIONS, DELETE, PUT"); header("Access-Control-Max-Age: 86400"); header("Access-Control-Allow-Headers: Content-Type, Authorization, X-Requested-With"); if ($request->isOptions()) { exit(); } return $next($request); } } ``` 上述代码实现了当接收到预检请求(`OPTIONS`)时直接返回成功状态码而不执行后续逻辑;对于其他类型的请求,则继续传递给下一个处理器并最终给出正常响应结果[^2]。 此外,也可以考虑将这些头部信息放置于具体的控制器内作为临时解决方案,但这不是推荐的做法,因为这会增加维护成本并且容易遗漏某些路由[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值