陈昶聿
3 天以前 ea9c33ab8ef00dd1611f2ed1ed9d331909e53a9f
ruoyi-admin/src/main/java/com/ruoyi/web/controller/sso/SSOController.java
@@ -8,6 +8,7 @@
import com.ruoyi.common.utils.OkHttpExample;
import com.ruoyi.common.utils.StringUtils;
import com.ruoyi.common.utils.http.HttpUtils;
import com.ruoyi.framework.web.service.SysLoginService;
import com.ruoyi.framework.web.service.TokenService;
import com.ruoyi.system.service.ISysConfigService;
import com.ruoyi.system.service.ISysUserService;
@@ -88,6 +89,9 @@
    private TokenService tokenService;
    @Autowired
    private SysLoginService loginService;
    @Autowired
    private ISysConfigService sysConfigService;
    private final RestTemplate restTemplate;
@@ -149,31 +153,42 @@
            log.info("获取到的token:" + accessToken);
            SSOUserInfo userInfo = getUserInfoLyra(accessToken.getAccess_token(), userInfoUrl,true);
            log.info("获取到的用户信息:" + userInfo);
            createLocalSession(userInfo);
//            createLocalSession(userInfo);
            if (StringUtils.isEmpty(path)) {
                throw new BaseException("请配置前端地址");
            }
            String reviewUrl = "";
            reviewUrl = UriComponentsBuilder.fromHttpUrl(path)
                    .path("/loginSSO")
                    .queryParam("token", accessToken.getAccess_token())
                    .queryParam("orgid", userInfo.getZuZhiJGID())
                    .queryParam("orgname", userInfo.getZuZhiJGMC())
                    .queryParam("ZuHuID", userInfo.getYongHuID())
                    .queryParam("deptCode", "null")
                    .build()
                    .toUriString();
            log.info("单点登陆重定向地址为:{}", reviewUrl);
            redirectView.setUrl(reviewUrl);
            redirectView.setStatusCode(HttpStatus.FOUND);
            String userName =  userInfo.getZhiGongID();
            String orgid = userInfo.getZuZhiJGID();
            String campusid = "1";
            String deptId = null;
            String token = null;
            log.info("【SSO登录】获取用户Token参数:" + userInfo);
            String loginToken = loginService.ssoLogin(userName, orgid, deptId, campusid, token);
            if (StringUtils.isEmpty(loginToken)) {
                log.error("【SSO登录】登录失败,userName={}, orgid={}", userName, orgid);
                return buildRedirect(path + "/login");
            }
            String redirectUrl = path + "/loginSSO?token=" + loginToken + "&orgid=" + orgid + "&orgname=null&ZuHuID=null&deptCode=null";
            log.info("【SSO登录】重定向地址:{}", redirectUrl);
            return buildRedirect(redirectUrl);
        } catch (Exception e) {
            log.error("SSO登录失败", e);
            redirectView.setUrl(path + "/login?error=sso_failed");
            return redirectView;
        }
    }
    /**
     * 构建重定向视图
     */
    private RedirectView buildRedirect(String url) {
        RedirectView redirectView = new RedirectView();
        redirectView.setUrl(url);
        redirectView.setStatusCode(HttpStatus.MOVED_PERMANENTLY);
        return redirectView;
    }