parent
464ac600d4
commit
f97d25ef69
@ -1,107 +1,123 @@
|
|||||||
package com.archive.framework.manager.factory
|
package com.archive.framework.manager.factory
|
||||||
|
|
||||||
;
|
;
|
||||||
|
|
||||||
import com.archive.common.utils.ServletUtils;
|
|
||||||
import com.archive.common.utils.security.ShiroUtils;
|
|
||||||
import com.archive.project.monitor.online.domain.OnlineSession;
|
|
||||||
import com.archive.project.monitor.operlog.domain.OperLog;
|
|
||||||
import eu.bitwalker.useragentutils.UserAgent;
|
|
||||||
import java.util.TimerTask;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public class AsyncFactory
|
|
||||||
{
|
|
||||||
private static final Logger sys_user_logger = LoggerFactory.getLogger("sys-user");
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public static TimerTask syncSessionToDb(OnlineSession session) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public static TimerTask recordOper(OperLog operLog) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public static TimerTask recordLogininfor(String username, String status, String message, Object... args) {
|
|
||||||
UserAgent userAgent = UserAgent.parseUserAgentString(ServletUtils.getRequest().getHeader("User-Agent"));
|
|
||||||
String ip = ShiroUtils.getIp();
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
import com.archive.common.constant.Constants;
|
||||||
|
import com.archive.common.utils.AddressUtils;
|
||||||
|
import com.archive.common.utils.LogUtils;
|
||||||
|
import com.archive.common.utils.ServletUtils;
|
||||||
|
import com.archive.common.utils.StringUtils;
|
||||||
|
import com.archive.common.utils.security.ShiroUtils;
|
||||||
|
import com.archive.common.utils.spring.SpringUtils;
|
||||||
|
import com.archive.project.monitor.logininfor.domain.Logininfor;
|
||||||
|
import com.archive.project.monitor.logininfor.service.LogininforServiceImpl;
|
||||||
|
import com.archive.project.monitor.online.domain.OnlineSession;
|
||||||
|
import com.archive.project.monitor.online.domain.UserOnline;
|
||||||
|
import com.archive.project.monitor.online.service.IUserOnlineService;
|
||||||
|
import com.archive.project.monitor.operlog.domain.OperLog;
|
||||||
|
import com.archive.project.monitor.operlog.service.IOperLogService;
|
||||||
|
import eu.bitwalker.useragentutils.UserAgent;
|
||||||
|
|
||||||
/* Location: C:\Users\Administrator\Desktop\extracted.zip!\extracted\BOOT-INF\classes\com\archive\framework\manager\factory\AsyncFactory.class
|
import java.util.TimerTask;
|
||||||
* Java compiler version: 8 (52.0)
|
|
||||||
* JD-Core Version: 1.1.3
|
import org.slf4j.Logger;
|
||||||
*/
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
|
||||||
|
public class AsyncFactory {
|
||||||
|
private static final Logger sys_user_logger = LoggerFactory.getLogger("sys-user");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 同步session到数据库
|
||||||
|
*
|
||||||
|
* @param session 在线用户会话
|
||||||
|
* @return 任务task
|
||||||
|
*/
|
||||||
|
public static TimerTask syncSessionToDb(final OnlineSession session) {
|
||||||
|
return new TimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
UserOnline online = new UserOnline();
|
||||||
|
online.setSessionId(String.valueOf(session.getId()));
|
||||||
|
online.setDeptName(session.getDeptName());
|
||||||
|
online.setLoginName(session.getLoginName());
|
||||||
|
online.setStartTimestamp(session.getStartTimestamp());
|
||||||
|
online.setLastAccessTime(session.getLastAccessTime());
|
||||||
|
online.setExpireTime(session.getTimeout());
|
||||||
|
online.setIpaddr(session.getHost());
|
||||||
|
online.setLoginLocation(AddressUtils.getRealAddressByIP(session.getHost()));
|
||||||
|
online.setBrowser(session.getBrowser());
|
||||||
|
online.setOs(session.getOs());
|
||||||
|
online.setStatus(session.getStatus());
|
||||||
|
online.setSession(session);
|
||||||
|
SpringUtils.getBean(IUserOnlineService.class).saveOnline(online);
|
||||||
|
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 操作日志记录
|
||||||
|
*
|
||||||
|
* @param operLog 操作日志信息
|
||||||
|
* @return 任务task
|
||||||
|
*/
|
||||||
|
public static TimerTask recordOper(final OperLog operLog) {
|
||||||
|
return new TimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
// 远程查询操作地点
|
||||||
|
operLog.setOperLocation(AddressUtils.getRealAddressByIP(operLog.getOperIp()));
|
||||||
|
SpringUtils.getBean(IOperLogService.class).insertOperlog(operLog);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 记录登录信息
|
||||||
|
*
|
||||||
|
* @param username 用户名
|
||||||
|
* @param status 状态
|
||||||
|
* @param message 消息
|
||||||
|
* @param args 列表
|
||||||
|
* @return 任务task
|
||||||
|
*/
|
||||||
|
public static TimerTask recordLogininfor(final String username, final String status, final String message, final Object... args) {
|
||||||
|
final UserAgent userAgent = UserAgent.parseUserAgentString(ServletUtils.getRequest().getHeader("User-Agent"));
|
||||||
|
final String ip = ShiroUtils.getIp();
|
||||||
|
return new TimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
String address = AddressUtils.getRealAddressByIP(ip);
|
||||||
|
StringBuilder s = new StringBuilder();
|
||||||
|
s.append(LogUtils.getBlock(ip));
|
||||||
|
s.append(address);
|
||||||
|
s.append(LogUtils.getBlock(username));
|
||||||
|
s.append(LogUtils.getBlock(status));
|
||||||
|
s.append(LogUtils.getBlock(message));
|
||||||
|
// 打印信息到日志
|
||||||
|
sys_user_logger.info(s.toString(), args);
|
||||||
|
// 获取客户端操作系统
|
||||||
|
String os = userAgent.getOperatingSystem().getName();
|
||||||
|
// 获取客户端浏览器
|
||||||
|
String browser = userAgent.getBrowser().getName();
|
||||||
|
// 封装对象
|
||||||
|
Logininfor logininfor = new Logininfor();
|
||||||
|
logininfor.setLoginName(username);
|
||||||
|
logininfor.setIpaddr(ip);
|
||||||
|
logininfor.setLoginLocation(address);
|
||||||
|
logininfor.setBrowser(browser);
|
||||||
|
logininfor.setOs(os);
|
||||||
|
logininfor.setMsg(message);
|
||||||
|
// 日志状态
|
||||||
|
if (StringUtils.equalsAny(status, Constants.LOGIN_SUCCESS, Constants.LOGOUT, Constants.REGISTER)) {
|
||||||
|
logininfor.setStatus(Constants.SUCCESS);
|
||||||
|
} else if (Constants.LOGIN_FAIL.equals(status)) {
|
||||||
|
logininfor.setStatus(Constants.FAIL);
|
||||||
|
}
|
||||||
|
// 插入数据
|
||||||
|
SpringUtils.getBean(LogininforServiceImpl.class).insertLogininfor(logininfor);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in new issue