Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
P
PRMS
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
zhengfunan
PRMS
Commits
39040bc7
Commit
39040bc7
authored
Dec 03, 2020
by
gaozhentao
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
修改http请求方式,修改getpost 处理方式
parent
1562caf6
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
212 additions
and
43 deletions
+212
-43
BasicTask.java
...in/java/com/yingxin/prms/service/asyncTask/BasicTask.java
+1
-0
HttpTask.java
...ain/java/com/yingxin/prms/service/asyncTask/HttpTask.java
+52
-43
SendHttpUtil.java
src/main/java/com/yingxin/prms/utils/SendHttpUtil.java
+147
-0
TimeUtil.java
src/main/java/com/yingxin/prms/utils/TimeUtil.java
+12
-0
No files found.
src/main/java/com/yingxin/prms/service/asyncTask/BasicTask.java
View file @
39040bc7
...
...
@@ -20,6 +20,7 @@ public class BasicTask {
* @param isAlive
*/
Boolean
insertToKairos
(
HttpClient
client
,
String
ip
,
int
port
,
long
dur
,
boolean
isAlive
)
{
boolean
ss
=
false
;
MetricBuilder
builderHeartbeat
=
MetricBuilder
.
getInstance
();
builderHeartbeat
.
addMetric
(
"heartbeat"
)
...
...
src/main/java/com/yingxin/prms/service/asyncTask/HttpTask.java
View file @
39040bc7
package
com
.
yingxin
.
prms
.
service
.
asyncTask
;
import
com.yingxin.prms.domain.Server_Host_Info
;
import
com.yingxin.prms.utils.SendHttpUtil
;
import
net.sf.json.JSONObject
;
import
org.apache.http.HttpEntity
;
import
org.apache.http.util.EntityUtils
;
import
org.kairosdb.client.HttpClient
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.http.HttpEntity
;
import
org.springframework.http.HttpHeaders
;
import
org.springframework.http.MediaType
;
import
org.springframework.http.ResponseEntity
;
import
org.springframework.http.client.SimpleClientHttpRequestFactory
;
import
org.springframework.scheduling.annotation.Async
;
import
org.springframework.stereotype.Component
;
import
org.springframework.web.client.RestClientException
;
import
org.springframework.web.client.RestTemplate
;
import
org.apache.http.client.methods.CloseableHttpResponse
;
import
java.io.IOException
;
import
java.net.SocketException
;
import
java.util.HashMap
;
import
java.util.Map
;
import
java.util.concurrent.ConcurrentHashMap
;
@Component
...
...
@@ -23,7 +27,6 @@ public class HttpTask extends BasicTask{
private
final
HttpClient
httpClient
;
private
RestTemplate
restTemplate
;
private
static
Logger
logger
=
LoggerFactory
.
getLogger
(
HttpTask
.
class
);
...
...
@@ -32,7 +35,6 @@ public class HttpTask extends BasicTask{
SimpleClientHttpRequestFactory
httpRequestFactory
=
new
SimpleClientHttpRequestFactory
();
httpRequestFactory
.
setConnectTimeout
(
5000
);
httpRequestFactory
.
setReadTimeout
(
5000
);
restTemplate
=
new
RestTemplate
(
httpRequestFactory
);
this
.
httpClient
=
httpClient
;
}
...
...
@@ -43,21 +45,15 @@ public class HttpTask extends BasicTask{
*/
@Async
(
"asyncTaskPool"
)
public
void
doTask
(
Server_Host_Info
hostInfo
,
ConcurrentHashMap
<
String
,
String
>
alarmHost
)
{
HttpEntity
<
String
>
requestEntity
;
ResponseEntity
<
String
>
responseEntity
=
null
;
Map
<
String
,
String
>
map
=
new
HashMap
();
long
dur
=
0
;
long
start
=
System
.
currentTimeMillis
();
try
{
if
(
hostInfo
.
getService_method
().
equals
(
"post"
)
&&
!
hostInfo
.
getCluster_name
().
equals
(
"网证开通接口"
))
{
HttpHeaders
headers
=
new
HttpHeaders
();
headers
.
setContentType
(
MediaType
.
APPLICATION_JSON_UTF8
);
requestEntity
=
new
HttpEntity
<>(
hostInfo
.
getRequest_body
(),
headers
);
responseEntity
=
restTemplate
.
postForEntity
(
hostInfo
.
getService_path
(),
requestEntity
,
String
.
class
);
map
=
SendHttpUtil
.
doPost
(
hostInfo
.
getService_path
(),
hostInfo
.
getRequest_body
());
}
if
(
hostInfo
.
getService_method
().
equals
(
"get"
))
{
responseEntity
=
restTemplate
.
getForEntity
(
hostInfo
.
getService_path
(),
String
.
class
);
map
=
SendHttpUtil
.
doGet
(
hostInfo
.
getService_path
()
);
}
dur
=
System
.
currentTimeMillis
()
-
start
;
}
catch
(
RestClientException
e
)
{
...
...
@@ -70,57 +66,57 @@ public class HttpTask extends BasicTask{
boolean
flag
=
false
;
switch
(
hostInfo
.
getCluster_name
()){
case
"VPN方式接入服务"
:
flag
=
checkStatusCode
(
responseEntity
);
flag
=
checkStatusCode
(
map
);
break
;
case
"token方式接入服务"
:
flag
=
checkStatusCode
(
responseEntity
);
flag
=
checkStatusCode
(
map
);
break
;
case
"日志采集服务"
:
flag
=
checkStatusCode
(
responseEntity
);
flag
=
checkStatusCode
(
map
);
break
;
case
"核心调度服务"
:
flag
=
checkStatusCode
(
responseEntity
);
flag
=
checkStatusCode
(
map
);
break
;
case
"token核验服务"
:
flag
=
checkStatusCode
(
responseEntity
);
flag
=
checkStatusCode
(
map
);
break
;
case
"平台业务权限配置管理服务"
:
flag
=
checkStatusCode
(
responseEntity
);
flag
=
checkStatusCode
(
map
);
break
;
case
"权限核验服务facl"
:
flag
=
che
nkStatus
(
responseEntity
);
flag
=
che
ckStatus
(
map
);
break
;
case
"账户应用管理服务"
:
flag
=
checkStatusCode
(
responseEntity
);
flag
=
checkStatusCode
(
map
);
break
;
case
"1比1比对(图片+图片)"
:
flag
=
check
Code
(
responseEntity
);
flag
=
check
StatusCode
(
map
);
break
;
case
"1比1比对(图片+特征)"
:
flag
=
check
Code
(
responseEntity
);
flag
=
check
StatusCode
(
map
);
break
;
case
"1比1比对(特征+特征)"
:
flag
=
check
Code
(
responseEntity
);
flag
=
check
StatusCode
(
map
);
break
;
case
"1比N比对(特征)"
:
flag
=
checkStatusCode
(
responseEntity
);
flag
=
checkStatusCode
(
map
);
break
;
case
"1比N比对(图片)"
:
flag
=
check
Code
(
responseEntity
);
flag
=
check
StatusCode
(
map
);
break
;
case
"图片生成特征值"
:
flag
=
check
Code
(
responseEntity
);
flag
=
check
StatusCode
(
map
);
break
;
case
"依图"
:
flag
=
checkCode
(
responseEntity
);
flag
=
checkCode
(
map
);
break
;
case
"云从"
:
flag
=
checkCode
(
responseEntity
);
flag
=
checkCode
(
map
);
break
;
default
:
flag
=
checkStatusCode
(
responseEntity
);
flag
=
checkStatusCode
(
map
);
}
if
(
responseEntity
!=
null
)
{
if
(
map
.
get
(
"body"
)
!=
null
&&
!
map
.
get
(
"body"
).
isEmpty
()
)
{
insertToKairos
(
httpClient
,
hostInfo
.
getHost_ip
(),
hostInfo
.
getHost_port
(),
dur
,
flag
);
logger
.
info
(
"httpTask to {}|{}"
,
hostInfo
.
getHost_ip
(),
flag
);
if
(
flag
)
{
...
...
@@ -132,24 +128,34 @@ public class HttpTask extends BasicTask{
}
/* 针对不同服务集群 返回结果 作不同校验 */
private
boolean
checkStatusCode
(
ResponseEntity
<
String
>
responseEntity
)
{
int
statusCodeValue
=
responseEntity
.
getStatusCodeValue
();
if
(
statusCodeValue
==
200
){
private
boolean
checkStatusCode
(
Map
<
String
,
String
>
map
)
{
if
(
map
.
get
(
"status"
).
equals
(
"200"
)){
return
true
;
}
return
false
;
}
private
boolean
checkCode
(
ResponseEntity
<
String
>
responseEntity
)
{
JSONObject
jsonObject
=
JSONObject
.
fromObject
(
responseEntity
.
getBody
());
private
boolean
checkCode
(
Map
<
String
,
String
>
map
)
{
JSONObject
jsonObject
=
JSONObject
.
fromObject
(
map
.
get
(
"body"
));
if
(
map
.
containsKey
(
"body"
)){
String
code
=
jsonObject
.
getString
(
"code"
);
if
(
code
.
equals
(
"0"
)){
return
true
;
}
}
return
false
;
}
private
boolean
checkErrorCode
(
ResponseEntity
<
String
>
responseEntity
)
{
JSONObject
jsonObject
=
JSONObject
.
fromObject
(
responseEntity
.
getBody
());
private
boolean
checkErrorCode
(
CloseableHttpResponse
response
)
{
JSONObject
jsonObject
=
null
;
try
{
if
(
response
==
null
){
return
false
;
}
jsonObject
=
JSONObject
.
fromObject
(
EntityUtils
.
toString
(
response
.
getEntity
(),
"utf-8"
));
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
return
false
;
}
String
code
=
jsonObject
.
getString
(
"error_code"
);
if
(
code
.
equals
(
"0"
)){
return
true
;
...
...
@@ -157,12 +163,15 @@ public class HttpTask extends BasicTask{
return
false
;
}
private
boolean
chenkStatus
(
ResponseEntity
<
String
>
responseEntity
)
{
JSONObject
jsonObject
=
JSONObject
.
fromObject
(
responseEntity
.
getBody
());
private
boolean
checkStatus
(
Map
<
String
,
String
>
map
)
{
JSONObject
jsonObject
=
null
;
if
(
map
.
containsKey
(
"body"
)){
jsonObject
=
JSONObject
.
fromObject
(
map
.
get
(
"body"
));
String
status
=
jsonObject
.
getString
(
"status"
);
if
(
status
.
equals
(
"true"
)){
return
true
;
}
}
return
false
;
}
...
...
src/main/java/com/yingxin/prms/utils/SendHttpUtil.java
0 → 100644
View file @
39040bc7
package
com
.
yingxin
.
prms
.
utils
;
import
org.apache.http.HttpEntity
;
import
org.apache.http.HttpMessage
;
import
org.apache.http.HttpResponse
;
import
org.apache.http.ParseException
;
import
org.apache.http.client.ClientProtocolException
;
import
org.apache.http.client.config.RequestConfig
;
import
org.apache.http.client.methods.CloseableHttpResponse
;
import
org.apache.http.client.methods.HttpGet
;
import
org.apache.http.client.methods.HttpPost
;
import
org.apache.http.entity.StringEntity
;
import
org.apache.http.impl.client.CloseableHttpClient
;
import
org.apache.http.impl.client.HttpClientBuilder
;
import
org.apache.http.impl.client.HttpClients
;
import
org.apache.http.util.EntityUtils
;
import
java.io.IOException
;
import
java.io.UnsupportedEncodingException
;
import
java.net.SocketException
;
import
java.net.URLEncoder
;
import
java.util.HashMap
;
import
java.util.Map
;
/**
* Description:
* Datetime: 2020/12/1 16:15
* Author: gaozhentao
*/
public
class
SendHttpUtil
{
public
static
Map
<
String
,
String
>
doGet
(
String
uri
)
{
Map
<
String
,
String
>
map
=
new
HashMap
();
// 获得Http客户端(可以理解为:你得先有一个浏览器;注意:实际上HttpClient与浏览器是不一样的)
CloseableHttpClient
httpClient
=
HttpClientBuilder
.
create
().
build
();
// 参数
StringBuffer
params
=
new
StringBuffer
();
// 创建Get请求
HttpGet
httpGet
=
new
HttpGet
(
uri
);
// 响应模型
CloseableHttpResponse
response
=
null
;
try
{
// 配置信息
RequestConfig
requestConfig
=
RequestConfig
.
custom
()
// 设置连接超时时间(单位毫秒)
.
setConnectTimeout
(
5000
)
// 设置请求超时时间(单位毫秒)
.
setConnectionRequestTimeout
(
5000
)
// socket读写超时时间(单位毫秒)
.
setSocketTimeout
(
5000
)
// 设置是否允许重定向(默认为true)
.
setRedirectsEnabled
(
true
).
build
();
// 将上面的配置信息 运用到这个Get请求里
httpGet
.
setConfig
(
requestConfig
);
// 由客户端执行(发送)Get请求
response
=
httpClient
.
execute
(
httpGet
);
// 从响应模型中获取响应实体
HttpEntity
responseEntity
=
response
.
getEntity
();
map
.
put
(
"status"
,
String
.
valueOf
(
response
.
getStatusLine
().
getStatusCode
()));
if
(
responseEntity
!=
null
)
{
map
.
put
(
"body"
,
EntityUtils
.
toString
(
responseEntity
));
}
}
catch
(
ClientProtocolException
e
)
{
e
.
printStackTrace
();
}
catch
(
ParseException
e
)
{
e
.
printStackTrace
();
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
finally
{
try
{
// 释放资源
if
(
httpClient
!=
null
)
{
httpClient
.
close
();
}
if
(
response
!=
null
)
{
response
.
close
();
}
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
return
map
;
}
}
public
static
Map
<
String
,
String
>
doPost
(
String
uri
,
String
body
)
{
Map
<
String
,
String
>
map
=
new
HashMap
();
// 获得Http客户端(可以理解为:你得先有一个浏览器;注意:实际上HttpClient与浏览器是不一样的)
CloseableHttpClient
httpClient
=
HttpClientBuilder
.
create
().
build
();
// 创建Post请求
HttpPost
httpPost
=
new
HttpPost
(
uri
);
StringEntity
entity
=
new
StringEntity
(
body
,
"UTF-8"
);
// post请求是将参数放在请求体里面传过去的;这里将entity放入post请求体中
httpPost
.
setEntity
(
entity
);
httpPost
.
setHeader
(
"Content-Type"
,
"application/json;charset=utf8"
);
// 响应模型
CloseableHttpResponse
response
=
null
;
HttpEntity
responseEntity
=
null
;
try
{
// 由客户端执行(发送)Post请求
response
=
httpClient
.
execute
(
httpPost
);
responseEntity
=
response
.
getEntity
();
map
.
put
(
"status"
,
String
.
valueOf
(
response
.
getStatusLine
().
getStatusCode
()));
if
(
responseEntity
==
null
){
}
else
{
map
.
put
(
"body"
,
EntityUtils
.
toString
(
responseEntity
,
"utf-8"
));
}
// 从响应模型中获取响应实体
}
catch
(
ClientProtocolException
e
)
{
e
.
printStackTrace
();
}
catch
(
ParseException
e
)
{
e
.
printStackTrace
();
}
catch
(
SocketException
e
){
e
.
printStackTrace
();
// System.out.println("conn:"+uri);
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
finally
{
try
{
// 释放资源
if
(
httpClient
!=
null
)
{
httpClient
.
close
();
}
if
(
response
!=
null
)
{
response
.
close
();
}
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
return
map
;
}
}
}
src/main/java/com/yingxin/prms/utils/TimeUtil.java
View file @
39040bc7
package
com
.
yingxin
.
prms
.
utils
;
import
org.apache.http.HttpEntity
;
import
org.apache.http.client.ClientProtocolException
;
import
org.apache.http.client.methods.CloseableHttpResponse
;
import
org.apache.http.client.methods.HttpPost
;
import
org.apache.http.entity.StringEntity
;
import
org.apache.http.impl.client.CloseableHttpClient
;
import
org.apache.http.impl.client.HttpClientBuilder
;
import
org.apache.http.util.EntityUtils
;
import
org.springframework.http.ResponseEntity
;
import
java.io.IOException
;
import
java.text.DateFormat
;
import
java.text.ParseException
;
import
java.text.SimpleDateFormat
;
...
...
@@ -41,4 +52,5 @@ public class TimeUtil {
public
static
String
getMD5Result
(
String
password
){
return
password
.
substring
(
12
,
password
.
length
()-
24
);
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment