Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
C
clx-performance
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
姜武杰
clx-performance
Commits
13a2b3cd
提交
13a2b3cd
authored
10月 17, 2024
作者:
姜武杰
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
使用okhttp进行重写,okhttp自己控制池化
上级
0639e7f7
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
74 行增加
和
145 行删除
+74
-145
pom.xml
clx-performance-web/pom.xml
+4
-0
HttpsUtils.java
...ce-web/src/main/java/com/openapi/sdk/util/HttpsUtils.java
+70
-145
没有找到文件。
clx-performance-web/pom.xml
浏览文件 @
13a2b3cd
...
...
@@ -357,6 +357,10 @@
<groupId>
com.msl.message
</groupId>
<artifactId>
message-sdk
</artifactId>
</dependency>
<dependency>
<groupId>
com.squareup.okhttp3
</groupId>
<artifactId>
okhttp
</artifactId>
</dependency>
</dependencies>
...
...
clx-performance-web/src/main/java/com/openapi/sdk/util/HttpsUtils.java
浏览文件 @
13a2b3cd
package
com
.
openapi
.
sdk
.
util
;
import
javax.net.ssl.*
;
import
java.io.DataOutputStream
;
import
okhttp3.*
;
import
javax.net.ssl.HostnameVerifier
;
import
javax.net.ssl.SSLContext
;
import
javax.net.ssl.TrustManager
;
import
javax.net.ssl.X509TrustManager
;
import
java.io.IOException
;
import
java.io.InputStreamReader
;
import
java.net.HttpURLConnection
;
import
java.net.URL
;
import
java.security.KeyManagementException
;
import
java.security.NoSuchAlgorithmException
;
import
java.security.SecureRandom
;
import
java.security.cert.CertificateException
;
import
java.security.cert.X509Certificate
;
import
java.util.concurrent.TimeUnit
;
public
class
HttpsUtils
{
public
HttpsUtils
()
{
}
public
static
String
doPost
(
String
url
,
int
connentTimeout
,
int
readTimeout
)
throws
Exception
{
HttpURLConnection
conn
=
null
;
InputStreamReader
isReader
=
null
;
StringBuffer
result
=
new
StringBuffer
();
private
static
final
OkHttpClient
client
;
static
{
try
{
trustAllHttpsCertificates
();
HostnameVerifier
hv
=
new
HostnameVerifier
()
{
public
boolean
verify
(
String
urlHostName
,
SSLSession
session
)
{
System
.
out
.
println
(
"Warning: URL Host: "
+
urlHostName
+
" vs. "
+
session
.
getPeerHost
());
return
true
;
}
// 创建一个信任所有证书的 TrustManager
TrustManager
[]
trustAllCerts
=
new
TrustManager
[]{
new
X509TrustManager
()
{
@Override
public
void
checkClientTrusted
(
X509Certificate
[]
chain
,
String
authType
)
{
}
@Override
public
void
checkServerTrusted
(
X509Certificate
[]
chain
,
String
authType
)
{
}
@Override
public
X509Certificate
[]
getAcceptedIssuers
()
{
return
new
X509Certificate
[
0
];
}
}
};
HttpsURLConnection
.
setDefaultHostnameVerifier
(
hv
);
conn
=
(
HttpURLConnection
)(
new
URL
(
url
)).
openConnection
();
conn
.
setDoInput
(
true
);
conn
.
setDoOutput
(
true
);
conn
.
setUseCaches
(
false
);
conn
.
setRequestMethod
(
"POST"
);
conn
.
setConnectTimeout
(
connentTimeout
);
conn
.
setReadTimeout
(
readTimeout
);
isReader
=
new
InputStreamReader
(
conn
.
getInputStream
(),
"UTF-8"
);
char
[]
bfchar
=
new
char
[
2048
];
int
length
=
0
;
while
((
length
=
isReader
.
read
(
bfchar
))
!=
-
1
)
{
String
temp
=
new
String
(
bfchar
,
0
,
length
);
result
.
append
(
temp
);
}
}
catch
(
Exception
var17
)
{
System
.
err
.
println
(
"发送 POST 请求出现异常!"
+
var17
.
getMessage
());
throw
var17
;
}
finally
{
try
{
if
(
isReader
!=
null
)
{
isReader
.
close
();
}
}
catch
(
IOException
var16
)
{
System
.
err
.
println
(
"关闭数据流出错了!\n"
+
var16
.
getMessage
()
+
"\n"
);
throw
var16
;
}
}
return
result
.
toString
();
}
// 安装所有信任的 SSL 套接字工厂
SSLContext
sslContext
=
SSLContext
.
getInstance
(
"SSL"
);
sslContext
.
init
(
null
,
trustAllCerts
,
new
SecureRandom
());
public
static
String
doPost
(
String
url
,
String
param
,
int
readTimeout
,
int
connectTimeout
)
throws
Exception
{
InputStreamReader
isReader
=
null
;
HttpURLConnection
conn
=
null
;
DataOutputStream
dos
=
null
;
StringBuffer
result
=
new
StringBuffer
();
try
{
trustAllHttpsCertificates
();
HostnameVerifier
hv
=
new
HostnameVerifier
()
{
public
boolean
verify
(
String
urlHostName
,
SSLSession
session
)
{
System
.
out
.
println
(
"Warning: URL Host: "
+
urlHostName
+
" vs. "
+
session
.
getPeerHost
());
return
true
;
}
// 创建一个允许所有主机名的 HostnameVerifier
HostnameVerifier
hostnameVerifier
=
(
hostname
,
session
)
->
{
System
.
out
.
println
(
"Warning: URL Host: "
+
hostname
+
" vs. "
+
session
.
getPeerHost
());
return
true
;
};
HttpsURLConnection
.
setDefaultHostnameVerifier
(
hv
);
conn
=
(
HttpURLConnection
)(
new
URL
(
url
)).
openConnection
();
conn
.
setDoInput
(
true
);
conn
.
setDoOutput
(
true
);
conn
.
setUseCaches
(
false
);
conn
.
setRequestProperty
(
"Content-Length"
,
String
.
valueOf
(
param
.
getBytes
(
"UTF-8"
).
length
));
conn
.
setRequestMethod
(
"POST"
);
conn
.
setConnectTimeout
(
connectTimeout
);
conn
.
setRequestProperty
(
"charset"
,
"UTF-8"
);
conn
.
setReadTimeout
(
readTimeout
);
conn
.
connect
();
dos
=
new
DataOutputStream
(
conn
.
getOutputStream
());
int
length
=
0
;
int
totalLength
=
param
.
length
();
while
(
length
<
totalLength
)
{
int
endLength
=
length
+
1024
;
if
(
endLength
>
totalLength
)
{
endLength
=
totalLength
;
}
dos
.
write
(
param
.
substring
(
length
,
endLength
).
getBytes
(
"UTF-8"
));
length
=
endLength
;
dos
.
flush
();
}
dos
.
close
();
isReader
=
new
InputStreamReader
(
conn
.
getInputStream
(),
"UTF-8"
);
char
[]
bfchar
=
new
char
[
2048
];
int
rlength
=
0
;
while
((
rlength
=
isReader
.
read
(
bfchar
))
!=
-
1
)
{
String
temp
=
new
String
(
bfchar
,
0
,
rlength
);
result
.
append
(
temp
);
}
return
result
.
toString
();
}
catch
(
Exception
var21
)
{
System
.
err
.
println
(
"发送 POST 请求出现异常!"
+
var21
.
getMessage
()
+
"e:"
+
var21
);
throw
var21
;
}
finally
{
try
{
if
(
isReader
!=
null
)
{
isReader
.
close
();
}
}
catch
(
IOException
var20
)
{
System
.
err
.
println
(
"关闭数据流出错了!\n"
+
var20
.
getMessage
()
+
"\n"
);
throw
var20
;
}
try
{
if
(
conn
!=
null
)
{
conn
.
disconnect
();
}
}
catch
(
Exception
var19
)
{
System
.
err
.
println
(
"关闭连接出错了!\n"
+
var19
.
getMessage
()
+
"\n"
);
throw
var19
;
}
// 创建 OkHttpClient 并启用连接池
client
=
new
OkHttpClient
.
Builder
()
.
sslSocketFactory
(
sslContext
.
getSocketFactory
(),
(
X509TrustManager
)
trustAllCerts
[
0
])
.
hostnameVerifier
(
hostnameVerifier
)
.
connectTimeout
(
10
,
TimeUnit
.
SECONDS
)
.
readTimeout
(
10
,
TimeUnit
.
SECONDS
)
.
writeTimeout
(
10
,
TimeUnit
.
SECONDS
)
.
retryOnConnectionFailure
(
true
)
.
build
();
}
catch
(
NoSuchAlgorithmException
|
KeyManagementException
e
)
{
throw
new
RuntimeException
(
"Failed to create OkHttpClient"
,
e
);
}
}
private
static
void
trustAllHttpsCertificates
()
throws
Exception
{
TrustManager
[]
trustAllCerts
=
new
TrustManager
[
1
];
TrustManager
tm
=
new
miTM
();
trustAllCerts
[
0
]
=
tm
;
SSLContext
sc
=
SSLContext
.
getInstance
(
"SSL"
);
sc
.
init
((
KeyManager
[])
null
,
trustAllCerts
,
(
SecureRandom
)
null
);
HttpsURLConnection
.
setDefaultSSLSocketFactory
(
sc
.
getSocketFactory
());
}
static
class
miTM
implements
TrustManager
,
X509TrustManager
{
miTM
()
{
}
public
static
String
doPost
(
String
url
,
int
connectTimeout
,
int
readTimeout
)
throws
IOException
{
Request
request
=
new
Request
.
Builder
()
.
url
(
url
)
.
post
(
RequestBody
.
create
(
""
,
MediaType
.
get
(
"application/x-www-form-urlencoded"
)))
.
build
();
public
X509Certificate
[]
getAcceptedIssuers
()
{
return
null
;
}
public
boolean
isServerTrusted
(
X509Certificate
[]
certs
)
{
return
true
;
}
public
boolean
isClientTrusted
(
X509Certificate
[]
certs
)
{
return
true
;
try
(
Response
response
=
client
.
newCall
(
request
).
execute
())
{
if
(!
response
.
isSuccessful
())
{
throw
new
IOException
(
"Unexpected code "
+
response
);
}
return
response
.
body
().
string
();
}
}
public
void
checkServerTrusted
(
X509Certificate
[]
certs
,
String
authType
)
throws
CertificateException
{
}
public
static
String
doPost
(
String
url
,
String
param
,
int
readTimeout
,
int
connectTimeout
)
throws
IOException
{
RequestBody
body
=
RequestBody
.
create
(
param
,
MediaType
.
get
(
"application/x-www-form-urlencoded"
));
Request
request
=
new
Request
.
Builder
()
.
url
(
url
)
.
post
(
body
)
.
build
();
public
void
checkClientTrusted
(
X509Certificate
[]
certs
,
String
authType
)
throws
CertificateException
{
try
(
Response
response
=
client
.
newCall
(
request
).
execute
())
{
if
(!
response
.
isSuccessful
())
{
throw
new
IOException
(
"Unexpected code "
+
response
);
}
return
response
.
body
().
string
();
}
}
}
}
\ No newline at end of file
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论