package com.casic.missiles.controller; import cn.hutool.core.util.StrUtil; import com.casic.missiles.core.application.enums.LoginType; import com.casic.missiles.core.base.controller.BaseController; import com.casic.missiles.core.model.auth.AuthUser; import com.casic.missiles.core.model.auth.CasicCustomToken; import com.casic.missiles.core.shiro.ShiroKit; import com.casic.missiles.core.util.RSAUtils; import com.casic.missiles.model.response.SuccessResponseData; import com.casic.missiles.modular.domain.constants.PermissionConstants; import com.casic.missiles.modular.interfaces.log.LogManager; import com.casic.missiles.modular.interfaces.log.factory.LogTaskFactory; import com.casic.missiles.modular.system.dto.LoginSuccessDTO; import lombok.extern.slf4j.Slf4j; import org.apache.shiro.subject.Subject; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; import java.security.NoSuchAlgorithmException; import java.util.Map; import static com.casic.missiles.core.util.HttpContext.getIp; /** * 仅为mock登录使用 * * @author lenovo */ @Controller @RequestMapping("/route") @Slf4j public class MockController extends BaseController { /** * 获取mockToken */ @GetMapping("/mockToken") @ResponseBody public Object mockToken(String username, String password) { super.getSession().setAttribute(PermissionConstants.IS_APP, false); SuccessResponseData resultData = new SuccessResponseData(); if (StrUtil.hasEmpty(username, password)) { username = "admin"; password = "111111"; } Subject currentUser = ShiroKit.getSubject(); try { Map<String, String> key = RSAUtils.genKeyPair(); ShiroKit.getSession().setAttribute(PermissionConstants.PRIVATE_KEY, key.get(RSAUtils.RSAPrivateKey)); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } //token自定义 CasicCustomToken token = new CasicCustomToken(username, password); token.setType(LoginType.PASSWORD); token.setRememberMe(false); try { currentUser.login(token); } catch (Exception e) { e.printStackTrace(); } AuthUser shiroUser = ShiroKit.getUser(); super.getSession().setAttribute("shiroUser", shiroUser); super.getSession().setAttribute("username", shiroUser.getAccount()); super.getSession().setAttribute(PermissionConstants.SESSION_KEY, shiroUser.getId()); LogManager.me().executeLog(LogTaskFactory.loginLog(shiroUser.getId(), getIp())); ShiroKit.getSession().setAttribute("sessionFlag", true); resultData.setData(new LoginSuccessDTO(ShiroKit.getSession().getId().toString(), null)); resultData.setMessage("登录成功"); return resultData; } }