package com.yuanchu.limslaboratory.controller; import com.yuanchu.limslaboratory.clients.UserLoginUtils; import com.yuanchu.limslaboratory.pojo.Enterprise; import com.yuanchu.limslaboratory.pojo.User; import com.yuanchu.limslaboratory.service.UserService; import com.yuanchu.limslaboratory.shiro.realm.ShiroRealm; import com.yuanchu.limslaboratory.utils.SpringUtils; import com.yuanchu.limslaboratory.vo.Result; import io.swagger.annotations.*; 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.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import java.util.HashMap; import java.util.Map; /** *

* 前端控制器 *

* * @author 江苏鵷雏网络科技有限公司 * @since 2023-07-07 */ @RestController @RequestMapping("/user") @Api(tags = "用户模块") public class UserController { @Autowired private UserService userService; @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("登录失败"); } } @PostMapping("/getUserById") @ApiOperation("获取指定用户id的用户信息和企业信息") @ApiImplicitParams(value = { @ApiImplicitParam(value = "用户id", name = "userId", dataTypeClass = Integer.class, required = true) }) public Result getUserById(int userId) { try { Map map = userService.selectUserByUserId(userId); User user = new User(map.get("account"),map.get("uname"),map.get("phone"),map.get("email"),map.get("info")); Enterprise enterprise = new Enterprise(map.get("name"),map.get("byname"),map.get("link_name"),map.get("link_phone")); Map map1 = new HashMap<>(); map1.put("enterprise", enterprise); map1.put("user", user); return Result.success(map1); } catch (Exception e) { return Result.fail("用户id为空!"); } } }