java110
2023-08-11 3424a01617671b3ed919a9aa878c03b1e0e4c897
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
package com.java110.core.factory;
 
import com.java110.dto.log.TransactionOutLogDto;
import com.java110.intf.common.ITransactionOutLogV1ServiceSMO;
import com.java110.po.log.TransactionOutLogPo;
import com.java110.utils.cache.MappingCache;
import com.java110.utils.constant.MappingConstant;
import com.java110.utils.constant.ServiceConstant;
import com.java110.utils.factory.ApplicationContextFactory;
import com.java110.utils.util.StringUtil;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
 
public class LogFactory {
 
 
    /**
     * 保存对外交互日志
     *
     * @param url            地址
     * @param reqStr         请求参数
     * @param responseEntity 返回参数
     */
    public static void saveOutLog(String url, String reqStr, ResponseEntity responseEntity) {
        saveOutLog(url, "无", 0, null, reqStr, responseEntity);
    }
 
    /**
     * 保存对外交互日志
     *
     * @param url            地址
     * @param method         方法
     * @param reqStr         请求参数
     * @param responseEntity 返回参数
     */
    public static void saveOutLog(String url, String method, String reqStr, ResponseEntity responseEntity) {
        saveOutLog(url, method, 0, null, reqStr, responseEntity);
 
    }
 
    /**
     * 保存对外交互日志
     *
     * @param url            地址
     * @param method         方法
     * @param costTime       所需时间
     * @param reqHeaders     请求头
     * @param reqStr         请求参数
     * @param responseEntity 返回参数
     */
    public static void saveOutLog(String url, String method, long costTime, HttpHeaders reqHeaders, String reqStr, ResponseEntity responseEntity) {
        try {
            String logServiceCode = MappingCache.getValue(MappingConstant.DOMAIN_SYSTEM_SWITCH, MappingCache.CALL_OUT_LOG);
 
            if (StringUtil.isEmpty(logServiceCode) || "OFF".equalsIgnoreCase(logServiceCode) || url.startsWith(ServiceConstant.BOOT_SERVICE_ORDER_URL)) {
                return;
            }
            ITransactionOutLogV1ServiceSMO transactionOutLogV1InnerServiceSMO = null;
            try {
                transactionOutLogV1InnerServiceSMO
                        = ApplicationContextFactory.getBean(ITransactionOutLogV1ServiceSMO.class.getName(), ITransactionOutLogV1ServiceSMO.class);
            } catch (Exception e) {
                transactionOutLogV1InnerServiceSMO
                        = ApplicationContextFactory.getBean("transactionOutLogV1ServiceSMOImpl", ITransactionOutLogV1ServiceSMO.class);
            }
            if (transactionOutLogV1InnerServiceSMO == null) {
                transactionOutLogV1InnerServiceSMO
                        = ApplicationContextFactory.getBean("transactionOutLogV1ServiceSMOImpl", ITransactionOutLogV1ServiceSMO.class);
            }
 
            TransactionOutLogPo transactionOutLogPo = new TransactionOutLogPo();
            //todo 分析日志类型
            String logType = analysisLogType(url);
 
            transactionOutLogPo.setCostTime(costTime + "");
            transactionOutLogPo.setLogId(GenerateCodeFactory.getGeneratorId("11"));
            transactionOutLogPo.setRequestHeader(reqHeaders == null ? "{}" : reqHeaders.toSingleValueMap().toString());
            transactionOutLogPo.setRequestMessage(reqStr);
            transactionOutLogPo.setRequestMethod(method);
            transactionOutLogPo.setRequestUrl(url);
            transactionOutLogPo.setResponseHeader(responseEntity.getHeaders() == null ? "" : responseEntity.getHeaders().toSingleValueMap().toString());
            transactionOutLogPo.setResponseMessage(responseEntity.getBody().toString());
            transactionOutLogPo.setState(responseEntity.getStatusCode() == HttpStatus.OK ? TransactionOutLogDto.STATE_S : TransactionOutLogDto.STATE_F);
            transactionOutLogPo.setLogType(logType);
 
            transactionOutLogV1InnerServiceSMO.saveTransactionOutLog(transactionOutLogPo);
        } catch (Exception e) {
            e.printStackTrace();
        }
 
    }
 
    /**
     * 分析日志类型
     *
     * @param url
     * @return
     */
    private static String analysisLogType(String url) {
 
        if (url.contains("9999") || url.contains("iot") || url.contains("extApi")) {
            return TransactionOutLogDto.LOG_TYPE_IOT;
        }
 
        if (url.contains("api.mch.weixin.qq.com")) {
            return TransactionOutLogDto.LOG_TYPE_WECHAT_PAY;
        }
 
        if(TransactionOutLogDto.LOG_TYPE_SMS.equals(url)){
            return TransactionOutLogDto.LOG_TYPE_SMS;
        }
 
        if(TransactionOutLogDto.LOG_TYPE_OSS.equals(url)){
            return TransactionOutLogDto.LOG_TYPE_OSS;
        }
 
        return TransactionOutLogDto.LOG_TYPE_DEFAULT;
    }
}