From efbed347c8b659ca13207a1dbe34e77fdb003949 Mon Sep 17 00:00:00 2001 From: XiaoRuby <3114200645@qq.com> Date: 星期五, 07 七月 2023 16:40:32 +0800 Subject: [PATCH] LIMS管理系统框架-开发-1.0.0 --- user-server/src/main/java/com/yuanchu/limslaboratory/controller/UserController.java | 48 +++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 47 insertions(+), 1 deletions(-) diff --git a/user-server/src/main/java/com/yuanchu/limslaboratory/controller/UserController.java b/user-server/src/main/java/com/yuanchu/limslaboratory/controller/UserController.java index 5bb5aca..b2eaf01 100644 --- a/user-server/src/main/java/com/yuanchu/limslaboratory/controller/UserController.java +++ b/user-server/src/main/java/com/yuanchu/limslaboratory/controller/UserController.java @@ -1,6 +1,20 @@ package com.yuanchu.limslaboratory.controller; - +import com.yuanchu.limslaboratory.clients.UserLoginUtils; +import com.yuanchu.limslaboratory.pojo.User; +import com.yuanchu.limslaboratory.shiro.realm.ShiroRealm; +import com.yuanchu.limslaboratory.utils.SpringUtils; +import com.yuanchu.limslaboratory.vo.Result; +import io.swagger.annotations.Api; +import io.swagger.annotations.ApiImplicitParam; +import io.swagger.annotations.ApiImplicitParams; +import io.swagger.annotations.ApiOperation; +import org.apache.shiro.SecurityUtils; +import org.apache.shiro.authc.IncorrectCredentialsException; +import org.apache.shiro.authc.UnknownAccountException; +import org.apache.shiro.authc.UsernamePasswordToken; +import org.apache.shiro.subject.Subject; +import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @@ -15,6 +29,38 @@ */ @RestController @RequestMapping("/user") +@Api(tags = "鐢ㄦ埛妯″潡") public class UserController { + @ApiOperation("鐢ㄦ埛鐧诲綍") + @ApiImplicitParams(value = { + @ApiImplicitParam(name = "account", value = "璐﹀彿", dataTypeClass = String.class, required = true), + @ApiImplicitParam(name = "password", value = "瀵嗙爜", dataTypeClass = String.class, required = true) + }) + @PostMapping("/login") + public Result<?> UserLogin(String account, String password){ + boolean loginSuccess = false; + Subject subject = SecurityUtils.getSubject(); + if (!subject.isAuthenticated()) { + UsernamePasswordToken usernamePasswordToken = new UsernamePasswordToken(account, password); + try { + subject.login(usernamePasswordToken); + loginSuccess = true; + } catch (UnknownAccountException e) { + return Result.fail(202, "娌℃湁鎵惧埌璇ヨ处鍙凤紝璇锋鏌ヨ緭鍏ワ紒"); + } catch (IncorrectCredentialsException e) { + return Result.fail(202, "瀵嗙爜涓嶅尮閰嶏紝璇锋鏌ヨ緭鍏ワ紒"); + } + } + if (loginSuccess) { + // 鑾峰彇shiroRealm涓殑鏁版嵁 + ShiroRealm bean = SpringUtils.getBean(ShiroRealm.class); + User user = bean.user; + user.setPassword(null); + UserLoginUtils bean1 = SpringUtils.getBean(UserLoginUtils.class); + return bean1.LoginExamine(user); + }else { + return Result.fail("鐧诲綍澶辫触"); + } + } } -- Gitblit v1.9.3