From fe7fa03c8f6047fe32c8477c0d3548d8f30e151d Mon Sep 17 00:00:00 2001 From: zhuo <2089219845@qq.com> Date: 星期四, 13 三月 2025 14:01:36 +0800 Subject: [PATCH] Merge branch 'dev' into dev_dz --- ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java | 50 +++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 43 insertions(+), 7 deletions(-) diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java index c05ebf3..c620578 100644 --- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java +++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java @@ -2,13 +2,17 @@ import java.util.List; import java.util.Set; +import java.util.UUID; + +import com.ruoyi.common.annotation.Anonymous; +import com.ruoyi.common.config.SsoBean; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RestController; import com.ruoyi.common.constant.Constants; -import com.ruoyi.common.core.domain.Result; +import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.core.domain.entity.SysMenu; import com.ruoyi.common.core.domain.entity.SysUser; import com.ruoyi.common.core.domain.model.LoginBody; @@ -39,6 +43,9 @@ @Autowired private TokenService tokenService; + @Autowired + private SsoBean ssoBean; + /** * 鐧诲綍鏂规硶 * @@ -46,9 +53,9 @@ * @return 缁撴灉 */ @PostMapping("/login") - public Result login(@RequestBody LoginBody loginBody) + public AjaxResult login(@RequestBody LoginBody loginBody) { - Result ajax = Result.success(); + AjaxResult ajax = AjaxResult.success(); // 鐢熸垚浠ょ墝 String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(), loginBody.getUuid()); @@ -62,7 +69,7 @@ * @return 鐢ㄦ埛淇℃伅 */ @GetMapping("getInfo") - public Result getInfo() + public AjaxResult getInfo() { LoginUser loginUser = SecurityUtils.getLoginUser(); SysUser user = loginUser.getUser(); @@ -75,7 +82,7 @@ loginUser.setPermissions(permissions); tokenService.refreshToken(loginUser); } - Result ajax = Result.success(); + AjaxResult ajax = AjaxResult.success(); ajax.put("user", user); ajax.put("roles", roles); ajax.put("permissions", permissions); @@ -88,10 +95,39 @@ * @return 璺敱淇℃伅 */ @GetMapping("getRouters") - public Result getRouters() + public AjaxResult getRouters() { Long userId = SecurityUtils.getUserId(); List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId); - return Result.success(menuService.buildMenus(menus)); + return AjaxResult.success(menuService.buildMenus(menus)); + } + + /** + * 鑾峰彇缁熶竴鐧诲綍骞冲彴鑾峰彇CODE鍦板潃 + * + * @return + */ + + @Anonymous + @GetMapping("/getSsoAuthUrl") + public AjaxResult getSsoAuthUrl() { + String uuid = UUID.randomUUID().toString(); + return AjaxResult.success(ssoBean.getUrl() + "/oauth2/auth?response_type=code&scope=openid&client_id=" + ssoBean.getClientId() + "&redirect_uri=" + ssoBean.getCallbackUrl() + "&state=" + uuid); + } + + /** + * 鍗曠偣鐧诲綍 + * + * @param code 鐧诲綍淇℃伅 + * @return 缁撴灉 + */ + @PostMapping("/loginBySSO") + public AjaxResult loginBySSO(String code) + { + AjaxResult ajax = AjaxResult.success(); + // 鐢熸垚浠ょ墝 + String token = loginService.loginBySSO(code); + ajax.put(Constants.TOKEN, token); + return ajax; } } -- Gitblit v1.9.3