崩!撤!卖!溜! 2023-01-04 16:11 采纳率: 100%
浏览 33
已结题

TP6后置中间件拦截登录导致验证码图片显示不了,如何解决?

后置中间件拦截登录导致captcha验证码显示不了;

img

Auth中间件

<?php
namespace app\admin\middleware;
class Auth
{
    public function handle($request, \Closure $next)
    {
        $Response = $next($request);
        if (empty(session(config("admin.Session_admin"))) && !preg_match('/login/i', $request->pathinfo())) {
            return redirect(url('login/index'));
        }
        return $Response;
    }
}

前台验证码

 
<div class="admin-captcha"><img src="{:url('verify/index')}" alt="" width="120" height="49"
           onclick='this.src="/admin/Verify/index.html?"+Math.random();'></div>

验证码控制器

<?php
namespace app\admin\controller;
use app\BaseController;
use think\captcha\facade\Captcha;

class verify extends BaseController
{
    public function index()
    {
        return Captcha::create('verify');
    }
}

有没有大拿指点一下如何处理

  • 写回答

2条回答 默认 最新

  • byg2005bbc 2023-01-24 13:54
    关注

    搞明白了。
    问题出在,你中间件中Auth中的判断条件:

    if (empty(session(config("admin.Session_admin"))) && !preg_match('/login/i', $request->pathinfo())) {
                return redirect(url('login/index'));
    }
    

    因为中间件是应用类型,所有在admin应用模块下的都起作用,对前台验证码verify/index的请求也一并拦截掉了,所以显示不了。
    你可以修改条件放行验证码:

    if(empty(session("admin_user")) && !preg_match("/login/",$request->pathinfo())
                && !preg_match("/verify/",$request->pathinfo())){ //放行验证码请求
                return redirect(url('login/index'));
    }
    

    实测有效。
    另外象验证码这类前后端均会使用的类,建议放到common\controller中更合适,不会受到应用中间件拦截的影响。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月3日
  • 已采纳回答 2月23日
  • 创建了问题 1月4日

悬赏问题

  • ¥66 定制开发肯德基自动化网站下单软件
  • ¥20 vscode虚拟环境依赖包未安装
  • ¥15 odoo17关于owl开发js代码问题
  • ¥15 光纤中多普勒频移公式的推导
  • ¥15 怎么制作一个人脸识别门禁系统
  • ¥20 大华dss监控平台网络关闭登不进去
  • ¥15 请使用蚁群算法解决下列问题,并给出我完整的代码
  • ¥20 关于php录入完成后,批量更新数据库
  • ¥15 请教往复密封润滑问题
  • ¥15 cocos creator发布ios包