| | |
| | | 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; |
| | |
| | | private TokenService tokenService; |
| | | |
| | | @Autowired |
| | | private SysLoginService loginService; |
| | | |
| | | @Autowired |
| | | private ISysConfigService sysConfigService; |
| | | |
| | | private final RestTemplate restTemplate; |
| | |
| | | // 重定向地址对象(重定向地址 |
| | | RedirectView redirectView = new RedirectView(); |
| | | try { |
| | | SSOTokenResponse accessToken = getAccessTokenLyra(code, accessTokenUrl, clientId, redirectUri, clientSecret,true); |
| | | SSOTokenResponse accessToken = getAccessTokenLyra(code, accessTokenUrl, clientId, clientSecret, redirectUri,true); |
| | | 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; |
| | | } |
| | | |