Risve 2022-10-13 09:51 采纳率: 86.1%
浏览 84
已结题

vue分离项目实现微信公众号单点登录403

场景:微信公众号开放一个路由单点登录进第三方系统,前端:获取微信code传到后端认证接口,接口返回token认证成功调转到主页面。 后端:1、判断是否登录状态,是则返回token,否则继续。2、接收code解析出openId,还是看代码吧。
问题:第一次单点正常进入主页面,之后非正常退出的情况下再单点一直显示403

public AjaxResult userInfo(@RequestParam("code") String code) throws Exception {
        //本地是否已登录
        LoginUser loginUser = tokenService.getLoginUser(ServletUtils.getRequest());
        if (StringUtils.isNotNull(loginUser))
        {
            AjaxResult success = AjaxResult.success();
            String token = loginUser.getToken();
            success.put(Constants.TOKEN, token);
            return success;
        }
        WxMpOAuth2AccessToken wxMpOAuth2AccessToken;
        try
        {
            wxMpOAuth2AccessToken = wxMpService.oauth2getAccessToken(code);
        }
        catch (WxErrorException e)
        {
            throw new Exception(e.getError().getErrorMsg());
        }
        String openId = wxMpOAuth2AccessToken.getOpenId();
        //绑定账号
        SysUser user= userService.selectByWxOpenId(openId);
        String token;
        if(StringUtils.isNull(user))
        {
            return AjaxResult.warn(mpServer + "#/binding" + "?openId=" + openId);
        }
        else
        {
            token = loginService.pointLogin(user.getUserName());
            redisCache.setCacheObject(code, token, 1, TimeUnit.DAYS);
        }
        AjaxResult ajax = AjaxResult.success();
        ajax.put(Constants.TOKEN, token);
        return ajax;
    }

img

  • 写回答

1条回答 默认 最新

  • sum墨 2022-10-13 20:13
    关注

    以我的理解的话,如果是第二次进入应该直接在这里返回:

    img

    你是不是少了一步,在第一次登录后在系统缓存这个登录状态,比如写个

    tokenService.saveLoginUser
    

    什么的

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月1日
  • 已采纳回答 10月24日
  • 创建了问题 10月13日

悬赏问题

  • ¥15 javaFX利用scene builder的fxml文件进行开发时的label setText方法未生效问题
  • ¥15 notepad++ 自动补全提示,如输入汉字"人名",就会出现"张三","李四"
  • ¥15 如何用matlab实现PSO算法与两种智能优化算法在30维和50维问题上的性能比较?
  • ¥15 在qt的QGraphicsView和QGraphicsScene中遇到的问题
  • ¥50 如何完美解决谷歌礼品卡支付不被检测
  • ¥15 nslt的可用模型,或者其他可以进行推理的现有模型
  • ¥15 arduino上连sim900a实现连接mqtt服务器
  • ¥15 vncviewer7.0安装后如何正确注册License许可证,激活使用
  • ¥15 phython如何实现以下功能?查找同一用户名的消费金额合并2
  • ¥66 关于人体营养与饮食规划的线性规划模型