《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门,即可获取!
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);
map.put(key, value);
}
return map;
最后的话
无论是哪家公司,都很重视Spring框架技术,重视基础,所以千万别小看任何知识。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。
同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,好了希望这篇文章对大家有帮助!
部分截图:
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门,即可获取!
,所以千万别小看任何知识。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。
同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,好了希望这篇文章对大家有帮助!**
部分截图:
[外链图片转存中…(img-RvkmwYTk-1714657570794)]
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门,即可获取!