ssl测试
parent
3d513ac8cc
commit
2857d0a3df
|
@ -27,6 +27,11 @@ WfForm.OPER_SAVECOMPLETE = '保存后页面跳转前 KB900210501'
|
||||||
WfForm.OPER_WITHDRAW = '撤回 KB900201101'
|
WfForm.OPER_WITHDRAW = '撤回 KB900201101'
|
||||||
WfForm.OPER_CLOSE = '页面关闭'
|
WfForm.OPER_CLOSE = '页面关闭'
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 注册流程事件
|
||||||
|
* @param type
|
||||||
|
* @param callback
|
||||||
|
*/
|
||||||
WfForm.registerCheckEvent = (type, callback = (callback) = {}) => {
|
WfForm.registerCheckEvent = (type, callback = (callback) = {}) => {
|
||||||
// WfForm.registerCheckEvent(WfForm.OPER_SAVE+","+WfForm.OPER_SUBMIT,function(callback){
|
// WfForm.registerCheckEvent(WfForm.OPER_SAVE+","+WfForm.OPER_SUBMIT,function(callback){
|
||||||
// //... 执行自定义逻辑
|
// //... 执行自定义逻辑
|
||||||
|
@ -164,6 +169,60 @@ WfForm.getDetailAllRowIndexStr = function (detailMark) {
|
||||||
// }
|
// }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
添加明细行并设置初始值
|
||||||
|
* 参数 参数类型 必须 说明
|
||||||
|
* detailMark String 是 明细表标示,明细1就是detail_1,以此递增类推
|
||||||
|
* initAddRowData JSON 否 给新增后设置初始值,格式为{field110:{value:”11”},field112:{value:”22”},…},注意key不带下划线标示
|
||||||
|
* @param detailMark
|
||||||
|
* @param initAddRowData
|
||||||
|
*/
|
||||||
|
WfForm.addDetailRow = function (detailMark, initAddRowData = {}) {
|
||||||
|
// //明细2添加一行并给新添加的行字段field111赋值
|
||||||
|
// WfForm.addDetailRow("detail_2",{field111:{value:"初始值"}});
|
||||||
|
// //添加一行并给浏览按钮字段赋值
|
||||||
|
// WfForm.addDetailRow("detail_2",{field222:{
|
||||||
|
// value: "2,3",
|
||||||
|
// specialobj:[
|
||||||
|
// {id:"2",name:"张三"},
|
||||||
|
// {id:"3",name:"李四"}
|
||||||
|
// ]
|
||||||
|
// }});
|
||||||
|
// //动态字段赋值,明细1添加一行并给字段名称为begindate的字段赋值
|
||||||
|
// var begindatefield = WfForm.convertFieldNameToId("begindate", "detail_1");
|
||||||
|
// var addObj = {};
|
||||||
|
// addObj[begindatefield] = {value:"2019-03-01"};
|
||||||
|
// WfForm.addDetailRow("detail_1", addObj);
|
||||||
|
// //不推荐这种动态键值写法,IE不支持,避免掉
|
||||||
|
// WfForm.addDetailRow("detail_1",{[begindatefield]:{value:"2019-03-01"}})
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 系统样式的Confirm确认框
|
||||||
|
* 参数 参数类型 必须 说明
|
||||||
|
* content String 是 确认信息
|
||||||
|
* okEvent Function 是 点击确认事件
|
||||||
|
* cancelEvent Function 否 点击取消事件
|
||||||
|
* otherInfo Object 否 自定义信息(按钮名称)
|
||||||
|
* @param content
|
||||||
|
* @param okEvent
|
||||||
|
* @param cancelEvent
|
||||||
|
* @param otherInfo
|
||||||
|
*/
|
||||||
|
WfForm.showConfirm = function (content, okEvent, cancelEvent, otherInfo = {}) {
|
||||||
|
// WfForm.showConfirm("确认删除吗?", function(){
|
||||||
|
// alert("删除成功");
|
||||||
|
// });
|
||||||
|
// WfForm.showConfirm("请问你是否需要技术协助?",function(){
|
||||||
|
// alert("点击确认调用的事件");
|
||||||
|
// },function(){
|
||||||
|
// alert("点击取消调用的事件");
|
||||||
|
// },{
|
||||||
|
// title:"信息确认", //弹确认框的title,仅PC端有效
|
||||||
|
// okText:"需要", //自定义确认按钮名称
|
||||||
|
// cancelText:"不需要" //自定义取消按钮名称
|
||||||
|
// });
|
||||||
|
}
|
||||||
|
|
||||||
/* ******************* 建模表开发依赖 ******************* */
|
/* ******************* 建模表开发依赖 ******************* */
|
||||||
|
|
||||||
|
|
|
@ -305,52 +305,133 @@ $(() => {
|
||||||
$(() => {
|
$(() => {
|
||||||
const workflowInsertValueConfig = [
|
const workflowInsertValueConfig = [
|
||||||
{
|
{
|
||||||
table: '',
|
table: 'detail_1',
|
||||||
targetTable: '',
|
targetTable: 'detail_3',
|
||||||
filedMapping: [{
|
filedMapping: [{
|
||||||
source: '',
|
source: 'mbmc',
|
||||||
target: ''
|
target: 'name'
|
||||||
|
}, {
|
||||||
|
source: 'mbms',
|
||||||
|
target: 'description'
|
||||||
|
}, {
|
||||||
|
source: 'zp',
|
||||||
|
target: 'score'
|
||||||
|
}, {
|
||||||
|
source: 'zwpj',
|
||||||
|
target: 'grpj'
|
||||||
|
}, {
|
||||||
|
source: 'mbmc',
|
||||||
|
target: 'ldpf'
|
||||||
|
}, {
|
||||||
|
source: 'ldpj',
|
||||||
|
target: 'ldpj'
|
||||||
}]
|
}]
|
||||||
}, {
|
}, {
|
||||||
table: '',
|
table: 'detail_2',
|
||||||
targetTable: '',
|
targetTable: 'detail_3',
|
||||||
filedMapping: []
|
filedMapping: [{
|
||||||
|
source: 'xx',
|
||||||
|
target: 'name'
|
||||||
|
}, {
|
||||||
|
source: 'ms',
|
||||||
|
target: 'description'
|
||||||
|
}, {
|
||||||
|
source: 'zp',
|
||||||
|
target: 'score'
|
||||||
|
}, {
|
||||||
|
source: 'zwpj',
|
||||||
|
target: 'grpj'
|
||||||
|
}, {
|
||||||
|
source: 'mbmc',
|
||||||
|
target: 'ldpf'
|
||||||
|
}, {
|
||||||
|
source: 'ldpj',
|
||||||
|
target: 'ldpj'
|
||||||
|
}]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
||||||
(function start() {
|
/**
|
||||||
|
* 执行提交时将配置中的明细表数据合并到指定的明细表中
|
||||||
|
*/
|
||||||
|
WfForm.registerCheckEvent(WfForm.OPER_SUBMIT, (continueRun) => {
|
||||||
|
start()
|
||||||
|
continueRun()
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 开始执行合并操作
|
||||||
|
*/
|
||||||
|
function start() {
|
||||||
let mappingResult = []
|
let mappingResult = []
|
||||||
workflowInsertValueConfig.forEach(item => {
|
workflowInsertValueConfig.forEach(item => {
|
||||||
let valueMapping = getDetailValueMapping(item)
|
let valueMapping = getDetailValueMapping(item)
|
||||||
mappingResult = [...mappingResult, ...valueMapping]
|
mappingResult = [...mappingResult, ...valueMapping]
|
||||||
})
|
})
|
||||||
})()
|
setValue(mappingResult)
|
||||||
|
|
||||||
function setValue(valueMapping) {
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 设置表数据到指定的明细表中
|
||||||
|
* @param valueMapping 值映射数组
|
||||||
|
*/
|
||||||
|
function setValue(valueMapping) {
|
||||||
|
valueMapping.forEach(row => {
|
||||||
|
let rowData = {}
|
||||||
|
row.forEach(item => {
|
||||||
|
if (!rowData[item.targetTable]) {
|
||||||
|
rowData[item.targetTable] = {}
|
||||||
|
}
|
||||||
|
rowData[item.targetTable][Utils.convertNameToIdUtil({
|
||||||
|
fieldName: item.targetField,
|
||||||
|
table: item.targetTable
|
||||||
|
})] = {
|
||||||
|
value: item.value
|
||||||
|
}
|
||||||
|
})
|
||||||
|
Object.keys(rowData).forEach(key => {
|
||||||
|
WfForm.addDetailRow(key, rowData[key]);
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取明细值和对应字段的映射数组
|
||||||
|
* @param configItem 配置项
|
||||||
|
* @returns {*[]} 明细字段和对应值的映射数组
|
||||||
|
*/
|
||||||
function getDetailValueMapping(configItem) {
|
function getDetailValueMapping(configItem) {
|
||||||
let detailIdsStr = WfForm.getDetailAllRowIndexStr(configItem.table);
|
let detailIdsStr = WfForm.getDetailAllRowIndexStr(configItem.table);
|
||||||
let detailIdArr = detailIdsStr.split(",")
|
let detailIdArr = detailIdsStr.split(",")
|
||||||
let result = []
|
let result = []
|
||||||
for (let i = 0; i < detailIdArr.length; i++) {
|
for (let i = 0; i < detailIdArr.length; i++) {
|
||||||
let fieldValueMapping = getValueByConfig(configItem.filedMapping, configItem.table, i)
|
let fieldValueMapping = getValueByConfig(configItem.filedMapping, configItem.table, detailIdArr[i], configItem.targetTable)
|
||||||
result.push(fieldValueMapping)
|
result.push(fieldValueMapping)
|
||||||
}
|
}
|
||||||
return result
|
return result
|
||||||
}
|
}
|
||||||
|
|
||||||
function getValueByConfig(fieldMapping, tableName, detailIndex) {
|
/**
|
||||||
|
* 通过配置数据获取值
|
||||||
|
* @param fieldMapping 字段映射规则数组
|
||||||
|
* @param tableName 表名称
|
||||||
|
* @param detailIndex 明细表下标
|
||||||
|
* @param targetTable 目标表
|
||||||
|
* @returns {*[]} 对应明细行的值数组
|
||||||
|
*/
|
||||||
|
function getValueByConfig(fieldMapping, tableName, detailIndex, targetTable) {
|
||||||
let result = []
|
let result = []
|
||||||
fieldMapping.forEach(item => {
|
fieldMapping.forEach(item => {
|
||||||
let fieldValue = Utils.getFiledValueByName({
|
let fieldValue = Utils.getFiledValueByName({
|
||||||
fieldName: item.source,
|
fieldName: item.source,
|
||||||
TableName: tableName
|
table: tableName
|
||||||
}, detailIndex)
|
}, detailIndex)
|
||||||
result.push({
|
result.push({
|
||||||
targetField: item.target,
|
targetField: item.target,
|
||||||
value: fieldValue
|
value: fieldValue,
|
||||||
|
targetTable: targetTable
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
return result
|
return result
|
||||||
|
@ -360,3 +441,46 @@ $(() => {
|
||||||
})
|
})
|
||||||
|
|
||||||
/* ******************* 流程明细数据整合插入end ******************* */
|
/* ******************* 流程明细数据整合插入end ******************* */
|
||||||
|
|
||||||
|
|
||||||
|
/* ******************* 当明细数据未加载完成时 控制流程提交 start ******************* */
|
||||||
|
$(() => {
|
||||||
|
const config = {
|
||||||
|
table: 'detail_1',
|
||||||
|
field: ['fj']
|
||||||
|
}
|
||||||
|
|
||||||
|
function check() {
|
||||||
|
let detailRowIndexStr = WfForm.getDetailAllRowIndexStr(config.table);
|
||||||
|
let rowIndexArr = detailRowIndexStr.split(",");
|
||||||
|
try {
|
||||||
|
rowIndexArr.forEach(item => {
|
||||||
|
config.field.forEach(field => {
|
||||||
|
let value = WfForm.getFieldValue(WfForm.convertFieldNameToId(field, <table></table>) + "_" + item)
|
||||||
|
if (value == '' || value == null) {
|
||||||
|
throw field + " is can not be null!";
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
})
|
||||||
|
} catch (err) {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
WfForm.registerCheckEvent(WfForm.OPER_SUBMIT, callback => {
|
||||||
|
if (check()) {
|
||||||
|
callback()
|
||||||
|
} else {
|
||||||
|
WfForm.showConfirm("~`~` " + "7 模版文件生成中,请稍后在提交! " + " `~`8 Template file generation, please submit later! " + "`~`~", function () {
|
||||||
|
}, function () {
|
||||||
|
}, {
|
||||||
|
title: "~`~` " + "7 提交检查提示 " + "`~` 8 Submit check prompt " + "`~`~", //弹确认框的title,仅PC端有效
|
||||||
|
okText: "OK", //自定义确认按钮名称
|
||||||
|
cancelText: "Cancel" //自定义取消按钮名称
|
||||||
|
});
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
/* ******************* 当明细数据未加载完成时 控制流程提交 end ******************* */
|
|
@ -2,7 +2,7 @@ package aiyh.utils.action;
|
||||||
|
|
||||||
import aiyh.utils.Util;
|
import aiyh.utils.Util;
|
||||||
import aiyh.utils.excention.CustomerException;
|
import aiyh.utils.excention.CustomerException;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import com.google.common.base.Strings;
|
||||||
import org.apache.log4j.Logger;
|
import org.apache.log4j.Logger;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import weaver.hrm.User;
|
import weaver.hrm.User;
|
||||||
|
@ -12,7 +12,6 @@ import weaver.workflow.request.RequestManager;
|
||||||
import weaver.workflow.workflow.WorkflowBillComInfo;
|
import weaver.workflow.workflow.WorkflowBillComInfo;
|
||||||
import weaver.workflow.workflow.WorkflowComInfo;
|
import weaver.workflow.workflow.WorkflowComInfo;
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -61,7 +60,7 @@ public abstract class SafeCusBaseAction implements Action {
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
Util.verifyRequiredField(this);
|
Util.verifyRequiredField(this);
|
||||||
if (StringUtils.isEmpty(src)) {
|
if (!Strings.isNullOrEmpty(src)) {
|
||||||
src = "submit";
|
src = "submit";
|
||||||
}
|
}
|
||||||
// 初始化默认的流程处理方法
|
// 初始化默认的流程处理方法
|
||||||
|
@ -101,7 +100,7 @@ public abstract class SafeCusBaseAction implements Action {
|
||||||
*/
|
*/
|
||||||
public boolean exceptionCallback(Exception e, RequestManager requestManager) {
|
public boolean exceptionCallback(Exception e, RequestManager requestManager) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
log.error(Util.logStr("getDataId action fail, exception message is [{}], error stack trace msg is: \n{}",
|
log.error(Util.logStr("execute action fail, exception message is [{}], error stack trace msg is: \n{}",
|
||||||
e.getMessage(), Util.getErrString(e)));
|
e.getMessage(), Util.getErrString(e)));
|
||||||
Util.actionFail(requestManager, e.getMessage());
|
Util.actionFail(requestManager, e.getMessage());
|
||||||
return true;
|
return true;
|
||||||
|
@ -208,6 +207,16 @@ public abstract class SafeCusBaseAction implements Action {
|
||||||
return mainTable;
|
return mainTable;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>获取流程主表数据</h2>
|
||||||
|
*
|
||||||
|
* @return 流程主表数据
|
||||||
|
*/
|
||||||
|
protected Map<String, Object> getObjMainTableValue(RequestInfo requestInfo) {
|
||||||
|
Map<String, String> mainTableValue = getMainTableValue(requestInfo);
|
||||||
|
return new HashMap<>(mainTableValue);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h2>获取所有明细数据</h2>
|
* <h2>获取所有明细数据</h2>
|
||||||
|
|
|
@ -10,29 +10,31 @@ import org.apache.log4j.Logger;
|
||||||
* @author ayh
|
* @author ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class CustomerException extends RuntimeException{
|
public class CustomerException extends RuntimeException {
|
||||||
private Logger logger = Util.getLogger();
|
private final Logger logger = Util.getLogger();
|
||||||
private String msg;
|
private final String msg;
|
||||||
private Throwable throwable;
|
private Throwable throwable;
|
||||||
private Integer code;
|
private Integer code = -1;
|
||||||
|
|
||||||
public CustomerException(String msg){
|
public CustomerException(String msg) {
|
||||||
super(msg);
|
super(msg);
|
||||||
this.msg = msg;
|
this.msg = msg;
|
||||||
}
|
}
|
||||||
|
|
||||||
public CustomerException(String msg,Integer code){
|
public CustomerException(String msg, Integer code) {
|
||||||
super(msg);
|
super(msg);
|
||||||
this.code = code;
|
this.code = code;
|
||||||
this.msg = msg;
|
this.msg = msg;
|
||||||
}
|
}
|
||||||
public CustomerException(String msg, Integer code, Throwable throwable){
|
|
||||||
|
public CustomerException(String msg, Integer code, Throwable throwable) {
|
||||||
super(msg);
|
super(msg);
|
||||||
this.code= code;
|
this.code = code;
|
||||||
this.msg = msg;
|
this.msg = msg;
|
||||||
}
|
}
|
||||||
public CustomerException(String msg, Throwable throwable){
|
|
||||||
super(msg,throwable);
|
public CustomerException(String msg, Throwable throwable) {
|
||||||
|
super(msg, throwable);
|
||||||
this.msg = msg;
|
this.msg = msg;
|
||||||
this.throwable = throwable;
|
this.throwable = throwable;
|
||||||
}
|
}
|
||||||
|
@ -40,12 +42,12 @@ public class CustomerException extends RuntimeException{
|
||||||
@Override
|
@Override
|
||||||
public void printStackTrace() {
|
public void printStackTrace() {
|
||||||
logger.error("二开自定义异常:" + this.msg);
|
logger.error("二开自定义异常:" + this.msg);
|
||||||
if(this.throwable != null){
|
if (this.throwable != null) {
|
||||||
logger.error("异常信息: " + Util.getErrString(this.throwable));
|
logger.error("异常信息: " + Util.getErrString(this.throwable));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Integer getCode (){
|
public Integer getCode() {
|
||||||
return this.code;
|
return this.code;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,17 +4,22 @@ import org.apache.http.client.CredentialsProvider;
|
||||||
import org.apache.http.client.config.RequestConfig;
|
import org.apache.http.client.config.RequestConfig;
|
||||||
import org.apache.http.conn.ssl.NoopHostnameVerifier;
|
import org.apache.http.conn.ssl.NoopHostnameVerifier;
|
||||||
import org.apache.http.conn.ssl.SSLConnectionSocketFactory;
|
import org.apache.http.conn.ssl.SSLConnectionSocketFactory;
|
||||||
|
import org.apache.http.conn.ssl.TrustSelfSignedStrategy;
|
||||||
import org.apache.http.impl.client.CloseableHttpClient;
|
import org.apache.http.impl.client.CloseableHttpClient;
|
||||||
import org.apache.http.impl.client.HttpClientBuilder;
|
import org.apache.http.impl.client.HttpClientBuilder;
|
||||||
import org.apache.http.impl.client.HttpClients;
|
import org.apache.http.impl.client.HttpClients;
|
||||||
import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
|
import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
|
||||||
import org.apache.http.ssl.SSLContextBuilder;
|
import org.apache.http.ssl.SSLContextBuilder;
|
||||||
|
import org.apache.http.ssl.SSLContexts;
|
||||||
|
|
||||||
import javax.net.ssl.HostnameVerifier;
|
import javax.net.ssl.HostnameVerifier;
|
||||||
import javax.net.ssl.SSLContext;
|
import javax.net.ssl.SSLContext;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
import java.security.KeyManagementException;
|
import java.security.KeyManagementException;
|
||||||
import java.security.KeyStoreException;
|
import java.security.KeyStoreException;
|
||||||
import java.security.NoSuchAlgorithmException;
|
import java.security.NoSuchAlgorithmException;
|
||||||
|
import java.security.cert.CertificateException;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -38,14 +43,15 @@ public class HttpManager {
|
||||||
* 设置请求配置
|
* 设置请求配置
|
||||||
*/
|
*/
|
||||||
static RequestConfig requestConfig = RequestConfig.custom()
|
static RequestConfig requestConfig = RequestConfig.custom()
|
||||||
//网络请求的超时时间
|
// 网络请求的超时时间
|
||||||
.setConnectTimeout(CONNECT_TIMEOUT)
|
.setConnectTimeout(CONNECT_TIMEOUT)
|
||||||
//连接池去获取连接的超时时间
|
// 连接池去获取连接的超时时间
|
||||||
.setConnectionRequestTimeout(CONNECTION_REQUEST_TIMEOUT)
|
.setConnectionRequestTimeout(CONNECTION_REQUEST_TIMEOUT)
|
||||||
//设置socket超时时间
|
// 设置socket超时时间
|
||||||
.setSocketTimeout(SOCKET_TIMEOUT)
|
.setSocketTimeout(SOCKET_TIMEOUT)
|
||||||
.build();
|
.build();
|
||||||
static PoolingHttpClientConnectionManager manager = new PoolingHttpClientConnectionManager();
|
static PoolingHttpClientConnectionManager manager = new PoolingHttpClientConnectionManager();
|
||||||
|
|
||||||
static {
|
static {
|
||||||
// 配置最大的连接数
|
// 配置最大的连接数
|
||||||
manager.setMaxTotal(MAX_TOTAL);
|
manager.setMaxTotal(MAX_TOTAL);
|
||||||
|
@ -55,11 +61,12 @@ public class HttpManager {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取连接对象 从连接池里面去获取,根据url创建对应的对象,http / https
|
* 获取连接对象 从连接池里面去获取,根据url创建对应的对象,http / https
|
||||||
|
*
|
||||||
* @param url 请求地址
|
* @param url 请求地址
|
||||||
* @return 连接对象
|
* @return 连接对象
|
||||||
*/
|
*/
|
||||||
public static CloseableHttpClient getHttpConnection(String url, CredentialsProvider credentialsProvider){
|
public static CloseableHttpClient getHttpConnection(String url, CredentialsProvider credentialsProvider) {
|
||||||
if(url.trim().toUpperCase().startsWith(HttpArgsType.HTTP_HTTPS.toUpperCase())){
|
if (url.trim().toUpperCase().startsWith(HttpArgsType.HTTP_HTTPS.toUpperCase())) {
|
||||||
SSLContext sslContext;
|
SSLContext sslContext;
|
||||||
SSLConnectionSocketFactory sslsf = null;
|
SSLConnectionSocketFactory sslsf = null;
|
||||||
try {
|
try {
|
||||||
|
@ -68,26 +75,70 @@ public class HttpManager {
|
||||||
return true;
|
return true;
|
||||||
}).build();
|
}).build();
|
||||||
HostnameVerifier hostnameVerifier = NoopHostnameVerifier.INSTANCE;
|
HostnameVerifier hostnameVerifier = NoopHostnameVerifier.INSTANCE;
|
||||||
sslsf = new SSLConnectionSocketFactory(sslContext,hostnameVerifier);
|
sslsf = new SSLConnectionSocketFactory(sslContext,
|
||||||
|
new String[]{"TLSv1"},
|
||||||
|
null,
|
||||||
|
hostnameVerifier);
|
||||||
} catch (NoSuchAlgorithmException | KeyStoreException | KeyManagementException e) {
|
} catch (NoSuchAlgorithmException | KeyStoreException | KeyManagementException e) {
|
||||||
e.printStackTrace();
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
HttpClientBuilder httpClientBuilder = HttpClients.custom()
|
||||||
|
.setSSLSocketFactory(sslsf)
|
||||||
|
.setSSLHostnameVerifier(NoopHostnameVerifier.INSTANCE)
|
||||||
|
.setConnectionManager(manager)
|
||||||
|
.setConnectionManagerShared(true)
|
||||||
|
.setDefaultRequestConfig(requestConfig);
|
||||||
|
if (credentialsProvider != null) {
|
||||||
|
httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
|
||||||
|
}
|
||||||
|
return httpClientBuilder
|
||||||
|
.build();
|
||||||
|
} else {
|
||||||
|
HttpClientBuilder httpClientBuilder = HttpClients.custom()
|
||||||
|
.setConnectionManager(manager)
|
||||||
|
.setDefaultRequestConfig(requestConfig)
|
||||||
|
.setConnectionManagerShared(true);
|
||||||
|
if (credentialsProvider != null) {
|
||||||
|
httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
|
||||||
|
}
|
||||||
|
return httpClientBuilder
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static CloseableHttpClient getHttpConnection(String url, CredentialsProvider credentialsProvider, String sslPath, String password) {
|
||||||
|
if (url.trim().toUpperCase().startsWith(HttpArgsType.HTTP_HTTPS.toUpperCase())) {
|
||||||
|
SSLContext sslContext;
|
||||||
|
SSLConnectionSocketFactory sslsf = null;
|
||||||
|
try {
|
||||||
|
sslContext = SSLContexts.custom()
|
||||||
|
.loadTrustMaterial(new File(sslPath), password.toCharArray(),
|
||||||
|
new TrustSelfSignedStrategy())
|
||||||
|
.build();
|
||||||
|
sslsf = new SSLConnectionSocketFactory(sslContext,
|
||||||
|
new String[]{"TLSv1"},
|
||||||
|
null,
|
||||||
|
SSLConnectionSocketFactory.getDefaultHostnameVerifier());
|
||||||
|
} catch (NoSuchAlgorithmException | KeyStoreException | KeyManagementException | CertificateException |
|
||||||
|
IOException e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
}
|
}
|
||||||
HttpClientBuilder httpClientBuilder = HttpClients.custom()
|
HttpClientBuilder httpClientBuilder = HttpClients.custom()
|
||||||
.setSSLSocketFactory(sslsf)
|
.setSSLSocketFactory(sslsf)
|
||||||
.setConnectionManager(manager)
|
.setConnectionManager(manager)
|
||||||
.setConnectionManagerShared(true)
|
.setConnectionManagerShared(true)
|
||||||
.setDefaultRequestConfig(requestConfig);
|
.setDefaultRequestConfig(requestConfig);
|
||||||
if(credentialsProvider != null){
|
if (credentialsProvider != null) {
|
||||||
httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
|
httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
|
||||||
}
|
}
|
||||||
return httpClientBuilder
|
return httpClientBuilder
|
||||||
.build();
|
.build();
|
||||||
}else{
|
} else {
|
||||||
HttpClientBuilder httpClientBuilder = HttpClients.custom()
|
HttpClientBuilder httpClientBuilder = HttpClients.custom()
|
||||||
.setConnectionManager(manager)
|
.setConnectionManager(manager)
|
||||||
.setDefaultRequestConfig(requestConfig)
|
.setDefaultRequestConfig(requestConfig)
|
||||||
.setConnectionManagerShared(true);
|
.setConnectionManagerShared(true);
|
||||||
if(credentialsProvider != null){
|
if (credentialsProvider != null) {
|
||||||
httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
|
httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
|
||||||
}
|
}
|
||||||
return httpClientBuilder
|
return httpClientBuilder
|
||||||
|
|
|
@ -1,7 +1,9 @@
|
||||||
package aiyh.utils.httpUtil;
|
package aiyh.utils.httpUtil;
|
||||||
|
|
||||||
|
|
||||||
|
import aiyh.utils.Util;
|
||||||
import com.alibaba.fastjson.JSON;
|
import com.alibaba.fastjson.JSON;
|
||||||
|
import com.alibaba.fastjson.JSONArray;
|
||||||
import com.fasterxml.jackson.core.JsonProcessingException;
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
import com.fasterxml.jackson.core.type.TypeReference;
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
|
@ -29,6 +31,8 @@ public class ResponeVo implements HttpResponse {
|
||||||
private String entityString;
|
private String entityString;
|
||||||
|
|
||||||
private Map<String, Object> entityMap;
|
private Map<String, Object> entityMap;
|
||||||
|
|
||||||
|
private List<Map> resultList;
|
||||||
/**
|
/**
|
||||||
* 相应头信息
|
* 相应头信息
|
||||||
*/
|
*/
|
||||||
|
@ -59,6 +63,11 @@ public class ResponeVo implements HttpResponse {
|
||||||
return requestData;
|
return requestData;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<Map> getResult() {
|
||||||
|
return resultList;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public void setRequestData(Map<String, Object> requestData) {
|
public void setRequestData(Map<String, Object> requestData) {
|
||||||
this.requestData = requestData;
|
this.requestData = requestData;
|
||||||
}
|
}
|
||||||
|
@ -75,9 +84,10 @@ public class ResponeVo implements HttpResponse {
|
||||||
return mapper.readValue(this.getEntityString(), Map.class);
|
return mapper.readValue(this.getEntityString(), Map.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Map<String, Object> getResponseMap(){
|
public Map<String, Object> getResponseMap() {
|
||||||
return this.entityMap;
|
return this.entityMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据相应结果,转化为实体类
|
* 根据相应结果,转化为实体类
|
||||||
*
|
*
|
||||||
|
@ -119,11 +129,13 @@ public class ResponeVo implements HttpResponse {
|
||||||
|
|
||||||
public void setEntityString(String entityString) {
|
public void setEntityString(String entityString) {
|
||||||
this.entityString = entityString;
|
this.entityString = entityString;
|
||||||
try{
|
try {
|
||||||
ObjectMapper mapper = new ObjectMapper();
|
ObjectMapper mapper = new ObjectMapper();
|
||||||
this.entityMap = mapper.readValue(this.getEntityString(), Map.class);
|
this.entityMap = mapper.readValue(this.getEntityString(), Map.class);
|
||||||
}catch (Exception ignore){
|
} catch (JsonProcessingException ignored) {
|
||||||
|
this.resultList = (List<Map>) JSONArray.parseArray(this.getEntityString(), Map.class);
|
||||||
|
} catch (Exception e) {
|
||||||
|
Util.getLogger().error("Unable to convert the response result to map or array!" + Util.getErrString(e));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -297,6 +309,5 @@ public class ResponeVo implements HttpResponse {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -55,6 +55,19 @@ public class HttpUtils {
|
||||||
private final PropertyPreFilters.MySimplePropertyPreFilter excludefilter = filters.addFilter();
|
private final PropertyPreFilters.MySimplePropertyPreFilter excludefilter = filters.addFilter();
|
||||||
// 默认编码
|
// 默认编码
|
||||||
private String DEFAULT_ENCODING = "UTF-8";
|
private String DEFAULT_ENCODING = "UTF-8";
|
||||||
|
private String sslKeyPath = "";
|
||||||
|
|
||||||
|
private String password = "";
|
||||||
|
|
||||||
|
public void setSslKeyPath(String sslKeyPath) {
|
||||||
|
this.sslKeyPath = sslKeyPath;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void setPassword(String password) {
|
||||||
|
this.password = password;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* basic 认证
|
* basic 认证
|
||||||
*/
|
*/
|
||||||
|
@ -169,6 +182,21 @@ public class HttpUtils {
|
||||||
return httpGet;
|
return httpGet;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取httpclient对象
|
||||||
|
*
|
||||||
|
* @param url 请求地址
|
||||||
|
* @return 对象
|
||||||
|
*/
|
||||||
|
private CloseableHttpClient getHttpClient(String url) {
|
||||||
|
if (Strings.isNullOrEmpty(this.sslKeyPath)) {
|
||||||
|
return HttpManager.getHttpConnection(url, this.credentialsProvider);
|
||||||
|
} else {
|
||||||
|
return HttpManager.getHttpConnection(url, this.credentialsProvider, sslKeyPath, password);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* get请求
|
* get请求
|
||||||
*
|
*
|
||||||
|
@ -177,7 +205,7 @@ public class HttpUtils {
|
||||||
* @throws IOException io异常
|
* @throws IOException io异常
|
||||||
*/
|
*/
|
||||||
public ResponeVo apiGet(String url) throws IOException {
|
public ResponeVo apiGet(String url) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> params = paramsHandle(null);
|
Map<String, Object> params = paramsHandle(null);
|
||||||
String getUrl = urlHandle(url, params);
|
String getUrl = urlHandle(url, params);
|
||||||
Map<String, String> headers = headersHandle(null);
|
Map<String, String> headers = headersHandle(null);
|
||||||
|
@ -206,7 +234,7 @@ public class HttpUtils {
|
||||||
* @throws IOException io异常
|
* @throws IOException io异常
|
||||||
*/
|
*/
|
||||||
public ResponeVo apiDelete(String url) throws IOException {
|
public ResponeVo apiDelete(String url) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> params = paramsHandle(null);
|
Map<String, Object> params = paramsHandle(null);
|
||||||
String getUrl = urlHandle(url, params);
|
String getUrl = urlHandle(url, params);
|
||||||
Map<String, String> headers = headersHandle(null);
|
Map<String, String> headers = headersHandle(null);
|
||||||
|
@ -236,7 +264,7 @@ public class HttpUtils {
|
||||||
* @throws IOException io异常
|
* @throws IOException io异常
|
||||||
*/
|
*/
|
||||||
public ResponeVo apiGet(String url, Map<String, String> headers) throws IOException {
|
public ResponeVo apiGet(String url, Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> params = paramsHandle(null);
|
Map<String, Object> params = paramsHandle(null);
|
||||||
String getUrl = urlHandle(url, params);
|
String getUrl = urlHandle(url, params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
|
@ -258,7 +286,7 @@ public class HttpUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
public ResponeVo apiDelete(String url, Map<String, String> headers) throws IOException {
|
public ResponeVo apiDelete(String url, Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> params = paramsHandle(null);
|
Map<String, Object> params = paramsHandle(null);
|
||||||
String getUrl = urlHandle(url, params);
|
String getUrl = urlHandle(url, params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
|
@ -283,7 +311,7 @@ public class HttpUtils {
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
String getUrl = urlHandle(url, paramsMap);
|
String getUrl = urlHandle(url, paramsMap);
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
HttpGet httpGet = new HttpGet(getUrl.trim());
|
HttpGet httpGet = new HttpGet(getUrl.trim());
|
||||||
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
||||||
httpGet.setHeader(entry.getKey(), entry.getValue());
|
httpGet.setHeader(entry.getKey(), entry.getValue());
|
||||||
|
@ -305,7 +333,7 @@ public class HttpUtils {
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
String getUrl = urlHandle(url, paramsMap);
|
String getUrl = urlHandle(url, paramsMap);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
HttpDelete httpDelete = new HttpDelete(getUrl.trim());
|
HttpDelete httpDelete = new HttpDelete(getUrl.trim());
|
||||||
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
||||||
httpDelete.setHeader(entry.getKey(), entry.getValue());
|
httpDelete.setHeader(entry.getKey(), entry.getValue());
|
||||||
|
@ -336,7 +364,7 @@ public class HttpUtils {
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
String getUrl = urlHandle(url, paramsMap);
|
String getUrl = urlHandle(url, paramsMap);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
HttpGet httpGet = new HttpGet(getUrl.trim());
|
HttpGet httpGet = new HttpGet(getUrl.trim());
|
||||||
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
||||||
httpGet.setHeader(entry.getKey(), entry.getValue());
|
httpGet.setHeader(entry.getKey(), entry.getValue());
|
||||||
|
@ -367,7 +395,7 @@ public class HttpUtils {
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
String getUrl = urlHandle(url, paramsMap);
|
String getUrl = urlHandle(url, paramsMap);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
HttpDelete httpDelete = new HttpDelete(getUrl.trim());
|
HttpDelete httpDelete = new HttpDelete(getUrl.trim());
|
||||||
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
||||||
httpDelete.setHeader(entry.getKey(), entry.getValue());
|
httpDelete.setHeader(entry.getKey(), entry.getValue());
|
||||||
|
@ -386,7 +414,7 @@ public class HttpUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
public ResponeVo apiPost(String url, Map<String, Object> params) throws IOException {
|
public ResponeVo apiPost(String url, Map<String, Object> params) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(null);
|
Map<String, String> headerMap = headersHandle(null);
|
||||||
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
||||||
|
@ -394,7 +422,7 @@ public class HttpUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
public ResponeVo apiPut(String url, Map<String, Object> params) throws IOException {
|
public ResponeVo apiPut(String url, Map<String, Object> params) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(null);
|
Map<String, String> headerMap = headersHandle(null);
|
||||||
HttpPut httpPut = handleHttpPut(url, headerMap, paramsMap);
|
HttpPut httpPut = handleHttpPut(url, headerMap, paramsMap);
|
||||||
|
@ -402,7 +430,7 @@ public class HttpUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
public ResponeVo apiPost(String url, Map<String, Object> params, Map<String, String> headers) throws IOException {
|
public ResponeVo apiPost(String url, Map<String, Object> params, Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
||||||
|
@ -410,21 +438,21 @@ public class HttpUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
public ResponeVo apiPost(String url, List<Object> params, Map<String, String> headers) throws IOException {
|
public ResponeVo apiPost(String url, List<Object> params, Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPost httpPost = handleHttpPost(url, headerMap, params);
|
HttpPost httpPost = handleHttpPost(url, headerMap, params);
|
||||||
return baseRequest(httpConnection, httpPost);
|
return baseRequest(httpConnection, httpPost);
|
||||||
}
|
}
|
||||||
|
|
||||||
public ResponeVo apiPostObject(String url, Object params, Map<String, String> headers) throws IOException {
|
public ResponeVo apiPostObject(String url, Object params, Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPost httpPost = handleHttpPostObject(url, headerMap, params);
|
HttpPost httpPost = handleHttpPostObject(url, headerMap, params);
|
||||||
return baseRequest(httpConnection, httpPost);
|
return baseRequest(httpConnection, httpPost);
|
||||||
}
|
}
|
||||||
|
|
||||||
public ResponeVo apiPut(String url, Map<String, Object> params, Map<String, String> headers) throws IOException {
|
public ResponeVo apiPut(String url, Map<String, Object> params, Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPut httpPut = handleHttpPut(url, headerMap, paramsMap);
|
HttpPut httpPut = handleHttpPut(url, headerMap, paramsMap);
|
||||||
|
@ -446,7 +474,7 @@ public class HttpUtils {
|
||||||
|
|
||||||
public ResponeVo apiUploadFile(String url, InputStream inputStream, String fileKey, String fileName,
|
public ResponeVo apiUploadFile(String url, InputStream inputStream, String fileKey, String fileName,
|
||||||
Map<String, Object> params, Map<String, String> headers) throws IOException {
|
Map<String, Object> params, Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpMultipartFile multipartFile = new HttpMultipartFile();
|
HttpMultipartFile multipartFile = new HttpMultipartFile();
|
||||||
|
@ -471,7 +499,7 @@ public class HttpUtils {
|
||||||
*/
|
*/
|
||||||
public ResponeVo apiUploadFiles(String url, List<HttpMultipartFile> multipartFileList, Map<String, Object> params,
|
public ResponeVo apiUploadFiles(String url, List<HttpMultipartFile> multipartFileList, Map<String, Object> params,
|
||||||
Map<String, String> headers) throws IOException {
|
Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPost httpPost = uploadFileByInputStream(url, multipartFileList, paramsMap, headerMap);
|
HttpPost httpPost = uploadFileByInputStream(url, multipartFileList, paramsMap, headerMap);
|
||||||
|
@ -491,7 +519,7 @@ public class HttpUtils {
|
||||||
*/
|
*/
|
||||||
public ResponeVo apiPutUploadFiles(String url, List<HttpMultipartFile> multipartFileList, Map<String, Object> params,
|
public ResponeVo apiPutUploadFiles(String url, List<HttpMultipartFile> multipartFileList, Map<String, Object> params,
|
||||||
Map<String, String> headers) throws IOException {
|
Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPut httpPut = uploadFileByInputStreamPut(url, multipartFileList, paramsMap, headerMap);
|
HttpPut httpPut = uploadFileByInputStreamPut(url, multipartFileList, paramsMap, headerMap);
|
||||||
|
@ -512,7 +540,7 @@ public class HttpUtils {
|
||||||
*/
|
*/
|
||||||
public Future<ResponeVo> apiUploadFileAsync(String url, InputStream inputStream, String fileKey, String fileName,
|
public Future<ResponeVo> apiUploadFileAsync(String url, InputStream inputStream, String fileKey, String fileName,
|
||||||
Map<String, Object> params, Map<String, String> headers) throws IOException {
|
Map<String, Object> params, Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpMultipartFile multipartFile = new HttpMultipartFile();
|
HttpMultipartFile multipartFile = new HttpMultipartFile();
|
||||||
|
@ -538,7 +566,7 @@ public class HttpUtils {
|
||||||
*/
|
*/
|
||||||
public ResponeVo apiUploadFile(String url, File file, String fileKey, String fileName,
|
public ResponeVo apiUploadFile(String url, File file, String fileKey, String fileName,
|
||||||
Map<String, Object> params, Map<String, String> headers) throws IOException {
|
Map<String, Object> params, Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPost httpPost = uploadFileByInputStream(url, file, fileKey, fileName, paramsMap, headerMap);
|
HttpPost httpPost = uploadFileByInputStream(url, file, fileKey, fileName, paramsMap, headerMap);
|
||||||
|
@ -560,7 +588,7 @@ public class HttpUtils {
|
||||||
|
|
||||||
public ResponeVo apiUploadFileById(String url, int id, String fileKey, String fileName,
|
public ResponeVo apiUploadFileById(String url, int id, String fileKey, String fileName,
|
||||||
Map<String, Object> params, Map<String, String> headers) throws IOException {
|
Map<String, Object> params, Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
InputStream inputStream = ImageFileManager.getInputStreamById(id);
|
InputStream inputStream = ImageFileManager.getInputStreamById(id);
|
||||||
|
@ -581,7 +609,7 @@ public class HttpUtils {
|
||||||
* @throws IOException io异常
|
* @throws IOException io异常
|
||||||
*/
|
*/
|
||||||
public void apiPost(String url, Map<String, Object> params, Map<String, String> headers, Consumer<CloseableHttpResponse> consumer) throws IOException {
|
public void apiPost(String url, Map<String, Object> params, Map<String, String> headers, Consumer<CloseableHttpResponse> consumer) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
||||||
|
@ -589,7 +617,7 @@ public class HttpUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
public ResponeVo apiPost(String url, Map<String, Object> params, Map<String, String> headers, Function<CloseableHttpResponse, ResponeVo> consumer) throws IOException {
|
public ResponeVo apiPost(String url, Map<String, Object> params, Map<String, String> headers, Function<CloseableHttpResponse, ResponeVo> consumer) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
||||||
|
@ -597,7 +625,7 @@ public class HttpUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
public ResponeVo apiPost(String url, Map<String, Object> params, Map<String, String> headers, BiFunction<Map<String, Object>, CloseableHttpResponse, ResponeVo> consumer) throws IOException {
|
public ResponeVo apiPost(String url, Map<String, Object> params, Map<String, String> headers, BiFunction<Map<String, Object>, CloseableHttpResponse, ResponeVo> consumer) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
||||||
|
@ -612,7 +640,7 @@ public class HttpUtils {
|
||||||
* @throws IOException io异常
|
* @throws IOException io异常
|
||||||
*/
|
*/
|
||||||
public void apiPut(String url, Map<String, Object> params, Map<String, String> headers, Consumer<CloseableHttpResponse> consumer) throws IOException {
|
public void apiPut(String url, Map<String, Object> params, Map<String, String> headers, Consumer<CloseableHttpResponse> consumer) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPut httpPut = handleHttpPut(url, headerMap, paramsMap);
|
HttpPut httpPut = handleHttpPut(url, headerMap, paramsMap);
|
||||||
|
@ -768,7 +796,7 @@ public class HttpUtils {
|
||||||
* @throws IOException io异常
|
* @throws IOException io异常
|
||||||
*/
|
*/
|
||||||
public Future<ResponeVo> asyncApiGet(String url) throws IOException {
|
public Future<ResponeVo> asyncApiGet(String url) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> params = paramsHandle(null);
|
Map<String, Object> params = paramsHandle(null);
|
||||||
String getUrl = urlHandle(url, params);
|
String getUrl = urlHandle(url, params);
|
||||||
Map<String, String> headers = headersHandle(null);
|
Map<String, String> headers = headersHandle(null);
|
||||||
|
@ -787,7 +815,7 @@ public class HttpUtils {
|
||||||
* @throws IOException io异常
|
* @throws IOException io异常
|
||||||
*/
|
*/
|
||||||
public Future<ResponeVo> asyncApiDelete(String url) throws IOException {
|
public Future<ResponeVo> asyncApiDelete(String url) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> params = paramsHandle(null);
|
Map<String, Object> params = paramsHandle(null);
|
||||||
String getUrl = urlHandle(url, params);
|
String getUrl = urlHandle(url, params);
|
||||||
Map<String, String> headers = headersHandle(null);
|
Map<String, String> headers = headersHandle(null);
|
||||||
|
@ -807,7 +835,7 @@ public class HttpUtils {
|
||||||
* @throws IOException io异常
|
* @throws IOException io异常
|
||||||
*/
|
*/
|
||||||
public Future<ResponeVo> asyncApiGet(String url, Map<String, String> headers) throws IOException {
|
public Future<ResponeVo> asyncApiGet(String url, Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> params = paramsHandle(null);
|
Map<String, Object> params = paramsHandle(null);
|
||||||
String getUrl = urlHandle(url, params);
|
String getUrl = urlHandle(url, params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
|
@ -819,7 +847,7 @@ public class HttpUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
public Future<ResponeVo> asyncApiDelete(String url, Map<String, String> headers) throws IOException {
|
public Future<ResponeVo> asyncApiDelete(String url, Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> params = paramsHandle(null);
|
Map<String, Object> params = paramsHandle(null);
|
||||||
String getUrl = urlHandle(url, params);
|
String getUrl = urlHandle(url, params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
|
@ -834,7 +862,7 @@ public class HttpUtils {
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
String getUrl = urlHandle(url, paramsMap);
|
String getUrl = urlHandle(url, paramsMap);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
HttpGet httpGet = new HttpGet(getUrl.trim());
|
HttpGet httpGet = new HttpGet(getUrl.trim());
|
||||||
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
||||||
httpGet.setHeader(entry.getKey(), entry.getValue());
|
httpGet.setHeader(entry.getKey(), entry.getValue());
|
||||||
|
@ -846,7 +874,7 @@ public class HttpUtils {
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
String getUrl = urlHandle(url, paramsMap);
|
String getUrl = urlHandle(url, paramsMap);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
HttpDelete httpDelete = new HttpDelete(getUrl.trim());
|
HttpDelete httpDelete = new HttpDelete(getUrl.trim());
|
||||||
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
||||||
httpDelete.setHeader(entry.getKey(), entry.getValue());
|
httpDelete.setHeader(entry.getKey(), entry.getValue());
|
||||||
|
@ -867,7 +895,7 @@ public class HttpUtils {
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
String getUrl = urlHandle(url, paramsMap);
|
String getUrl = urlHandle(url, paramsMap);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
HttpGet httpGet = new HttpGet(getUrl.trim());
|
HttpGet httpGet = new HttpGet(getUrl.trim());
|
||||||
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
||||||
httpGet.setHeader(entry.getKey(), entry.getValue());
|
httpGet.setHeader(entry.getKey(), entry.getValue());
|
||||||
|
@ -893,7 +921,7 @@ public class HttpUtils {
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
String getUrl = urlHandle(url, paramsMap);
|
String getUrl = urlHandle(url, paramsMap);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
HttpDelete httpDelete = new HttpDelete(getUrl.trim());
|
HttpDelete httpDelete = new HttpDelete(getUrl.trim());
|
||||||
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
for (Map.Entry<String, String> entry : headerMap.entrySet()) {
|
||||||
httpDelete.setHeader(entry.getKey(), entry.getValue());
|
httpDelete.setHeader(entry.getKey(), entry.getValue());
|
||||||
|
@ -909,7 +937,7 @@ public class HttpUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
public Future<ResponeVo> asyncApiPost(String url, Map<String, Object> params) throws IOException {
|
public Future<ResponeVo> asyncApiPost(String url, Map<String, Object> params) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(null);
|
Map<String, String> headerMap = headersHandle(null);
|
||||||
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
||||||
|
@ -917,7 +945,7 @@ public class HttpUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
public Future<ResponeVo> asyncApiPut(String url, Map<String, Object> params) throws IOException {
|
public Future<ResponeVo> asyncApiPut(String url, Map<String, Object> params) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(null);
|
Map<String, String> headerMap = headersHandle(null);
|
||||||
HttpPut httpPut = handleHttpPut(url, headerMap, paramsMap);
|
HttpPut httpPut = handleHttpPut(url, headerMap, paramsMap);
|
||||||
|
@ -925,7 +953,7 @@ public class HttpUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
public Future<ResponeVo> asyncApiPost(String url, Map<String, Object> params, Map<String, String> headers) throws IOException {
|
public Future<ResponeVo> asyncApiPost(String url, Map<String, Object> params, Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
||||||
|
@ -933,7 +961,7 @@ public class HttpUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
public Future<ResponeVo> asyncApiPut(String url, Map<String, Object> params, Map<String, String> headers) throws IOException {
|
public Future<ResponeVo> asyncApiPut(String url, Map<String, Object> params, Map<String, String> headers) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPut httpPut = handleHttpPut(url, headerMap, paramsMap);
|
HttpPut httpPut = handleHttpPut(url, headerMap, paramsMap);
|
||||||
|
@ -948,7 +976,7 @@ public class HttpUtils {
|
||||||
* @throws IOException io异常
|
* @throws IOException io异常
|
||||||
*/
|
*/
|
||||||
public void asyncApiPost(String url, Map<String, Object> params, Map<String, String> headers, Consumer<ResponeVo> consumer) throws IOException {
|
public void asyncApiPost(String url, Map<String, Object> params, Map<String, String> headers, Consumer<ResponeVo> consumer) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
HttpPost httpPost = handleHttpPost(url, headerMap, paramsMap);
|
||||||
|
@ -970,7 +998,7 @@ public class HttpUtils {
|
||||||
* @throws IOException io异常
|
* @throws IOException io异常
|
||||||
*/
|
*/
|
||||||
public void asyncApiPut(String url, Map<String, Object> params, Map<String, String> headers, Consumer<ResponeVo> consumer) throws IOException {
|
public void asyncApiPut(String url, Map<String, Object> params, Map<String, String> headers, Consumer<ResponeVo> consumer) throws IOException {
|
||||||
CloseableHttpClient httpConnection = HttpManager.getHttpConnection(url, this.credentialsProvider);
|
CloseableHttpClient httpConnection = getHttpClient(url);
|
||||||
Map<String, Object> paramsMap = paramsHandle(params);
|
Map<String, Object> paramsMap = paramsHandle(params);
|
||||||
Map<String, String> headerMap = headersHandle(headers);
|
Map<String, String> headerMap = headersHandle(headers);
|
||||||
HttpPut httpPut = handleHttpPut(url, headerMap, paramsMap);
|
HttpPut httpPut = handleHttpPut(url, headerMap, paramsMap);
|
||||||
|
@ -1010,9 +1038,9 @@ public class HttpUtils {
|
||||||
if (Strings.isNullOrEmpty(contentType)) {
|
if (Strings.isNullOrEmpty(contentType)) {
|
||||||
List<NameValuePair> nvps = new ArrayList<>();
|
List<NameValuePair> nvps = new ArrayList<>();
|
||||||
for (Map.Entry<String, Object> entry : params.entrySet()) {
|
for (Map.Entry<String, Object> entry : params.entrySet()) {
|
||||||
//nvps.add(new BasicNameValuePair(entry.getKey(), JSON.toJSONString(entry.getValue())));
|
// nvps.add(new BasicNameValuePair(entry.getKey(), JSON.toJSONString(entry.getValue())));
|
||||||
|
|
||||||
//修复请求form表单提交时,参数值被双引号括了起来
|
// 修复请求form表单提交时,参数值被双引号括了起来
|
||||||
nvps.add(new BasicNameValuePair(entry.getKey(), Util.null2String(entry.getValue())));
|
nvps.add(new BasicNameValuePair(entry.getKey(), Util.null2String(entry.getValue())));
|
||||||
}
|
}
|
||||||
httpPost.setHeader("Content-Type", HttpArgsType.DEFAULT_CONTENT_TYPE);
|
httpPost.setHeader("Content-Type", HttpArgsType.DEFAULT_CONTENT_TYPE);
|
||||||
|
@ -1020,9 +1048,9 @@ public class HttpUtils {
|
||||||
} else if (contentType.toUpperCase().startsWith(HttpArgsType.X_WWW_FORM_URLENCODED.toUpperCase())) {
|
} else if (contentType.toUpperCase().startsWith(HttpArgsType.X_WWW_FORM_URLENCODED.toUpperCase())) {
|
||||||
List<NameValuePair> nvps = new ArrayList<>();
|
List<NameValuePair> nvps = new ArrayList<>();
|
||||||
for (Map.Entry<String, Object> entry : params.entrySet()) {
|
for (Map.Entry<String, Object> entry : params.entrySet()) {
|
||||||
//nvps.add(new BasicNameValuePair(entry.getKey(), JSON.toJSONString(entry.getValue())));
|
// nvps.add(new BasicNameValuePair(entry.getKey(), JSON.toJSONString(entry.getValue())));
|
||||||
|
|
||||||
//修复请求form表单提交时,参数值被双引号括了起来
|
// 修复请求form表单提交时,参数值被双引号括了起来
|
||||||
nvps.add(new BasicNameValuePair(entry.getKey(), Util.null2String(entry.getValue())));
|
nvps.add(new BasicNameValuePair(entry.getKey(), Util.null2String(entry.getValue())));
|
||||||
}
|
}
|
||||||
httpPost.setEntity(new UrlEncodedFormEntity(nvps));
|
httpPost.setEntity(new UrlEncodedFormEntity(nvps));
|
||||||
|
@ -1059,7 +1087,7 @@ public class HttpUtils {
|
||||||
*/
|
*/
|
||||||
private HttpPost uploadFileByInputStream(String url, List<HttpMultipartFile> multipartFileList,
|
private HttpPost uploadFileByInputStream(String url, List<HttpMultipartFile> multipartFileList,
|
||||||
Map<String, Object> params, Map<String, String> headers) {
|
Map<String, Object> params, Map<String, String> headers) {
|
||||||
//log.info(Util.logStr("start request : url is [{}],other param [\n{}\n],heard [\n{}\n]", url, JSONObject.toJSONString(params,
|
// log.info(Util.logStr("start request : url is [{}],other param [\n{}\n],heard [\n{}\n]", url, JSONObject.toJSONString(params,
|
||||||
// excludefilter,
|
// excludefilter,
|
||||||
// SerializerFeature.PrettyFormat,
|
// SerializerFeature.PrettyFormat,
|
||||||
// SerializerFeature.WriteDateUseDateFormat),
|
// SerializerFeature.WriteDateUseDateFormat),
|
||||||
|
@ -1204,8 +1232,8 @@ public class HttpUtils {
|
||||||
if (Strings.isNullOrEmpty(contentType)) {
|
if (Strings.isNullOrEmpty(contentType)) {
|
||||||
List<NameValuePair> nvps = new ArrayList<>();
|
List<NameValuePair> nvps = new ArrayList<>();
|
||||||
for (Map.Entry<String, Object> entry : paramsMap.entrySet()) {
|
for (Map.Entry<String, Object> entry : paramsMap.entrySet()) {
|
||||||
//nvps.add(new BasicNameValuePair(entry.getKey(), JSON.toJSONString(entry.getValue())));
|
// nvps.add(new BasicNameValuePair(entry.getKey(), JSON.toJSONString(entry.getValue())));
|
||||||
//修复请求form表单提交时,参数值被双引号括了起来
|
// 修复请求form表单提交时,参数值被双引号括了起来
|
||||||
nvps.add(new BasicNameValuePair(entry.getKey(), Util.null2String(entry.getValue())));
|
nvps.add(new BasicNameValuePair(entry.getKey(), Util.null2String(entry.getValue())));
|
||||||
}
|
}
|
||||||
httpPut.setHeader("Content-Type", HttpArgsType.DEFAULT_CONTENT_TYPE);
|
httpPut.setHeader("Content-Type", HttpArgsType.DEFAULT_CONTENT_TYPE);
|
||||||
|
@ -1213,8 +1241,8 @@ public class HttpUtils {
|
||||||
} else if (contentType.toUpperCase().startsWith(HttpArgsType.X_WWW_FORM_URLENCODED.toUpperCase())) {
|
} else if (contentType.toUpperCase().startsWith(HttpArgsType.X_WWW_FORM_URLENCODED.toUpperCase())) {
|
||||||
List<NameValuePair> nvps = new ArrayList<>();
|
List<NameValuePair> nvps = new ArrayList<>();
|
||||||
for (Map.Entry<String, Object> entry : paramsMap.entrySet()) {
|
for (Map.Entry<String, Object> entry : paramsMap.entrySet()) {
|
||||||
//nvps.add(new BasicNameValuePair(entry.getKey(), JSON.toJSONString(entry.getValue())));
|
// nvps.add(new BasicNameValuePair(entry.getKey(), JSON.toJSONString(entry.getValue())));
|
||||||
//修复请求form表单提交时,参数值被双引号括了起来
|
// 修复请求form表单提交时,参数值被双引号括了起来
|
||||||
nvps.add(new BasicNameValuePair(entry.getKey(), Util.null2String(entry.getValue())));
|
nvps.add(new BasicNameValuePair(entry.getKey(), Util.null2String(entry.getValue())));
|
||||||
}
|
}
|
||||||
httpPut.setEntity(new UrlEncodedFormEntity(nvps));
|
httpPut.setEntity(new UrlEncodedFormEntity(nvps));
|
||||||
|
|
|
@ -0,0 +1,30 @@
|
||||||
|
package aiyh.utils.tool;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ASCII字符对应的字符串缓存
|
||||||
|
*
|
||||||
|
* @author looly
|
||||||
|
* @since 4.0.1
|
||||||
|
*/
|
||||||
|
public class ASCIIStrCache {
|
||||||
|
|
||||||
|
private static final int ASCII_LENGTH = 128;
|
||||||
|
private static final String[] CACHE = new String[ASCII_LENGTH];
|
||||||
|
|
||||||
|
static {
|
||||||
|
for (char c = 0; c < ASCII_LENGTH; c++) {
|
||||||
|
CACHE[c] = String.valueOf(c);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字符转为字符串<br>
|
||||||
|
* 如果为ASCII字符,使用缓存
|
||||||
|
*
|
||||||
|
* @param c 字符
|
||||||
|
* @return 字符串
|
||||||
|
*/
|
||||||
|
public static String toString(char c) {
|
||||||
|
return c < ASCII_LENGTH ? CACHE[c] : String.valueOf(c);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,289 @@
|
||||||
|
package aiyh.utils.tool;
|
||||||
|
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
public class Assert {
|
||||||
|
public Assert() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void isTrue(boolean expression, String errorMsgTemplate, Object... params) throws IllegalArgumentException {
|
||||||
|
if (!expression) {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format(errorMsgTemplate, params));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static <T> boolean isEmpty(T[] array) {
|
||||||
|
return array == null || array.length == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static String format(CharSequence template, Object... params) {
|
||||||
|
if (null == template) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
if (isEmpty(params) || isBlank(template)) {
|
||||||
|
return template.toString();
|
||||||
|
}
|
||||||
|
return StrFormatter.format(template.toString(), params);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static boolean isBlank(CharSequence str) {
|
||||||
|
int length;
|
||||||
|
|
||||||
|
if ((str == null) || ((length = str.length()) == 0)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < length; i++) {
|
||||||
|
// 只要有一个非空字符即为非空字符串
|
||||||
|
if (!CharUtil.isBlankChar(str.charAt(i))) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void isTrue(boolean expression) throws IllegalArgumentException {
|
||||||
|
isTrue(expression, "[Assertion failed] - this expression must be true");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void isFalse(boolean expression, String errorMsgTemplate, Object... params) throws IllegalArgumentException {
|
||||||
|
if (expression) {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format(errorMsgTemplate, params));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void isFalse(boolean expression) throws IllegalArgumentException {
|
||||||
|
isFalse(expression, "[Assertion failed] - this expression must be false");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void isNull(Object object, String errorMsgTemplate, Object... params) throws IllegalArgumentException {
|
||||||
|
if (object != null) {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format(errorMsgTemplate, params));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void isNull(Object object) throws IllegalArgumentException {
|
||||||
|
isNull(object, "[Assertion failed] - the object argument must be null");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T> T notNull(T object, String errorMsgTemplate, Object... params) throws IllegalArgumentException {
|
||||||
|
if (object == null) {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format(errorMsgTemplate, params));
|
||||||
|
} else {
|
||||||
|
return object;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T> T notNull(T object) throws IllegalArgumentException {
|
||||||
|
return notNull(object, "[Assertion failed] - this argument is required; it must not be null");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T extends CharSequence> T notEmpty(T text, String errorMsgTemplate, Object... params) throws IllegalArgumentException {
|
||||||
|
if (isEmpty(text)) {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format(errorMsgTemplate, params));
|
||||||
|
} else {
|
||||||
|
return text;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static boolean isEmpty(CharSequence str) {
|
||||||
|
return str == null || str.length() == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T extends CharSequence> T notEmpty(T text) throws IllegalArgumentException {
|
||||||
|
return notEmpty(text, "[Assertion failed] - this String argument must have length; it must not be null or empty");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T extends CharSequence> T notBlank(T text, String errorMsgTemplate, Object... params) throws IllegalArgumentException {
|
||||||
|
if (StrFormatter.isBlank(text)) {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format(errorMsgTemplate, params));
|
||||||
|
} else {
|
||||||
|
return text;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T extends CharSequence> T notBlank(T text) throws IllegalArgumentException {
|
||||||
|
return notBlank(text, "[Assertion failed] - this String argument must have text; it must not be null, empty, or blank");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String notContain(String textToSearch, String substring, String errorMsgTemplate, Object... params) throws IllegalArgumentException {
|
||||||
|
if (isNotEmpty(textToSearch) && isNotEmpty(substring) && textToSearch.contains(substring)) {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format(errorMsgTemplate, params));
|
||||||
|
} else {
|
||||||
|
return substring;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static boolean isNotEmpty(CharSequence str) {
|
||||||
|
return !isEmpty(str);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String notContain(String textToSearch, String substring) throws IllegalArgumentException {
|
||||||
|
return notContain(textToSearch, substring, "[Assertion failed] - this String argument must not contain the substring [{}]", substring);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Object[] notEmpty(Object[] array, String errorMsgTemplate, Object... params) throws IllegalArgumentException {
|
||||||
|
if (Objects.isNull(array) || array.length == 0) {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format(errorMsgTemplate, params));
|
||||||
|
} else {
|
||||||
|
return array;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Object[] notEmpty(Object[] array) throws IllegalArgumentException {
|
||||||
|
return notEmpty(array, "[Assertion failed] - this array must not be empty: it must contain at least 1 element");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T> T[] noNullElements(T[] array, String errorMsgTemplate, Object... params) throws IllegalArgumentException {
|
||||||
|
if (hasNull(array)) {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format(errorMsgTemplate, params));
|
||||||
|
} else {
|
||||||
|
return array;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static <T> boolean hasNull(T... array) {
|
||||||
|
if (isNotEmpty(array)) {
|
||||||
|
Object[] var1 = array;
|
||||||
|
int var2 = array.length;
|
||||||
|
|
||||||
|
for (int var3 = 0; var3 < var2; ++var3) {
|
||||||
|
T element = (T) var1[var3];
|
||||||
|
if (null == element) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T> boolean isNotEmpty(T[] array) {
|
||||||
|
return array != null && array.length != 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T> T[] noNullElements(T[] array) throws IllegalArgumentException {
|
||||||
|
return noNullElements(array, "[Assertion failed] - this array must not contain any null elements");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T> Collection<T> notEmpty(Collection<T> collection, String errorMsgTemplate, Object... params) throws IllegalArgumentException {
|
||||||
|
if (collection == null || collection.isEmpty()) {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format(errorMsgTemplate, params));
|
||||||
|
} else {
|
||||||
|
return collection;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T> Collection<T> notEmpty(Collection<T> collection) throws IllegalArgumentException {
|
||||||
|
return notEmpty(collection, "[Assertion failed] - this collection must not be empty: it must contain at least 1 element");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <K, V> Map<K, V> notEmpty(Map<K, V> map, String errorMsgTemplate, Object... params) throws IllegalArgumentException {
|
||||||
|
if (Objects.isNull(map) || map.isEmpty()) {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format(errorMsgTemplate, params));
|
||||||
|
} else {
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <K, V> Map<K, V> notEmpty(Map<K, V> map) throws IllegalArgumentException {
|
||||||
|
return notEmpty(map, "[Assertion failed] - this map must not be empty; it must contain at least one entry");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T> T isInstanceOf(Class<?> type, T obj) {
|
||||||
|
return isInstanceOf(type, obj, "Object [{}] is not instanceof [{}]", obj, type);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T> T isInstanceOf(Class<?> type, T obj, String errorMsgTemplate, Object... params) throws IllegalArgumentException {
|
||||||
|
notNull(type, "Type to check against must not be null");
|
||||||
|
if (!type.isInstance(obj)) {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format(errorMsgTemplate, params));
|
||||||
|
} else {
|
||||||
|
return obj;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void isAssignable(Class<?> superType, Class<?> subType) throws IllegalArgumentException {
|
||||||
|
isAssignable(superType, subType, "{} is not assignable to {})", subType, superType);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void isAssignable(Class<?> superType, Class<?> subType, String errorMsgTemplate, Object... params) throws IllegalArgumentException {
|
||||||
|
notNull(superType, "Type to check against must not be null");
|
||||||
|
if (subType == null || !superType.isAssignableFrom(subType)) {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format(errorMsgTemplate, params));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void state(boolean expression, String errorMsgTemplate, Object... params) throws IllegalStateException {
|
||||||
|
if (!expression) {
|
||||||
|
throw new IllegalStateException(StrFormatter.format(errorMsgTemplate, params));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void state(boolean expression) throws IllegalStateException {
|
||||||
|
state(expression, "[Assertion failed] - this state invariant must be true");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static int checkIndex(int index, int size) throws IllegalArgumentException, IndexOutOfBoundsException {
|
||||||
|
return checkIndex(index, size, "[Assertion failed]");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static int checkIndex(int index, int size, String errorMsgTemplate, Object... params) throws IllegalArgumentException, IndexOutOfBoundsException {
|
||||||
|
if (index >= 0 && index < size) {
|
||||||
|
return index;
|
||||||
|
} else {
|
||||||
|
throw new IndexOutOfBoundsException(badIndexMsg(index, size, errorMsgTemplate, params));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static int checkBetween(int value, int min, int max) {
|
||||||
|
if (value >= min && value <= max) {
|
||||||
|
return value;
|
||||||
|
} else {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format("Length must be between {} and {}.", min, max));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static long checkBetween(long value, long min, long max) {
|
||||||
|
if (value >= min && value <= max) {
|
||||||
|
return value;
|
||||||
|
} else {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format("Length must be between {} and {}.", min, max));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static double checkBetween(double value, double min, double max) {
|
||||||
|
if (!(value < min) && !(value > max)) {
|
||||||
|
return value;
|
||||||
|
} else {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format("Length must be between {} and {}.", min, max));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Number checkBetween(Number value, Number min, Number max) {
|
||||||
|
notNull(value);
|
||||||
|
notNull(min);
|
||||||
|
notNull(max);
|
||||||
|
double valueDouble = value.doubleValue();
|
||||||
|
double minDouble = min.doubleValue();
|
||||||
|
double maxDouble = max.doubleValue();
|
||||||
|
if (!(valueDouble < minDouble) && !(valueDouble > maxDouble)) {
|
||||||
|
return value;
|
||||||
|
} else {
|
||||||
|
throw new IllegalArgumentException(StrFormatter.format("Length must be between {} and {}.", min, max));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static String badIndexMsg(int index, int size, String desc, Object... params) {
|
||||||
|
if (index < 0) {
|
||||||
|
return StrFormatter.format("{} ({}) must not be negative", StrFormatter.format(desc, params), index);
|
||||||
|
} else if (size < 0) {
|
||||||
|
throw new IllegalArgumentException("negative size: " + size);
|
||||||
|
} else {
|
||||||
|
return StrFormatter.format("{} ({}) must be less than size ({})", StrFormatter.format(desc, params), index, size);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,336 @@
|
||||||
|
package aiyh.utils.tool;
|
||||||
|
|
||||||
|
|
||||||
|
import cn.hutool.core.text.ASCIIStrCache;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字符工具类<br>
|
||||||
|
* 部分工具来自于Apache Commons系列
|
||||||
|
*
|
||||||
|
* @author looly
|
||||||
|
* @since 4.0.1
|
||||||
|
*/
|
||||||
|
public class CharUtil {
|
||||||
|
|
||||||
|
public static final char SPACE = ' ';
|
||||||
|
public static final char TAB = ' ';
|
||||||
|
public static final char DOT = '.';
|
||||||
|
public static final char SLASH = '/';
|
||||||
|
public static final char BACKSLASH = '\\';
|
||||||
|
public static final char CR = '\r';
|
||||||
|
public static final char LF = '\n';
|
||||||
|
public static final char UNDERLINE = '_';
|
||||||
|
public static final char DASHED = '-';
|
||||||
|
public static final char COMMA = ',';
|
||||||
|
public static final char DELIM_START = '{';
|
||||||
|
public static final char DELIM_END = '}';
|
||||||
|
public static final char BRACKET_START = '[';
|
||||||
|
public static final char BRACKET_END = ']';
|
||||||
|
public static final char COLON = ':';
|
||||||
|
public static final char DOUBLE_QUOTES = '"';
|
||||||
|
public static final char SINGLE_QUOTE = '\'';
|
||||||
|
public static final char AMP = '&';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 是否为ASCII字符,ASCII字符位于0~127之间
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* CharUtil.isAscii('a') = true
|
||||||
|
* CharUtil.isAscii('A') = true
|
||||||
|
* CharUtil.isAscii('3') = true
|
||||||
|
* CharUtil.isAscii('-') = true
|
||||||
|
* CharUtil.isAscii('\n') = true
|
||||||
|
* CharUtil.isAscii('©') = false
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @param ch 被检查的字符处
|
||||||
|
* @return true表示为ASCII字符,ASCII字符位于0~127之间
|
||||||
|
*/
|
||||||
|
public static boolean isAscii(char ch) {
|
||||||
|
return ch < 128;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 是否为可见ASCII字符,可见字符位于32~126之间
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* CharUtil.isAsciiPrintable('a') = true
|
||||||
|
* CharUtil.isAsciiPrintable('A') = true
|
||||||
|
* CharUtil.isAsciiPrintable('3') = true
|
||||||
|
* CharUtil.isAsciiPrintable('-') = true
|
||||||
|
* CharUtil.isAsciiPrintable('\n') = false
|
||||||
|
* CharUtil.isAsciiPrintable('©') = false
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @param ch 被检查的字符处
|
||||||
|
* @return true表示为ASCII可见字符,可见字符位于32~126之间
|
||||||
|
*/
|
||||||
|
public static boolean isAsciiPrintable(char ch) {
|
||||||
|
return ch >= 32 && ch < 127;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 是否为ASCII控制符(不可见字符),控制符位于0~31和127
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* CharUtil.isAsciiControl('a') = false
|
||||||
|
* CharUtil.isAsciiControl('A') = false
|
||||||
|
* CharUtil.isAsciiControl('3') = false
|
||||||
|
* CharUtil.isAsciiControl('-') = false
|
||||||
|
* CharUtil.isAsciiControl('\n') = true
|
||||||
|
* CharUtil.isAsciiControl('©') = false
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @param ch 被检查的字符
|
||||||
|
* @return true表示为控制符,控制符位于0~31和127
|
||||||
|
*/
|
||||||
|
public static boolean isAsciiControl(final char ch) {
|
||||||
|
return ch < 32 || ch == 127;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 判断是否为字母(包括大写字母和小写字母)<br>
|
||||||
|
* 字母包括A~Z和a~z
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* CharUtil.isLetter('a') = true
|
||||||
|
* CharUtil.isLetter('A') = true
|
||||||
|
* CharUtil.isLetter('3') = false
|
||||||
|
* CharUtil.isLetter('-') = false
|
||||||
|
* CharUtil.isLetter('\n') = false
|
||||||
|
* CharUtil.isLetter('©') = false
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @param ch 被检查的字符
|
||||||
|
* @return true表示为字母(包括大写字母和小写字母)字母包括A~Z和a~z
|
||||||
|
*/
|
||||||
|
public static boolean isLetter(char ch) {
|
||||||
|
return isLetterUpper(ch) || isLetterLower(ch);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>
|
||||||
|
* 判断是否为大写字母,大写字母包括A~Z
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* CharUtil.isLetterUpper('a') = false
|
||||||
|
* CharUtil.isLetterUpper('A') = true
|
||||||
|
* CharUtil.isLetterUpper('3') = false
|
||||||
|
* CharUtil.isLetterUpper('-') = false
|
||||||
|
* CharUtil.isLetterUpper('\n') = false
|
||||||
|
* CharUtil.isLetterUpper('©') = false
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @param ch 被检查的字符
|
||||||
|
* @return true表示为大写字母,大写字母包括A~Z
|
||||||
|
*/
|
||||||
|
public static boolean isLetterUpper(final char ch) {
|
||||||
|
return ch >= 'A' && ch <= 'Z';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>
|
||||||
|
* 检查字符是否为小写字母,小写字母指a~z
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* CharUtil.isLetterLower('a') = true
|
||||||
|
* CharUtil.isLetterLower('A') = false
|
||||||
|
* CharUtil.isLetterLower('3') = false
|
||||||
|
* CharUtil.isLetterLower('-') = false
|
||||||
|
* CharUtil.isLetterLower('\n') = false
|
||||||
|
* CharUtil.isLetterLower('©') = false
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @param ch 被检查的字符
|
||||||
|
* @return true表示为小写字母,小写字母指a~z
|
||||||
|
*/
|
||||||
|
public static boolean isLetterLower(final char ch) {
|
||||||
|
return ch >= 'a' && ch <= 'z';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>
|
||||||
|
* 检查是否为数字字符,数字字符指0~9
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* CharUtil.isNumber('a') = false
|
||||||
|
* CharUtil.isNumber('A') = false
|
||||||
|
* CharUtil.isNumber('3') = true
|
||||||
|
* CharUtil.isNumber('-') = false
|
||||||
|
* CharUtil.isNumber('\n') = false
|
||||||
|
* CharUtil.isNumber('©') = false
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @param ch 被检查的字符
|
||||||
|
* @return true表示为数字字符,数字字符指0~9
|
||||||
|
*/
|
||||||
|
public static boolean isNumber(char ch) {
|
||||||
|
return ch >= '0' && ch <= '9';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 是否为16进制规范的字符,判断是否为如下字符
|
||||||
|
* <pre>
|
||||||
|
* 1. 0~9
|
||||||
|
* 2. a~f
|
||||||
|
* 4. A~F
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @param c 字符
|
||||||
|
* @return 是否为16进制规范的字符
|
||||||
|
* @since 4.1.5
|
||||||
|
*/
|
||||||
|
public static boolean isHexChar(char c) {
|
||||||
|
return isNumber(c) || (c >= 'a' && c <= 'f') || (c >= 'A' && c <= 'F');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 是否为字符或数字,包括A~Z、a~z、0~9
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* CharUtil.isLetterOrNumber('a') = true
|
||||||
|
* CharUtil.isLetterOrNumber('A') = true
|
||||||
|
* CharUtil.isLetterOrNumber('3') = true
|
||||||
|
* CharUtil.isLetterOrNumber('-') = false
|
||||||
|
* CharUtil.isLetterOrNumber('\n') = false
|
||||||
|
* CharUtil.isLetterOrNumber('©') = false
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @param ch 被检查的字符
|
||||||
|
* @return true表示为字符或数字,包括A~Z、a~z、0~9
|
||||||
|
*/
|
||||||
|
public static boolean isLetterOrNumber(final char ch) {
|
||||||
|
return isLetter(ch) || isNumber(ch);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字符转为字符串<br>
|
||||||
|
* 如果为ASCII字符,使用缓存
|
||||||
|
*
|
||||||
|
* @param c 字符
|
||||||
|
* @return 字符串
|
||||||
|
* @see ASCIIStrCache#toString(char)
|
||||||
|
*/
|
||||||
|
public static String toString(char c) {
|
||||||
|
return ASCIIStrCache.toString(c);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 给定类名是否为字符类,字符类包括:
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* Character.class
|
||||||
|
* char.class
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @param clazz 被检查的类
|
||||||
|
* @return true表示为字符类
|
||||||
|
*/
|
||||||
|
public static boolean isCharClass(Class<?> clazz) {
|
||||||
|
return clazz == Character.class || clazz == char.class;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 给定对象对应的类是否为字符类,字符类包括:
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* Character.class
|
||||||
|
* char.class
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @param value 被检查的对象
|
||||||
|
* @return true表示为字符类
|
||||||
|
*/
|
||||||
|
public static boolean isChar(Object value) {
|
||||||
|
// noinspection ConstantConditions
|
||||||
|
return value instanceof Character || value.getClass() == char.class;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 是否空白符<br>
|
||||||
|
* 空白符包括空格、制表符、全角空格和不间断空格<br>
|
||||||
|
*
|
||||||
|
* @param c 字符
|
||||||
|
* @return 是否空白符
|
||||||
|
* @see Character#isWhitespace(int)
|
||||||
|
* @see Character#isSpaceChar(int)
|
||||||
|
* @since 4.0.10
|
||||||
|
*/
|
||||||
|
public static boolean isBlankChar(char c) {
|
||||||
|
return isBlankChar((int) c);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 是否空白符<br>
|
||||||
|
* 空白符包括空格、制表符、全角空格和不间断空格<br>
|
||||||
|
*
|
||||||
|
* @param c 字符
|
||||||
|
* @return 是否空白符
|
||||||
|
* @see Character#isWhitespace(int)
|
||||||
|
* @see Character#isSpaceChar(int)
|
||||||
|
* @since 4.0.10
|
||||||
|
*/
|
||||||
|
public static boolean isBlankChar(int c) {
|
||||||
|
return Character.isWhitespace(c) || Character.isSpaceChar(c) || c == '\ufeff' || c == '\u202a';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 判断是否为emoji表情符<br>
|
||||||
|
*
|
||||||
|
* @param c 字符
|
||||||
|
* @return 是否为emoji
|
||||||
|
* @since 4.0.8
|
||||||
|
*/
|
||||||
|
public static boolean isEmoji(char c) {
|
||||||
|
// noinspection ConstantConditions
|
||||||
|
return !((c == 0x0) || //
|
||||||
|
(c == 0x9) || //
|
||||||
|
(c == 0xA) || //
|
||||||
|
(c == 0xD) || //
|
||||||
|
((c >= 0x20) && (c <= 0xD7FF)) || //
|
||||||
|
((c >= 0xE000) && (c <= 0xFFFD)) || //
|
||||||
|
((c >= 0x100000) && (c <= 0x10FFFF)));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 是否为Windows或者Linux(Unix)文件分隔符<br>
|
||||||
|
* Windows平台下分隔符为\,Linux(Unix)为/
|
||||||
|
*
|
||||||
|
* @param c 字符
|
||||||
|
* @return 是否为Windows或者Linux(Unix)文件分隔符
|
||||||
|
* @since 4.1.11
|
||||||
|
*/
|
||||||
|
public static boolean isFileSeparator(char c) {
|
||||||
|
return SLASH == c || BACKSLASH == c;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 比较两个字符是否相同
|
||||||
|
*
|
||||||
|
* @param c1 字符1
|
||||||
|
* @param c2 字符2
|
||||||
|
* @param ignoreCase 是否忽略大小写
|
||||||
|
* @return 是否相同
|
||||||
|
* @since 4.0.3
|
||||||
|
*/
|
||||||
|
public static boolean equals(char c1, char c2, boolean ignoreCase) {
|
||||||
|
if (ignoreCase) {
|
||||||
|
return Character.toLowerCase(c1) == Character.toLowerCase(c2);
|
||||||
|
}
|
||||||
|
return c1 == c2;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取字符类型
|
||||||
|
*
|
||||||
|
* @param c 字符
|
||||||
|
* @return 字符类型
|
||||||
|
* @since 5.2.3
|
||||||
|
*/
|
||||||
|
public static int getType(int c) {
|
||||||
|
return Character.getType(c);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,364 @@
|
||||||
|
package aiyh.utils.tool;
|
||||||
|
|
||||||
|
import java.nio.ByteBuffer;
|
||||||
|
import java.nio.charset.Charset;
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字符串格式化工具
|
||||||
|
*
|
||||||
|
* @author Looly
|
||||||
|
*/
|
||||||
|
public class StrFormatter {
|
||||||
|
public static final String ISO_8859_1 = "ISO-8859-1";
|
||||||
|
/**
|
||||||
|
* UTF-8
|
||||||
|
*/
|
||||||
|
public static final String UTF_8 = "UTF-8";
|
||||||
|
/**
|
||||||
|
* GBK
|
||||||
|
*/
|
||||||
|
public static final String GBK = "GBK";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ISO-8859-1
|
||||||
|
*/
|
||||||
|
public static final Charset CHARSET_ISO_8859_1 = StandardCharsets.ISO_8859_1;
|
||||||
|
/**
|
||||||
|
* UTF-8
|
||||||
|
*/
|
||||||
|
public static final Charset CHARSET_UTF_8 = StandardCharsets.UTF_8;
|
||||||
|
public static final int INDEX_NOT_FOUND = -1;
|
||||||
|
|
||||||
|
public static final char C_SPACE = CharUtil.SPACE;
|
||||||
|
public static final char C_TAB = CharUtil.TAB;
|
||||||
|
public static final char C_DOT = CharUtil.DOT;
|
||||||
|
public static final char C_SLASH = CharUtil.SLASH;
|
||||||
|
public static final char C_BACKSLASH = CharUtil.BACKSLASH;
|
||||||
|
public static final char C_CR = CharUtil.CR;
|
||||||
|
public static final char C_LF = CharUtil.LF;
|
||||||
|
public static final char C_UNDERLINE = CharUtil.UNDERLINE;
|
||||||
|
public static final char C_COMMA = CharUtil.COMMA;
|
||||||
|
public static final char C_DELIM_START = CharUtil.DELIM_START;
|
||||||
|
public static final char C_DELIM_END = CharUtil.DELIM_END;
|
||||||
|
public static final char C_BRACKET_START = CharUtil.BRACKET_START;
|
||||||
|
public static final char C_BRACKET_END = CharUtil.BRACKET_END;
|
||||||
|
public static final char C_COLON = CharUtil.COLON;
|
||||||
|
public static final String SPACE = " ";
|
||||||
|
public static final String TAB = " ";
|
||||||
|
public static final String DOT = ".";
|
||||||
|
public static final String DOUBLE_DOT = "..";
|
||||||
|
public static final String SLASH = "/";
|
||||||
|
public static final String BACKSLASH = "\\";
|
||||||
|
public static final String EMPTY = "";
|
||||||
|
public static final String NULL = "null";
|
||||||
|
public static final String CR = "\r";
|
||||||
|
public static final String LF = "\n";
|
||||||
|
public static final String CRLF = "\r\n";
|
||||||
|
public static final String UNDERLINE = "_";
|
||||||
|
public static final String DASHED = "-";
|
||||||
|
public static final String COMMA = ",";
|
||||||
|
public static final String DELIM_START = "{";
|
||||||
|
public static final String DELIM_END = "}";
|
||||||
|
public static final String BRACKET_START = "[";
|
||||||
|
public static final String BRACKET_END = "]";
|
||||||
|
public static final String COLON = ":";
|
||||||
|
|
||||||
|
public static final String HTML_NBSP = " ";
|
||||||
|
public static final String HTML_AMP = "&";
|
||||||
|
public static final String HTML_QUOTE = """;
|
||||||
|
public static final String HTML_APOS = "'";
|
||||||
|
public static final String HTML_LT = "<";
|
||||||
|
public static final String HTML_GT = ">";
|
||||||
|
|
||||||
|
public static final String EMPTY_JSON = "{}";
|
||||||
|
|
||||||
|
public static boolean isBlank(CharSequence str) {
|
||||||
|
final int length;
|
||||||
|
if ((str == null) || ((length = str.length()) == 0)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < length; i++) {
|
||||||
|
// 只要有一个非空字符即为非空字符串
|
||||||
|
if (!isBlankChar(str.charAt(i))) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean isBlankChar(char c) {
|
||||||
|
return isBlankChar((int) c);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean isBlankChar(int c) {
|
||||||
|
return Character.isWhitespace(c) || Character.isSpaceChar(c) || c == '\ufeff' || c == '\u202a';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 格式化字符串<br>
|
||||||
|
* 此方法只是简单将占位符 {} 按照顺序替换为参数<br>
|
||||||
|
* 如果想输出 {} 使用 \\转义 { 即可,如果想输出 {} 之前的 \ 使用双转义符 \\\\ 即可<br>
|
||||||
|
* 例:<br>
|
||||||
|
* 通常使用:format("this is {} for {}", "a", "b") =》 this is a for b<br>
|
||||||
|
* 转义{}: format("this is \\{} for {}", "a", "b") =》 this is \{} for a<br>
|
||||||
|
* 转义\: format("this is \\\\{} for {}", "a", "b") =》 this is \a for b<br>
|
||||||
|
*
|
||||||
|
* @param strPattern 字符串模板
|
||||||
|
* @param argArray 参数列表
|
||||||
|
* @return 结果
|
||||||
|
*/
|
||||||
|
public static String format(String strPattern, Object... argArray) {
|
||||||
|
return formatWith(strPattern, EMPTY_JSON, argArray);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T> boolean isEmpty(T[] array) {
|
||||||
|
return array == null || array.length == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 格式化字符串<br>
|
||||||
|
* 此方法只是简单将指定占位符 按照顺序替换为参数<br>
|
||||||
|
* 如果想输出占位符使用 \\转义即可,如果想输出占位符之前的 \ 使用双转义符 \\\\ 即可<br>
|
||||||
|
* 例:<br>
|
||||||
|
* 通常使用:format("this is {} for {}", "{}", "a", "b") =》 this is a for b<br>
|
||||||
|
* 转义{}: format("this is \\{} for {}", "{}", "a", "b") =》 this is {} for a<br>
|
||||||
|
* 转义\: format("this is \\\\{} for {}", "{}", "a", "b") =》 this is \a for b<br>
|
||||||
|
*
|
||||||
|
* @param strPattern 字符串模板
|
||||||
|
* @param placeHolder 占位符,例如{}
|
||||||
|
* @param argArray 参数列表
|
||||||
|
* @return 结果
|
||||||
|
* @since 5.7.14
|
||||||
|
*/
|
||||||
|
public static String formatWith(String strPattern, String placeHolder, Object... argArray) {
|
||||||
|
if (isBlank(strPattern) || isBlank(placeHolder) || isEmpty(argArray)) {
|
||||||
|
return strPattern;
|
||||||
|
}
|
||||||
|
final int strPatternLength = strPattern.length();
|
||||||
|
final int placeHolderLength = placeHolder.length();
|
||||||
|
|
||||||
|
// 初始化定义好的长度以获得更好的性能
|
||||||
|
final StringBuilder sbuf = new StringBuilder(strPatternLength + 50);
|
||||||
|
|
||||||
|
int handledPosition = 0;// 记录已经处理到的位置
|
||||||
|
int delimIndex;// 占位符所在位置
|
||||||
|
for (int argIndex = 0; argIndex < argArray.length; argIndex++) {
|
||||||
|
delimIndex = strPattern.indexOf(placeHolder, handledPosition);
|
||||||
|
if (delimIndex == -1) {// 剩余部分无占位符
|
||||||
|
if (handledPosition == 0) { // 不带占位符的模板直接返回
|
||||||
|
return strPattern;
|
||||||
|
}
|
||||||
|
// 字符串模板剩余部分不再包含占位符,加入剩余部分后返回结果
|
||||||
|
sbuf.append(strPattern, handledPosition, strPatternLength);
|
||||||
|
return sbuf.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 转义符
|
||||||
|
if (delimIndex > 0 && strPattern.charAt(delimIndex - 1) == C_BACKSLASH) {// 转义符
|
||||||
|
if (delimIndex > 1 && strPattern.charAt(delimIndex - 2) == C_BACKSLASH) {// 双转义符
|
||||||
|
// 转义符之前还有一个转义符,占位符依旧有效
|
||||||
|
sbuf.append(strPattern, handledPosition, delimIndex - 1);
|
||||||
|
sbuf.append(utf8Str(argArray[argIndex]));
|
||||||
|
handledPosition = delimIndex + placeHolderLength;
|
||||||
|
} else {
|
||||||
|
// 占位符被转义
|
||||||
|
argIndex--;
|
||||||
|
sbuf.append(strPattern, handledPosition, delimIndex - 1);
|
||||||
|
sbuf.append(placeHolder.charAt(0));
|
||||||
|
handledPosition = delimIndex + 1;
|
||||||
|
}
|
||||||
|
} else {// 正常占位符
|
||||||
|
sbuf.append(strPattern, handledPosition, delimIndex);
|
||||||
|
sbuf.append(utf8Str(argArray[argIndex]));
|
||||||
|
handledPosition = delimIndex + placeHolderLength;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 加入最后一个占位符后所有的字符
|
||||||
|
sbuf.append(strPattern, handledPosition, strPatternLength);
|
||||||
|
|
||||||
|
return sbuf.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String utf8Str(Object obj) {
|
||||||
|
return str(obj, CHARSET_UTF_8);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String str(Object obj, Charset charset) {
|
||||||
|
if (null == obj) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (obj instanceof String) {
|
||||||
|
return (String) obj;
|
||||||
|
} else if (obj instanceof byte[]) {
|
||||||
|
return str(obj, charset);
|
||||||
|
} else if (obj instanceof Byte[]) {
|
||||||
|
return str(obj, charset);
|
||||||
|
} else if (obj instanceof ByteBuffer) {
|
||||||
|
return str(obj, charset);
|
||||||
|
} else if (isArray(obj)) {
|
||||||
|
return toString(obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
return obj.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String toString(Object obj) {
|
||||||
|
if (null == obj) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (obj instanceof long[]) {
|
||||||
|
return Arrays.toString((long[]) obj);
|
||||||
|
} else if (obj instanceof int[]) {
|
||||||
|
return Arrays.toString((int[]) obj);
|
||||||
|
} else if (obj instanceof short[]) {
|
||||||
|
return Arrays.toString((short[]) obj);
|
||||||
|
} else if (obj instanceof char[]) {
|
||||||
|
return Arrays.toString((char[]) obj);
|
||||||
|
} else if (obj instanceof byte[]) {
|
||||||
|
return Arrays.toString((byte[]) obj);
|
||||||
|
} else if (obj instanceof boolean[]) {
|
||||||
|
return Arrays.toString((boolean[]) obj);
|
||||||
|
} else if (obj instanceof float[]) {
|
||||||
|
return Arrays.toString((float[]) obj);
|
||||||
|
} else if (obj instanceof double[]) {
|
||||||
|
return Arrays.toString((double[]) obj);
|
||||||
|
} else if (isArray(obj)) {
|
||||||
|
// 对象数组
|
||||||
|
try {
|
||||||
|
return Arrays.deepToString((Object[]) obj);
|
||||||
|
} catch (Exception ignore) {
|
||||||
|
// ignore
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return obj.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean isArray(Object obj) {
|
||||||
|
return null != obj && obj.getClass().isArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 格式化文本,使用 {varName} 占位<br>
|
||||||
|
* map = {a: "aValue", b: "bValue"} format("{a} and {b}", map) ---=》 aValue and bValue
|
||||||
|
*
|
||||||
|
* @param template 文本模板,被替换的部分用 {key} 表示
|
||||||
|
* @param map 参数值对
|
||||||
|
* @param ignoreNull 是否忽略 {@code null} 值,忽略则 {@code null} 值对应的变量不被替换,否则替换为""
|
||||||
|
* @return 格式化后的文本
|
||||||
|
* @since 5.7.10
|
||||||
|
*/
|
||||||
|
public static String format(CharSequence template, Map<?, ?> map, boolean ignoreNull) {
|
||||||
|
if (null == template) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
if (null == map || map.isEmpty()) {
|
||||||
|
return template.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
String template2 = template.toString();
|
||||||
|
String value;
|
||||||
|
for (Map.Entry<?, ?> entry : map.entrySet()) {
|
||||||
|
value = utf8Str(entry.getValue());
|
||||||
|
if (null == value && ignoreNull) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
template2 = replace(template2, "{" + entry.getKey() + "}", value);
|
||||||
|
}
|
||||||
|
return template2;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean isSubEquals(CharSequence str1, int start1, CharSequence str2, int start2, int length, boolean ignoreCase) {
|
||||||
|
if (null == str1 || null == str2) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return str1.toString().regionMatches(ignoreCase, start1, str2.toString(), start2, length);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static int indexOf(final CharSequence str, CharSequence searchStr, int fromIndex, boolean ignoreCase) {
|
||||||
|
if (str == null || searchStr == null) {
|
||||||
|
return INDEX_NOT_FOUND;
|
||||||
|
}
|
||||||
|
if (fromIndex < 0) {
|
||||||
|
fromIndex = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
final int endLimit = str.length() - searchStr.length() + 1;
|
||||||
|
if (fromIndex > endLimit) {
|
||||||
|
return INDEX_NOT_FOUND;
|
||||||
|
}
|
||||||
|
if (searchStr.length() == 0) {
|
||||||
|
return fromIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!ignoreCase) {
|
||||||
|
// 不忽略大小写调用JDK方法
|
||||||
|
return str.toString().indexOf(searchStr.toString(), fromIndex);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = fromIndex; i < endLimit; i++) {
|
||||||
|
if (isSubEquals(str, i, searchStr, 0, searchStr.length(), true)) {
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return INDEX_NOT_FOUND;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String str(CharSequence cs) {
|
||||||
|
return null == cs ? null : cs.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean isEmpty(CharSequence str) {
|
||||||
|
return str == null || str.length() == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String replace(CharSequence str, CharSequence searchStr, CharSequence replacement) {
|
||||||
|
return replace(str, 0, searchStr, replacement, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String replace(CharSequence str, int fromIndex, CharSequence searchStr, CharSequence replacement, boolean ignoreCase) {
|
||||||
|
if (isEmpty(str) || isEmpty(searchStr)) {
|
||||||
|
return str(str);
|
||||||
|
}
|
||||||
|
if (null == replacement) {
|
||||||
|
replacement = EMPTY;
|
||||||
|
}
|
||||||
|
|
||||||
|
final int strLength = str.length();
|
||||||
|
final int searchStrLength = searchStr.length();
|
||||||
|
if (fromIndex > strLength) {
|
||||||
|
return str(str);
|
||||||
|
} else if (fromIndex < 0) {
|
||||||
|
fromIndex = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
final StringBuilder result = new StringBuilder(strLength + 16);
|
||||||
|
if (0 != fromIndex) {
|
||||||
|
result.append(str.subSequence(0, fromIndex));
|
||||||
|
}
|
||||||
|
|
||||||
|
int preIndex = fromIndex;
|
||||||
|
int index;
|
||||||
|
while ((index = indexOf(str, searchStr, preIndex, ignoreCase)) > -1) {
|
||||||
|
result.append(str.subSequence(preIndex, index));
|
||||||
|
result.append(replacement);
|
||||||
|
preIndex = index + searchStrLength;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (preIndex < strLength) {
|
||||||
|
// 结尾部分
|
||||||
|
result.append(str.subSequence(preIndex, strLength));
|
||||||
|
}
|
||||||
|
return result.toString();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,47 @@
|
||||||
|
package com.api.youhong.ai.pcn.racetrack.controller;
|
||||||
|
|
||||||
|
import aiyh.utils.ApiResult;
|
||||||
|
import aiyh.utils.Util;
|
||||||
|
import com.api.youhong.ai.pcn.racetrack.service.RaceTrackService;
|
||||||
|
import org.apache.log4j.Logger;
|
||||||
|
import weaver.hrm.HrmUserVarify;
|
||||||
|
import weaver.hrm.User;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import javax.ws.rs.Consumes;
|
||||||
|
import javax.ws.rs.GET;
|
||||||
|
import javax.ws.rs.Path;
|
||||||
|
import javax.ws.rs.Produces;
|
||||||
|
import javax.ws.rs.core.Context;
|
||||||
|
import javax.ws.rs.core.MediaType;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>赛道图接口</h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/2/14 11:58</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
@Path("aiyh/race-track")
|
||||||
|
public class RaceTrackController {
|
||||||
|
|
||||||
|
private final Logger log = Util.getLogger();
|
||||||
|
|
||||||
|
private final RaceTrackService service = new RaceTrackService();
|
||||||
|
|
||||||
|
@GET
|
||||||
|
@Path("/get/event-list")
|
||||||
|
@Produces(MediaType.APPLICATION_JSON)
|
||||||
|
@Consumes(MediaType.APPLICATION_JSON)
|
||||||
|
public String getEventList(@Context HttpServletRequest request, @Context HttpServletResponse response) {
|
||||||
|
User user = HrmUserVarify.getUser(request, response);
|
||||||
|
try {
|
||||||
|
return ApiResult.success(service.getEventList(user));
|
||||||
|
} catch (Exception e) {
|
||||||
|
log.info("race track get event list error!\n" + Util.getErrString(e));
|
||||||
|
return ApiResult.error("race track get event list error!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,32 @@
|
||||||
|
package com.api.youhong.ai.pcn.racetrack.dto;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import lombok.ToString;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1></h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/2/14 17:19</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
@Setter
|
||||||
|
@Getter
|
||||||
|
@ToString
|
||||||
|
public class RaceTrackEvent {
|
||||||
|
/** id */
|
||||||
|
private Integer id;
|
||||||
|
|
||||||
|
/** 标题 */
|
||||||
|
private String title;
|
||||||
|
|
||||||
|
/** 副标题 */
|
||||||
|
private String subtitle;
|
||||||
|
|
||||||
|
/** 日期 */
|
||||||
|
private String date;
|
||||||
|
|
||||||
|
/** 月份 */
|
||||||
|
private String month;
|
||||||
|
}
|
|
@ -0,0 +1,50 @@
|
||||||
|
package com.api.youhong.ai.pcn.racetrack.mapper;
|
||||||
|
|
||||||
|
import aiyh.utils.annotation.recordset.ParamMapper;
|
||||||
|
import aiyh.utils.annotation.recordset.Select;
|
||||||
|
import aiyh.utils.annotation.recordset.SqlMapper;
|
||||||
|
import com.api.youhong.ai.pcn.racetrack.dto.RaceTrackEvent;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1></h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/2/14 15:07</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
@SqlMapper
|
||||||
|
public interface RacetrackMapper {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>查询当前年的事件列表</h2>
|
||||||
|
*
|
||||||
|
* @param raceTrackEventListTable 事件所属表
|
||||||
|
* @param raceTrackEventListDateField 事件日期字段
|
||||||
|
* @param raceTrackEventListTitleField 事件标题字段
|
||||||
|
* @param raceTrackEventListSubtitleField 事件副标题字段
|
||||||
|
* @return 事件列表
|
||||||
|
* @author youhong.ai
|
||||||
|
*/
|
||||||
|
@Select("select id, $t{raceTrackEventListDateField} date," +
|
||||||
|
"$t{raceTrackEventListTitleField} title," +
|
||||||
|
"MONTH($t{raceTrackEventListDateField}) month," +
|
||||||
|
"$t{raceTrackEventListSubtitleField} subtitle " +
|
||||||
|
" from $t{raceTrackEventListTable} where " +
|
||||||
|
"year($t{raceTrackEventListDateField}) = YEAR(NOW())")
|
||||||
|
List<RaceTrackEvent> selectEventList(@ParamMapper("raceTrackEventListTable") String raceTrackEventListTable,
|
||||||
|
@ParamMapper("raceTrackEventListDateField") String raceTrackEventListDateField,
|
||||||
|
@ParamMapper("raceTrackEventListTitleField") String raceTrackEventListTitleField,
|
||||||
|
@ParamMapper("raceTrackEventListSubtitleField") String raceTrackEventListSubtitleField);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>查询入职时间</h2>
|
||||||
|
*
|
||||||
|
* @param userId 用户ID
|
||||||
|
* @return 入职年限
|
||||||
|
* @author youhong.ai
|
||||||
|
*/
|
||||||
|
@Select("select companyworkyear from hrmresource where id = #{userId}")
|
||||||
|
String selectLengthOfEntryTime(@ParamMapper("userId") Integer userId);
|
||||||
|
}
|
|
@ -0,0 +1,59 @@
|
||||||
|
package com.api.youhong.ai.pcn.racetrack.service;
|
||||||
|
|
||||||
|
import aiyh.utils.Util;
|
||||||
|
import cn.hutool.core.lang.Assert;
|
||||||
|
import com.api.youhong.ai.pcn.racetrack.dto.RaceTrackEvent;
|
||||||
|
import com.api.youhong.ai.pcn.racetrack.mapper.RacetrackMapper;
|
||||||
|
import com.api.youhong.ai.pcn.racetrack.vo.RaceTrackVo;
|
||||||
|
import ebu7common.youhong.ai.bean.Builder;
|
||||||
|
import weaver.hrm.User;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>业务处理</h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/2/14 12:13</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
public class RaceTrackService {
|
||||||
|
|
||||||
|
private final RacetrackMapper mapper = Util.getMapper(RacetrackMapper.class);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>查询一年中的事件列表</h2>
|
||||||
|
*
|
||||||
|
* @return 事件列表
|
||||||
|
* @author youhong.ai
|
||||||
|
*/
|
||||||
|
public Object getEventList(User user) {
|
||||||
|
/* ******************* 查询配置参数并且校验是否有值 ******************* */
|
||||||
|
String raceTrackEventListTable = Util.getCusConfigValue("RACE_TRACK_EVENT_LIST_TABLE");
|
||||||
|
Assert.notBlank(raceTrackEventListTable,
|
||||||
|
"race track event list table can not be null! check configuration [RACE_TRACK_EVENT_LIST_TABLE] in uf_cus_dev_config table!");
|
||||||
|
String raceTrackEventListDateField = Util.getCusConfigValue("RACE_TRACK_EVENT_LIST_DATE_FIELD");
|
||||||
|
Assert.notBlank(raceTrackEventListDateField,
|
||||||
|
"race track event list table date field can not be null! check configuration [RACE_TRACK_EVENT_LIST_DATE_FIELD] in uf_cus_dev_config table!");
|
||||||
|
String raceTrackEventListTitleField = Util.getCusConfigValue("RACE_TRACK_EVENT_LIST_TITLE_FIELD");
|
||||||
|
Assert.notBlank(raceTrackEventListTitleField,
|
||||||
|
"race track event list table title field can not be null! check configuration [RACE_TRACK_EVENT_LIST_TITLE_FIELD] in uf_cus_dev_config table!");
|
||||||
|
String raceTrackEventListSubtitleField = Util.getCusConfigValue("RACE_TRACK_EVENT_LIST_SUBTITLE_FIELD");
|
||||||
|
Assert.notBlank(raceTrackEventListSubtitleField,
|
||||||
|
"race track event list table subtitle field can not be null! check configuration [RACE_TRACK_EVENT_LIST_SUBTITLE_FIELD] in uf_cus_dev_config table!");
|
||||||
|
|
||||||
|
List<RaceTrackEvent> raceTrackEventList = mapper.selectEventList(raceTrackEventListTable, raceTrackEventListDateField,
|
||||||
|
raceTrackEventListTitleField, raceTrackEventListSubtitleField);
|
||||||
|
String workYear = mapper.selectLengthOfEntryTime(user.getUID());
|
||||||
|
double workYearD = Double.parseDouble(workYear);
|
||||||
|
double workMonth = workYearD * 12;
|
||||||
|
String lengthOfEntryTime = "";
|
||||||
|
lengthOfEntryTime += Math.floor(workMonth / 12);
|
||||||
|
lengthOfEntryTime += " Year And " + Math.floor(workMonth % 12);
|
||||||
|
lengthOfEntryTime += " Month";
|
||||||
|
return Builder.builder(RaceTrackVo::new)
|
||||||
|
.with(RaceTrackVo::setEventList, raceTrackEventList)
|
||||||
|
.with(RaceTrackVo::setLengthOfEntryTime, lengthOfEntryTime)
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,27 @@
|
||||||
|
package com.api.youhong.ai.pcn.racetrack.vo;
|
||||||
|
|
||||||
|
import com.api.youhong.ai.pcn.racetrack.dto.RaceTrackEvent;
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import lombok.ToString;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1></h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/2/14 15:08</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
@Setter
|
||||||
|
@Getter
|
||||||
|
@ToString
|
||||||
|
public class RaceTrackVo {
|
||||||
|
|
||||||
|
/** 事件列表 */
|
||||||
|
List<RaceTrackEvent> eventList;
|
||||||
|
|
||||||
|
/** 入职时长 */
|
||||||
|
private String lengthOfEntryTime;
|
||||||
|
}
|
|
@ -3,6 +3,7 @@ package com.api.youhong.ai.pcn.workflow.doworkflowtomodel.mapper;
|
||||||
import aiyh.utils.annotation.recordset.ParamMapper;
|
import aiyh.utils.annotation.recordset.ParamMapper;
|
||||||
import aiyh.utils.annotation.recordset.Select;
|
import aiyh.utils.annotation.recordset.Select;
|
||||||
import aiyh.utils.annotation.recordset.SqlMapper;
|
import aiyh.utils.annotation.recordset.SqlMapper;
|
||||||
|
import com.api.youhong.ai.pcn.workflow.doworkflowtomodel.vo.ApaDataBtnShowVo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h1></h1>
|
* <h1></h1>
|
||||||
|
@ -28,8 +29,9 @@ public interface ApaLevelByScoreMapper {
|
||||||
Integer selectLevelByScore(Double score);
|
Integer selectLevelByScore(Double score);
|
||||||
|
|
||||||
|
|
||||||
@Select("select id from $t{tableName} where $t{userField} = #{uId}")
|
@Select("select id, $t{statusField} status from $t{tableName} where $t{userField} = #{uId} order by id desc limit 1")
|
||||||
Integer selectLevelByUserId(@ParamMapper("uId") int uid,
|
ApaDataBtnShowVo selectLevelByUserId(@ParamMapper("uId") int uid,
|
||||||
@ParamMapper("tableName") String tableName,
|
@ParamMapper("tableName") String tableName,
|
||||||
|
@ParamMapper("statusField") String statusField,
|
||||||
@ParamMapper("userField") String userField);
|
@ParamMapper("userField") String userField);
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,6 +4,7 @@ import aiyh.utils.Util;
|
||||||
import aiyh.utils.excention.CustomerException;
|
import aiyh.utils.excention.CustomerException;
|
||||||
import cn.hutool.core.lang.Assert;
|
import cn.hutool.core.lang.Assert;
|
||||||
import com.api.youhong.ai.pcn.workflow.doworkflowtomodel.mapper.ApaLevelByScoreMapper;
|
import com.api.youhong.ai.pcn.workflow.doworkflowtomodel.mapper.ApaLevelByScoreMapper;
|
||||||
|
import com.api.youhong.ai.pcn.workflow.doworkflowtomodel.vo.ApaDataBtnShowVo;
|
||||||
import weaver.hrm.User;
|
import weaver.hrm.User;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -34,11 +35,13 @@ public class ApaLevelByScoreService {
|
||||||
return level;
|
return level;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Integer getApaLastDateId(User user) {
|
public ApaDataBtnShowVo getApaLastDateId(User user) {
|
||||||
String apaLastIdTableName = Util.getCusConfigValue("APA_LAST_ID_TABLE_NAME");
|
String apaLastIdTableName = Util.getCusConfigValue("APA_LAST_ID_TABLE_NAME");
|
||||||
String apaLastIdUserField = Util.getCusConfigValue("APA_LAST_ID_USER_FIELD");
|
String apaLastIdUserField = Util.getCusConfigValue("APA_LAST_ID_USER_FIELD");
|
||||||
|
String apaLastIdStatusField = Util.getCusConfigValue("APA_LAST_ID_STATUS_FIELD");
|
||||||
Assert.notBlank(apaLastIdTableName, "can not get config [APA_LAST_ID_TABLE_NAME] from uf_cus_dev_config!");
|
Assert.notBlank(apaLastIdTableName, "can not get config [APA_LAST_ID_TABLE_NAME] from uf_cus_dev_config!");
|
||||||
Assert.notBlank(apaLastIdUserField, "can not get config [APA_LAST_ID_USER_FIELD] from uf_cus_dev_config!");
|
Assert.notBlank(apaLastIdUserField, "can not get config [APA_LAST_ID_USER_FIELD] from uf_cus_dev_config!");
|
||||||
return mapper.selectLevelByUserId(user.getUID(), apaLastIdTableName, apaLastIdUserField);
|
Assert.notBlank(apaLastIdStatusField, "can not get config [APA_LAST_ID_STATUS_FIELD] from uf_cus_dev_config!");
|
||||||
|
return mapper.selectLevelByUserId(user.getUID(), apaLastIdTableName, apaLastIdStatusField, apaLastIdUserField);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,22 @@
|
||||||
|
package com.api.youhong.ai.pcn.workflow.doworkflowtomodel.vo;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import lombok.ToString;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>apa台账创建流程按钮显示隐藏控制Vo实体</h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/2/13 16:39</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
@ToString
|
||||||
|
public class ApaDataBtnShowVo {
|
||||||
|
|
||||||
|
private Integer id;
|
||||||
|
|
||||||
|
private Integer status;
|
||||||
|
}
|
|
@ -0,0 +1,81 @@
|
||||||
|
package weaver.youhong.ai.intellectualproperty.action;
|
||||||
|
|
||||||
|
import aiyh.utils.Util;
|
||||||
|
import aiyh.utils.action.SafeCusBaseAction;
|
||||||
|
import aiyh.utils.annotation.ActionDefaultTestValue;
|
||||||
|
import aiyh.utils.annotation.ActionOptionalParam;
|
||||||
|
import aiyh.utils.annotation.PrintParamMark;
|
||||||
|
import aiyh.utils.annotation.RequiredMark;
|
||||||
|
import aiyh.utils.excention.CustomerException;
|
||||||
|
import aiyh.utils.httpUtil.ResponeVo;
|
||||||
|
import aiyh.utils.httpUtil.util.HttpUtils;
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import lombok.ToString;
|
||||||
|
import weaver.hrm.User;
|
||||||
|
import weaver.soa.workflow.request.RequestInfo;
|
||||||
|
import weaver.xiao.commons.config.entity.RequestMappingConfig;
|
||||||
|
import weaver.xiao.commons.config.service.DealWithMapping;
|
||||||
|
|
||||||
|
import javax.ws.rs.core.MediaType;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>知识产权局ca电子签</h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/2/16 15:22</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
@Setter
|
||||||
|
@Getter
|
||||||
|
@ToString
|
||||||
|
public class CaElectronicSignatureAction extends SafeCusBaseAction {
|
||||||
|
@PrintParamMark
|
||||||
|
@ActionOptionalParam(value = "false", desc = "是否自动提交流程")
|
||||||
|
@ActionDefaultTestValue("false")
|
||||||
|
private String submitAction = "false";
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@ActionOptionalParam(value = "true", desc = "是否失败后阻断流程")
|
||||||
|
@ActionDefaultTestValue("true")
|
||||||
|
private String block = "true";
|
||||||
|
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("请求接口参数配置表中的唯一标识字段的值")
|
||||||
|
private String onlyMark;
|
||||||
|
|
||||||
|
private final DealWithMapping dealWithMapping = new DealWithMapping();
|
||||||
|
|
||||||
|
private final HttpUtils httpUtils = new HttpUtils();
|
||||||
|
|
||||||
|
{
|
||||||
|
httpUtils.getGlobalCache().header.put("Content-Type", MediaType.APPLICATION_JSON);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void doSubmit(String requestId, String billTable, int workflowId, User user, RequestInfo requestInfo) {
|
||||||
|
try {
|
||||||
|
dealWithMapping.setMainTable(billTable);
|
||||||
|
RequestMappingConfig requestMappingConfig = dealWithMapping.treeDealWithUniqueCode(onlyMark);
|
||||||
|
String requestUrl = requestMappingConfig.getRequestUrl();
|
||||||
|
Map<String, Object> requestParam = dealWithMapping.getRequestParam(super.getObjMainTableValue(requestInfo), requestMappingConfig);
|
||||||
|
ResponeVo responeVo = httpUtils.apiPost(requestUrl, requestParam);
|
||||||
|
Map<String, Object> responseMap = responeVo.getResponseMap();
|
||||||
|
} catch (Exception e) {
|
||||||
|
if (Boolean.parseBoolean(block)) {
|
||||||
|
throw new CustomerException(e.getMessage(), e);
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
if (Boolean.parseBoolean(submitAction)) {
|
||||||
|
this.submitWorkflow(requestId, user.getUID());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void submitWorkflow(String requestId, Integer userId) {
|
||||||
|
Util.submitWorkflowThread(Integer.parseInt(requestId), userId, "电子签自动提交流程");
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,13 +2,10 @@ package weaver.youhong.ai.pcn.actioin.sendemail;
|
||||||
|
|
||||||
import aiyh.utils.Util;
|
import aiyh.utils.Util;
|
||||||
import aiyh.utils.action.SafeCusBaseAction;
|
import aiyh.utils.action.SafeCusBaseAction;
|
||||||
import aiyh.utils.annotation.ActionDesc;
|
import aiyh.utils.annotation.*;
|
||||||
import aiyh.utils.annotation.ActionOptionalParam;
|
|
||||||
import aiyh.utils.annotation.PrintParamMark;
|
|
||||||
import aiyh.utils.annotation.RequiredMark;
|
|
||||||
import aiyh.utils.entity.DocImageInfo;
|
import aiyh.utils.entity.DocImageInfo;
|
||||||
import aiyh.utils.excention.CustomerException;
|
import aiyh.utils.excention.CustomerException;
|
||||||
import cn.hutool.core.lang.Assert;
|
import aiyh.utils.tool.Assert;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
import lombok.ToString;
|
import lombok.ToString;
|
||||||
|
@ -47,19 +44,23 @@ public class SendEmailToExternalPersonnelAction extends SafeCusBaseAction {
|
||||||
|
|
||||||
@PrintParamMark
|
@PrintParamMark
|
||||||
@RequiredMark("用户邮箱对应表单字段")
|
@RequiredMark("用户邮箱对应表单字段")
|
||||||
|
@ActionDefaultTestValue("yx")
|
||||||
private String emailField;
|
private String emailField;
|
||||||
|
|
||||||
@PrintParamMark
|
@PrintParamMark
|
||||||
@ActionOptionalParam(value = "", desc = "发送邮箱内容自定义表单表单字段,不填则默认使用开发参数配置表(uf_cus_dev_config)中唯一标识为" +
|
@ActionOptionalParam(value = "", desc = "发送邮箱内容自定义表单表单字段,不填则默认使用开发参数配置表(uf_cus_dev_config)中唯一标识为" +
|
||||||
"`SendEmailToExternalPersonnelEmail`的值的邮件内容")
|
"`SendEmailToExternalPersonnelEmail`的值的邮件内容")
|
||||||
|
@ActionDefaultTestValue("nr")
|
||||||
private String customerContentField;
|
private String customerContentField;
|
||||||
|
|
||||||
@PrintParamMark
|
@PrintParamMark
|
||||||
@ActionOptionalParam(value = "", desc = "邮箱携带附件字段,不填则没有附件")
|
@ActionOptionalParam(value = "", desc = "邮箱携带附件字段,不填则没有附件")
|
||||||
|
@ActionDefaultTestValue("fj")
|
||||||
private String emailFileField;
|
private String emailFileField;
|
||||||
|
|
||||||
@PrintParamMark
|
@PrintParamMark
|
||||||
@ActionOptionalParam(value = "", desc = "邮件标题字段,不填写则默认使用`defaultEmailSubject`的参数值")
|
@ActionOptionalParam(value = "", desc = "邮件标题字段,不填写则默认使用`defaultEmailSubject`的参数值")
|
||||||
|
@ActionDefaultTestValue("bt")
|
||||||
private String emailSubjectField;
|
private String emailSubjectField;
|
||||||
|
|
||||||
@PrintParamMark
|
@PrintParamMark
|
||||||
|
@ -113,7 +114,7 @@ public class SendEmailToExternalPersonnelAction extends SafeCusBaseAction {
|
||||||
|
|
||||||
public void submitWorkflow(String requestId, Integer userId) {
|
public void submitWorkflow(String requestId, Integer userId) {
|
||||||
|
|
||||||
Util.submitWorkflowThread(Integer.parseInt(requestId), userId, "批量签署自动提交流程!");
|
Util.submitWorkflowThread(Integer.parseInt(requestId), userId, "邮件发送附件提交流程!");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
2
常用信息.md
2
常用信息.md
|
@ -77,7 +77,7 @@ getQueryString = (name) => {
|
||||||
**5.通过js获取react组件,操作组件内部数据**
|
**5.通过js获取react组件,操作组件内部数据**
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
function FindReact(dom, traverseUp = 0) {
|
function findReact(dom, traverseUp = 0) {
|
||||||
const key = Object.keys(dom).find(key => {
|
const key = Object.keys(dom).find(key => {
|
||||||
return key.startsWith("__reactFiber$") // react 17+
|
return key.startsWith("__reactFiber$") // react 17+
|
||||||
|| key.startsWith("__reactInternalInstance$"); // react <17
|
|| key.startsWith("__reactInternalInstance$"); // react <17
|
||||||
|
|
Loading…
Reference in New Issue