MongoClientURI connectionString = new MongoClientURI(connectionUrl);
mongoClient = new MongoClient(connectionString);
mongoDatabase = mongoClient.getDatabase(databaseName);
logsCollection = mongoDatabase.getCollection(collectionName, BasicDBObject.class);
}
logsCollection.insertOne((BasicDBObject) loggingEvent.getMessage());
}
@Override
public void close() {
if(mongoClient != null) {
mongoClient.close();
}
}
@Override
public boolean requiresLayout() {
return false;
}
// 省略getter和setter
}
-
定义MongoDB的配置参数,可通过log4j.properties配置:
-
connectionUrl:连接mongodb的串
-
databaseName:数据库名
-
collectionName:集合名
-
定义MongoDB的连接和操作对象,根据log4j.properties配置的参数初始化:
-
mongoClient:mongodb的连接客户端
-
mongoDatabase:记录日志的数据库
-
logsCollection:记录日志的集合
-
重写append函数:
-
根据log4j.properties中的配置创建mongodb连接
-
LoggingEvent提供getMessage()函数来获取日志消息
-
往配置的记录日志的collection中插入日志消息
-
重写close函数:关闭mongodb的
配置log4j.properties
设置名为mongodb的logger:
-
记录INFO级别日志
-
appender实现为com.didispace.log.MongoAppende
-
mongodb连接地址:mongodb://localhost:27017
-
mongodb数据库名:logs
-
mongodb集合名:logs_request
log4j.logger.mongodb=INFO, mongodb
mongodb输出
log4j.appender.mongodb=com.didispace.log.MongoAppender
log4j.appender.mongodb.connectionUrl=mongodb://localhost:27017
log4j.appender.mongodb.databaseName=logs
log4j.appender.mongodb.collectionName=logs_request
切面中使用mongodb logger
修改后的代码如下,主要做了以下几点修改:
-
logger取名为mongodb的
-
通过getBasicDBObject函数从HttpServletRequest和JoinPoint对象中获取请求信息,并组装成BasicDBObject
-
getHeadersInfo函数从HttpServletRequest中获取header信息
-
通过logger.info(),输出BasicDBObject对象的信息到mongodb
@Aspect
@Order(1)
@Component
public class WebLogAspect {
private Logger logger = Logger.getLogger(“mongodb”);
@Pointcut(“execution(public * com.didispace.web….(…))”)
public void webLog(){}
@Before(“webLog()”)
public void doBefore(JoinPoint joinPoint) throws Throwable {
// 获取HttpServletRequest
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
HttpServletRequest request = attributes.getRequest();
// 获取要记录的日志内容
BasicDBObject logInfo = getBasicDBObject(request, joinPoint);
logger.info(logInfo);
}
private BasicDBObject getBasicDBObject(HttpServletRequest request, JoinPoint joinPoint) {
// 基本信息
BasicDBObject r = new BasicDBObject();
r.append(“requestURL”, request.getRequestURL().toString());
r.append(“requestURI”, request.getRequestURI());
r.append(“queryString”, request.getQueryString());
r.append(“remoteAddr”, request.getRemoteAddr());
r.append(“remoteHost”, request.getRemoteHost());
r.append(“remotePort”, request.getRemotePort());
r.append(“localAddr”, request.getLocalAddr());
r.append(“localName”, request.getLocalName());
r.append(“method”, request.getMethod());
r.append(“headers”, getHeadersInfo(request));
r.append(“parameters”, request.getParameterMap());
r.append(“classMethod”, joinPoint.getSignature().getDeclaringTypeName() + “.” + joinPoint.getSignature().getName());
r.append(“args”, Arrays.toString(joinPoint.getArgs()));
return r;
}
private Map<String, String> getHeadersInfo(HttpServletRequest request) {
Map<String, String> map = new HashMap<>();
Enumeration headerNames = request.getHeaderNames();
while (headerNames.hasMoreElements()) {
String key = (String) headerNames.nextElement();
String value = request.getHeader(key);
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!**
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!