日志自定义Tag
import java.util.concurrent.ConcurrentMap;
import java.util.concurrent.ConcurrentHashMap; /**
* Created by
*/
public class LogWrapperFactory {
private static ConcurrentMap<String, LogWrapper> concurrentMap = new ConcurrentHashMap<String, LogWrapper>(); public static LogWrapper getLogWrapper(Class clazz){
//使用java8语法优化代码
concurrentMap.computeIfAbsent(clazz.getName(), k->new LogWrapper(clazz));
return concurrentMap.get(clazz.getName()); }
}
import java.util.*;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.google.common.base.Strings;
import org.apache.commons.collections.CollectionUtils; /**
* Created by
*/
public class LogWrapper { private Logger logger;
private ThreadLocal<List<Map<String, Object>>> tagThreadLocal = new ThreadLocal<List<Map<String, Object>>>(); public LogWrapper(Class clazz) {
this.logger = LoggerFactory.getLogger(clazz.getName());
if (null == tagThreadLocal.get()) {
tagThreadLocal.set(new ArrayList<Map<String, Object>>());
}
} public void clearTags() {
this.tagThreadLocal.set(new ArrayList());
} public LogWrapper addTag(String tagName, Object tagValue) {
List<Map<String, Object>> list = (List) tagThreadLocal.get();
list = Optional.ofNullable(list).orElse(new ArrayList<Map<String, Object>>());
Map<String, Object> tmap = new HashMap<String, Object>();
tmap.put(tagName, tagValue);
list.add(tmap);
tagThreadLocal.set(list);
return this;
} public LogWrapper TAG(Object tagValue) {
addTag("TYPE", tagValue);
return this;
} public LogWrapper KBCODE(Object tagValue) {
addTag("KBCODE", tagValue);
return this;
} public LogWrapper SERIALNO(Object tagValue) {
addTag("SERIALNO", tagValue);
return this;
} private void commonWriteLog(LogType logType, String firstParam) {
StringBuilder tagsBuilder = new StringBuilder("[ThreadName=" + Thread.currentThread().getName()+"]"); List<Map<String, Object>> list = (List) tagThreadLocal.get();
if (CollectionUtils.isNotEmpty(list)) {
list.stream().forEach(itemMap->{itemMap.forEach((k,v)->{tagsBuilder.append("[" + Strings.nullToEmpty(k) + "=" + Strings.nullToEmpty(String.valueOf(v)) + "]");});});
}
switch (logType) {
case INFO:
logger.info(tagsBuilder.toString() + Strings.nullToEmpty(firstParam));
break;
case WARN:
logger.warn(tagsBuilder.toString() + Strings.nullToEmpty(firstParam));
break;
case ERROR:
logger.error(tagsBuilder.toString() + Strings.nullToEmpty(firstParam));
break;
default:
logger.info(tagsBuilder.toString() + Strings.nullToEmpty(firstParam));
}
clearTags();
} private void commonWriteLog(LogType logType, String firstParam, Object... content) {
StringBuilder tagsBuilder = new StringBuilder("[ThreadName=" + Thread.currentThread().getName()+"]"); List<Map<String, Object>> list = (List<Map<String, Object>>) tagThreadLocal.get();
if (CollectionUtils.isNotEmpty(list)) {
list.stream().forEach(itemMap->{itemMap.forEach((k,v)->{tagsBuilder.append("[" + Strings.nullToEmpty(k) + "=" + Strings.nullToEmpty(String.valueOf(v)) + "]");});});
}
switch (logType) {
case INFO:
logger.info(tagsBuilder.toString() + Strings.nullToEmpty(firstParam), content);
break;
case WARN:
logger.warn(tagsBuilder.toString() + Strings.nullToEmpty(firstParam), content);
break;
case ERROR:
logger.error(tagsBuilder.toString() + Strings.nullToEmpty(firstParam), content);
break;
default:
logger.info(tagsBuilder.toString() + Strings.nullToEmpty(firstParam), content);
}
clearTags();
} public void info(String firstParam) {
commonWriteLog(LogType.INFO, firstParam);
} public void info(String firstParam, Object... content) {
commonWriteLog(LogType.INFO, firstParam, content);
} public void warn(String firstParam) {
commonWriteLog(LogType.WARN, firstParam);
} public void warn(String firstParam, Object... content) {
commonWriteLog(LogType.WARN, firstParam, content);
} public void error(String firstParam) {
commonWriteLog(LogType.ERROR, firstParam);
} public void error(String firstParam, Object content) {
commonWriteLog(LogType.ERROR, firstParam, content);
} public static void main(String[] args) throws Exception{ // new Thread(() -> {
// LogWrapper log = LogWrapperFactory.getLogWrapper(LogWrapper.class);
// log.addTag("abc", "abc").addTag("def", "def").info("i am {},welcome!{}", "flory", "ttt");
// }).start();
//
// new Thread(() -> {
// LogWrapper log2 = LogWrapperFactory.getLogWrapper(WarrantController.class);
// log2.addTag("123", "123").addTag("456", "456").info("i am {},welcome!{}", "flory", "ttt");
// }).start(); // LogWrapper log3 = LogWrapperFactory.getLogWrapper(WarrantController.class);
// log3.addTag("abc", "abc").addTag("def", "def").info("i am {},welcome!{}", "flory", "ttt");
} private enum LogType {
INFO(1, "info"),
WARN(2, "warn"),
ERROR(3, "error"); private Integer code;
private String msg; LogType(Integer code, String msg) {
this.code = code;
this.msg = msg;
} public Integer getCode() {
return code;
} public void setCode(Integer code) {
this.code = code;
} public String getMsg() {
return msg;
} public void setMsg(String msg) {
this.msg = msg;
}
}
}
使用示例:
import com.alibaba.fastjson.JSON;
import com.google.common.base.Throwables;
import com.pingan.bloan.genesis.logwrapper.LogWrapper;
import com.pingan.bloan.genesis.logwrapper.LogWrapperFactory;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils; import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map; /**
* Created by
*/
public class HttpExecute { private static LogWrapper loggerWrapper = LogWrapperFactory.getLogWrapper(HttpExecute.class);
private static final String CONTENT_TYPE = "application/json;charset=UTF-8";
private static final String UTF_8 = "UTF-8"; /**
* post方法
*
* @param url
* @param paramMap
* @return
*/
public static String executePost(String url, Map<String, Object> paramMap) {
HttpResponse response = null;
String sResponse = "";
try {
loggerWrapper.TAG("executePost").info("start visit outside resource, url:{}, prams:{}", url, JSON.toJSONString(paramMap));
CloseableHttpClient httpClient = HttpClients.createDefault();
HttpPost httpPost = new HttpPost(url);
HttpEntity entity = new StringEntity(JSON.toJSONString(paramMap), UTF_8);
httpPost.setEntity(entity); RequestConfig requestConfig = RequestConfig.custom().setConnectionRequestTimeout(10000).setConnectTimeout(10000).build();
httpPost.setConfig(requestConfig); httpPost.addHeader("Content-Type", CONTENT_TYPE);
httpPost.addHeader("Accept", CONTENT_TYPE); loggerWrapper.TAG("HttpClientService").info("httpClient config finished, start invoking...");
response = httpClient.execute(httpPost);
loggerWrapper.TAG("HttpClientService").info("httpClient finished response:{}", JSON.toJSONString(response)); sResponse = EntityUtils.toString(response.getEntity());
loggerWrapper.TAG("HttpClientService").info("invoke finished, response entity:{}", JSON.toJSONString(sResponse));
} catch (UnsupportedEncodingException e) {
loggerWrapper.TAG("executePost").error("UnsupportedEncodingException, details:{}", Throwables.getStackTraceAsString(e));
} catch (ClientProtocolException e) {
loggerWrapper.TAG("executePost").error("ClientProtocolException, details:{}", Throwables.getStackTraceAsString(e));
} catch (IOException e) {
loggerWrapper.TAG("executePost").error("IOException, details:{}", Throwables.getStackTraceAsString(e));
}
return sResponse;
}
}
日志自定义Tag的更多相关文章
- jsp如何自定义tag的标签库?
虽然和上一次的使用自定义的tld标签简化jsp的繁琐操作的有点不同,但是目的也是一致的.自定义tag比较简单. 1.新建tag标签 在WEB-INF目录下新建一个tags的文件夹,是自定义tag标签的 ...
- ASP.NET Core MVC – 自定义 Tag Helpers
ASP.NET Core Tag Helpers系列目录,共四篇: ASP.NET Core MVC Tag Helpers 介绍 ASP.NET Core MVC – Caching Tag Hel ...
- 自定义tag标签-实现long类型转换成Date类型
数据库里存储的是bigint型的时间,entity实体中存放的是long类型的标签,现在想输出到jsp页面,由于使用的是jstl标签,而要显示的是可读的时间类型,找来找去有个 fmt:formatDa ...
- jsp中 自定义 tag的几种方式
在jsp文件中,可以引用tag和tld文件. 1.对于tag文件,使用tagdir引用(这个直接是引用的后缀tag文件的jsp文件) <%@ taglib prefix="ui&quo ...
- Jsp 自定义tag标签
1转自:https://blog.csdn.net/yusimiao/article/details/46835617 Jsp自定义tag标签 自定义tag标签的好处 程序员可以自定一些特定功能的标记 ...
- 自定义tag标签的方法
JSP1.0中可以通过继承TagSupport或者BodyTagSupport来实现自定义的tag处理方法. JSP2.0中也支持另外一种更为简单的自定tag的方法,那就是直接讲JSP代码保存成*.t ...
- JSP自定义tag控件标签
JSP支持自定tag的方法,那就是直接讲JSP代码保存成*.tag或者*.tagx的标签定义文件.tag和tagx文件不仅支持经典jsp代码,各种标签模版代码,还支持xml样式的jsp指令代码. 按照 ...
- struts2 自定义tag标签
在项目中可能有很多相同的jsp页面表示功能,这时可以使用自定义的tag进行定义,渐少重复的工作量便于日后维护! 下面就基于struts2进行自定义标签的定义与实现: 首先:自定义类MyTag继承str ...
- JSP自定义tag
前端需要调用后端的配置,想起velocity-tools.然而jsp的话,目前只能想到tag和EL表达式了. Tag相当好写,jsp2.0提供了简化写法: 编写一个java类: public clas ...
随机推荐
- JavaWeb温习之HttpServletResquest对象
HttpServletRequest对象代表客户端的请求,当客户端通过HTTP协议访问服务器时,HTTP请求头中的所有信息都封装在这个对象中,通过这个对象提供的方法,可以获得客户端请求的所有信息. 1 ...
- weblogic新漏洞学习cve-2017-10271
一.原理: 很明显啦,readobject又出来背锅了,一个XML的反序列化漏洞导致的命令执行. 具体原理我看不懂java代码的我也只能学习别人的分析.给出一篇参考文章,写的非常详细: 漏洞原理 二. ...
- Linux Netfilter注册钩子点
注册钩子点首先要包含响应的头文件,因为这应该已经属于对kernel的编程了. #include <linux/module.h> #include <linux/kernel.h&g ...
- 如何设置Eclipse工作区默认编辑宽度
1)打开Window => Preferences窗口 2)打开Formatter属性页从Java => CodeStyle => Formatter 3) 单击New创建一个自己 ...
- MUI极简的JS函数
模块:utils http://dev.dcloud.net.cn/mui/util/#event mui.init(); mui框架将很多功能配置都集中在mui.init方法中,要使用某项功能,只需 ...
- Web安全开发建议
版权声明:原创作品,如需转载,请与作者联系.否则将追究法律责任. Web安全问题,很多时候会被人所忽略,安全漏洞造成了很多不必要的维护和开发任务,产生的问题有时候更是致命的. 实际上,只要我们养成一些 ...
- T-SQL数据库备份
/*1.--得到数据库的文件目录 @dbname 指定要取得目录的数据库名 如果指定的数据不存在,返回安装SQL时设置的默认数据目录 如果指定NULL,则返回默认的SQL备份目录名 */ /*--调用 ...
- Asp.net页面生存周期【转】
ASP.NET 页面生存周期中的关键事件 要想深入ASP.NET页面编程,就必须了解页面生存周期各个阶段及相关事件.重写相关事件和方法可以使我们更好的控制页面呈现. # 事件或方法 功能 描述 1 I ...
- js jquery.pagination.js分页
1.使用插件为 jquery.pagination.js ,如果没有这个js文件的话,我可以给发个. 首先引用 jquery.pagination.js (分页js),跟pagination.css( ...
- vs 2015
基于应用要求和要使用的语言选择所需工具. Xamarin for Visual Studio:针对所有设备的 C# 中的常用基本代码 Apache Cordova with Visual Studio ...