com.fastchar.extjs.action.ExtManagerAction Maven / Gradle / Ivy
package com.fastchar.extjs.action;
import com.fastchar.annotation.AFastRoute;
import com.fastchar.core.FastAction;
import com.fastchar.core.FastChar;
import com.fastchar.core.FastEntity;
import com.fastchar.core.FastHandler;
import com.fastchar.extjs.FastExtConfig;
import com.fastchar.extjs.annotation.AFastLog;
import com.fastchar.extjs.annotation.AFastSession;
import com.fastchar.extjs.core.heads.FastHeadExtInfo;
import com.fastchar.extjs.entity.*;
import com.fastchar.extjs.interfaces.IFastManagerListener;
import com.fastchar.utils.FastDateUtils;
import com.fastchar.utils.FastMD5Utils;
import com.fastchar.utils.FastStringUtils;
import java.util.List;
import java.util.concurrent.ConcurrentHashMap;
@AFastRoute({"/controller"})
public class ExtManagerAction extends FastAction {
public static final ConcurrentHashMap MANAGER_SINGLE_LOGIN_CODE = new ConcurrentHashMap<>();
@Override
protected String getRoute() {
return "/manager";
}
/**
* 后台管理员登录
* 参数:
* loginName 登录名{String}
* loginPassword 登录密码【MD5加密后提交】 {String}
*/
@AFastLog(value = "${managerRole}【${managerName}】进行了登录!", type = "管理员登录")
public void login() {
String loginName = getParam("loginName", true);
setRequestAttr("managerName", loginName);
setRequestAttr("managerRole", "后台管理员");
boolean isLoginByName = false;
//存在超级管理员的会话信息,调用了登录接口,以登录名查询
ExtManagerEntity session = ExtManagerEntity.getSession(this);
if (session != null) {
isLoginByName = true;
}
FastExtConfig extConfig = FastExtConfig.getInstance();
if (!isLoginByName) {
FastHeadExtInfo extInfo = extConfig.getExtInfo("login-type");
if (extInfo != null) {
if (!extInfo.getValue().equalsIgnoreCase("normal")) {
String validateCode = FastStringUtils.defaultValue(getSession("validateCode"), FastStringUtils.buildUUID());
if (!validateCaptcha(validateCode) && !validateCaptcha(getParam("validateCode", true))) {
resetCaptcha();
responseJson(-3, "登录失败,验证码错误!");
return;
}
}
}
}
String loginPassword = getParam("loginPassword", true);
ExtManagerEntity managerEntity = ExtManagerEntity.getInstance().login(loginName, loginPassword);
if (isLoginByName) {
managerEntity = ExtManagerEntity.getInstance().getByLoginName(loginName);
}
String errorInfo = "";
if (extConfig.isManagerLoginErrorLimit()) {
int errorCount = ExtManagerErrorEntity.dao().countTodayError(loginName);
int nextCount = Math.max(7 - errorCount, 0);
if (nextCount > 0) {
errorInfo = "今日还剩余" + nextCount + "次!";
} else {
responseJson(-1, "您今日登录错误次数超限!请明日再试!");
}
}
ExtManagerErrorEntity payErrorEntity = new ExtManagerErrorEntity();
payErrorEntity.set("managerLoginName", loginName);
if (managerEntity != null) {
if (managerEntity.getManagerRole() == null || managerEntity.getManagerRole().getRoleId() <= 0) {
responseJson(-1, "登录失败!您的账户未分配角色!");
}
if (managerEntity.getManagerRole().getInt("roleType", -1) < 0) {
responseJson(-1, "登录失败!您的账户角色的类型异常!");
}
if (managerEntity.getInt("managerState") == ExtManagerEntity.ManagerStateEnum.禁用.ordinal()) {
responseJson(-1, "登录失败!您的账号已被禁用!");
}
IFastManagerListener iFastManager = FastChar.getOverrides().singleInstance(false, IFastManagerListener.class);
if (iFastManager != null) {
FastHandler handler = new FastHandler();
iFastManager.onManagerLogin(managerEntity, handler);
if (handler.getCode() != 0) {
responseJson(-1, handler.getError());
}
}
setRequestAttr("managerName", managerEntity.getString("managerName"));
ExtManagerRoleEntity extManagerRoleEntity = managerEntity.getObject("role");
if (extManagerRoleEntity != null) {
setRequestAttr("managerRole", extManagerRoleEntity.getRoleName());
} else {
setRequestAttr("managerRole", "管理员");
}
managerEntity.set("lastLoginTime", FastDateUtils.getDateString());
managerEntity.update();
ExtManagerEntity.setSession(this, managerEntity);
String loginCode = FastStringUtils.buildOnlyCode("EXT");
setSession("loginCode", loginCode);
if (managerEntity.getInt("onlineType") == ExtManagerEntity.OnlineTypeEnum.单个终端.ordinal()) {
MANAGER_SINGLE_LOGIN_CODE.put(managerEntity.getManagerId(), loginCode);
} else {
MANAGER_SINGLE_LOGIN_CODE.remove(managerEntity.getManagerId());
}
payErrorEntity.delete("managerLoginName");
resetCaptcha();
responseJson(0, "登录成功!");
} else {
payErrorEntity.save();
resetCaptcha();
responseJson(-2, "登录失败,用户名或密码错误!" + errorInfo);
}
}
/**
* 后台操作功能时进行安全验证
* 参数:
* loginName 登录名{String}
* loginPassword 登录密码【MD5加密后提交】 {String}
* operate 操作的功能介绍
* timeout 验证的有效期,单位秒 默认:24小时,
*/
@AFastLog(value = "${managerRole}【${managerName}】进行了操作【${operate}】验证!", type = "安全验证")
public void valid() {
String loginName = getParam("loginName", true);
String operate = getParam("operate", "安全操作验证");
int time = getParamToInt("timeout", 24 * 60 * 60);
setRequestAttr("managerName", loginName);
setRequestAttr("managerRole", "后台管理员");
setRequestAttr("operate", operate);
FastHeadExtInfo extInfo = FastExtConfig.getInstance().getExtInfo("login-type");
if (extInfo != null) {
if (!extInfo.getValue().equalsIgnoreCase("normal")) {
if (!validateCaptcha(getParam("validateCode", true))) {
responseJson(-3, "验证失败,验证码错误!");
return;
}
}
}
String loginPassword = getParam("loginPassword", true);
ExtManagerEntity managerEntity = ExtManagerEntity.getInstance().login(loginName, loginPassword);
int errorCount = ExtManagerErrorEntity.dao().countTodayError(loginName);
int nextCount = Math.max(7 - errorCount, 0);
String errorInfo = null;
if (nextCount > 0) {
errorInfo = "今日还剩余" + nextCount + "次!";
} else {
responseJson(-1, "您今日登录错误次数超限!请明日再试!");
}
ExtManagerErrorEntity payErrorEntity = new ExtManagerErrorEntity();
payErrorEntity.set("managerLoginName", loginName);
if (managerEntity != null) {
if (managerEntity.getInt("managerState") == ExtManagerEntity.ManagerStateEnum.禁用.ordinal()) {
responseJson(-1, "验证失败!您的账号已被禁用!");
}
IFastManagerListener iFastManager = FastChar.getOverrides().singleInstance(false, IFastManagerListener.class);
if (iFastManager != null) {
FastHandler handler = new FastHandler();
iFastManager.onManagerLogin(managerEntity, handler);
if (handler.getCode() != 0) {
responseJson(-1, handler.getError());
}
}
payErrorEntity.delete("managerLoginName");
if (!operate.startsWith("^")) {
//不需要存的操作
setCookie("ValidOperate" + FastMD5Utils.MD5(operate), true, time);
}
responseJson(0, "验证成功!");
} else {
payErrorEntity.save();
responseJson(-2, "验证失败,用户名或密码错误!" + errorInfo);
}
}
/**
* 退出后台登录
*/
@AFastLog(value = "${managerRole}【${managerName}】退出了登录!", type = "管理员退出")
public void logout() {
ExtManagerEntity managerEntity = ExtManagerEntity.getSession(this);
if (managerEntity != null) {
setRequestAttr("managerName", managerEntity.getManagerName());
ExtManagerRoleEntity extManagerRoleEntity = managerEntity.getObject("role");
setRequestAttr("managerRole", extManagerRoleEntity.getRoleName());
} else {
setRequestAttr("managerName", "会话失效账户");
}
ExtManagerEntity.removeSession(this);
responseJson(0, "退出成功!");
}
/**
* 重置管理员账户密码
* 参数:
* managerId 管理员Id
* newPassword 新的登录密码【明文】
*/
@AFastSession
@AFastLog(value = "${managerRole}【${managerName}】重置了登录密码!", type = "密码重置")
public void resetPassword() {
ExtManagerEntity sessionUser = ExtManagerEntity.getSession(this);
setRequestAttr("managerName", sessionUser.getString("managerName"));
ExtManagerRoleEntity extManagerRoleEntity = sessionUser.getObject("role");
setRequestAttr("managerRole", extManagerRoleEntity.getRoleName());
ExtManagerEntity managerEntity = new ExtManagerEntity();
managerEntity.set("managerId", getParamToInt("managerId", true));
managerEntity.set("managerPassword", getParam("newPassword", true));
if (managerEntity.update()) {
responseJson(0, "密码重置成功!");
} else {
responseJson(-1, "密码重置失败!");
}
}
/**
* 修改管理员密码
* 参数:
* managerId 管理员Id
* managerPassword 当前登录密码【明文】
* newPassword 新的登录密码【明文】
* reNewPassword 确认新的登录密码【明文】
*/
@AFastSession
@AFastLog(value = "${managerRole}【${managerName}】修改了登录密码!", type = "密码重置")
public void modifyPassword() {
ExtManagerEntity sessionUser = ExtManagerEntity.getSession(this);
setRequestAttr("managerName", sessionUser.getString("managerName"));
ExtManagerRoleEntity extManagerRoleEntity = sessionUser.getObject("role");
setRequestAttr("managerRole", extManagerRoleEntity.getRoleName());
ExtManagerEntity managerEntity = ExtManagerEntity.getInstance().selectById(getParamToInt("managerId", true));
String newPassword = getParam("newPassword", true);
String reNewPassword = getParam("reNewPassword", true);
String managerPassword = getParam("managerPassword", true);
String oldPassword = managerEntity.getString("managerPassword");
if (!newPassword.equals(reNewPassword)) {
responseJson(-1, "两次密码输入不一致!");
return;
}
if (!FastMD5Utils.MD5(managerPassword).equals(oldPassword)) {
responseJson(-1, "当前密码输入错误!");
return;
}
managerEntity.set("managerPassword", newPassword);
if (managerEntity.update()) {
responseJson(0, "密码修改成功!");
} else {
responseJson(-1, "密码修改失败!");
}
}
/**
* 更新管理员权限与角色权限相同
* 参数:
* managerId 管理员Id
*/
@AFastSession
@AFastLog(value = "${managerRole}【${managerName}】同步了管理的角色权限!", type = "权限同步")
public void updatePower() {
ExtManagerEntity sessionUser = ExtManagerEntity.getSession(this);
setRequestAttr("managerName", sessionUser.getString("managerName"));
ExtManagerRoleEntity extManagerRoleEntity = sessionUser.getObject("role");
setRequestAttr("managerRole", extManagerRoleEntity.getRoleName());
List managerIds = getParamToIntList("managerId");
for (Integer managerId : managerIds) {
ExtManagerEntity byId = ExtManagerEntity.dao().selectById(managerId);
if (byId == null) {
continue;
}
ExtManagerRoleEntity managerRole = ExtManagerRoleEntity.dao().selectById(byId.getRoleId());
if (managerRole != null) {
byId.set("managerMenuPower", managerRole.getRoleMenuPower());
byId.set("managerExtPower", managerRole.getRoleExtPower());
byId.set("powerState", 0);
byId.update();
}
}
responseJson(0, "同步成功!");
}
/**
* 获取系统待办事项
* 参数:
* noticeId 获取指定的noticeId之后的数据
*/
@AFastSession
public void waitNotice() throws Exception {
setLog(false);
List noticeId = getParamToIntList("noticeId");
ExtManagerEntity sessionUser = ExtManagerEntity.getSession(this);
List> list = ExtSystemNoticeEntity.dao().getList(sessionUser.getLayerValue(), noticeId.toArray(new Integer[]{}));
responseJson(0, "获取成功!", list);
}
/**
* 更新待办事项
* 参数:
* noticeId 事务Id
*/
@AFastSession
public void doneNotice() {
int noticeId = getParamToInt("noticeId", true);
ExtSystemNoticeEntity extSystemNoticeEntity = ExtSystemNoticeEntity.newInstance();
extSystemNoticeEntity.set("noticeId", noticeId);
extSystemNoticeEntity.set("noticeState", ExtSystemNoticeEntity.ExtSystemNoticeStateEnum.已处理.ordinal());
extSystemNoticeEntity.update();
responseJson(0, "标记成功!");
}
/**
* 清空待办事项
*/
@AFastSession
public void clearNotice() {
ExtManagerEntity sessionUser = ExtManagerEntity.getSession(this);
ExtSystemNoticeEntity.dao().clearNotice(sessionUser.getLayerValue());
responseJson(0, "清空成功!");
}
/**
* 清空登录错误记录
*/
public void clearLoginError() {
String loginName = getParam("loginName", true);
ExtManagerErrorEntity payErrorEntity = new ExtManagerErrorEntity();
payErrorEntity.set("managerLoginName", loginName);
payErrorEntity.delete("managerLoginName");
responseJson(0, "清除成功!");
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy