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;
|
|
/**
|
* <p>
|
* 前端控制器
|
* </p>
|
*
|
* @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<String, String> 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为空!");
|
}
|
|
|
}
|
|
}
|