remote Request
import java.io.IOException;
import java.io.InputStream;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import java.security.GeneralSecurityException;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import java.util.ArrayList;
import java.util.List; import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLException;
import javax.net.ssl.SSLSession;
import javax.net.ssl.SSLSocket; import org.apache.commons.beanutils.BeanUtils;
import org.apache.commons.collections.CollectionUtils;
import org.apache.commons.lang3.StringUtils;
import org.apache.commons.lang3.math.NumberUtils;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.HttpStatus;
import org.apache.http.NameValuePair;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.conn.ssl.SSLConnectionSocketFactory;
import org.apache.http.conn.ssl.SSLContextBuilder;
import org.apache.http.conn.ssl.TrustStrategy;
import org.apache.http.conn.ssl.X509HostnameVerifier;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
/**
* 服务器端请求服务类
*
* @author Administrator
* @date 2018年1月15日
* @version 1.0
*/
@SuppressWarnings("deprecation")
public abstract class RequestService {
/** jackJson 转化工具 **/
private static final ObjectMapper mapper = new ObjectMapper();
/** 连接池配置 **/
private static PoolingHttpClientConnectionManager connMgr;
/** requestConfig **/
private static RequestConfig requestConfig; /** 日志 **/
private static Logger logger = LoggerFactory.getLogger(RequestService.class);
/** 服务器地址 **/
private static final String HOST_PATH = H5FileUtils.getValueFromProperties("remote.server.host");
/** 连接超时 **/
private static final int CONNECTION_TIMEOUT = NumberUtils.toInt(H5FileUtils.getValueFromProperties("remote.conntection.timeout")) * 1000; static {
// 设置连接池
connMgr = new PoolingHttpClientConnectionManager();
// 设置连接池大小
connMgr.setMaxTotal(100);
connMgr.setDefaultMaxPerRoute(connMgr.getMaxTotal()); RequestConfig.Builder configBuilder = RequestConfig.custom();
// 设置连接超时
configBuilder.setConnectTimeout(CONNECTION_TIMEOUT);
// 设置读取超时
configBuilder.setSocketTimeout(CONNECTION_TIMEOUT);
// 设置从连接池获取连接实例的超时
configBuilder.setConnectionRequestTimeout(CONNECTION_TIMEOUT);
// 在提交请求之前 测试连接是否可用
configBuilder.setStaleConnectionCheckEnabled(true);
requestConfig = configBuilder.build();
} /**
* GET方式请求远端服务器数据
* @param url
* @return
* @throws IOException
* @throws ClientProtocolException
*/
@SuppressWarnings("rawtypes")
protected ResponseVO getRemoteReqData(String url){
logger.debug(">>>getRemoteReqData(String url)");
logger.debug("url:" + url);
return this.getRemoteReqData(url, null);
} /**默认采用不解码形式
* GET方式请求远端服务器数据
* @param url
* @return
* @throws IOException
* @throws ClientProtocolException
*/
@SuppressWarnings("rawtypes")
protected ResponseVO getRemoteReqData(String url, String specifyUrl) {
logger.debug(">>>getRemoteReqData(String url, String specifyUrl)");
logger.debug("url:" + url);
logger.debug("specifyUrl:" + specifyUrl);
return this.getRemoteReqData(url, specifyUrl, CommonConstants.DECODE_N);
} /**
* GET方式请求远端服务器数据
* @param url
* @return ResponseVO
* @throws IOException
* @throws ClientProtocolException
*/
@SuppressWarnings("rawtypes")
protected ResponseVO getRemoteReqData(String url, String specifyUrl, String isDecode) {
logger.debug(">>>getRemoteReqData(String url, String specifyUrl, String isDecode)");
logger.debug("url:" + url);
logger.debug("specifyUrl:" + specifyUrl);
logger.debug("isDecode:" + isDecode);
// 开启服务
CloseableHttpClient client = getHttpClients(specifyUrl); // 主库判断
if(StringUtils.isNotEmpty(specifyUrl)){
url = specifyUrl + url;
}else{
url = getHostUrl() + url;
}
logger.debug("-> getUrl:" + url);
HttpGet get = new HttpGet(url);
ResponseVO respVO = null;
try {
HttpResponse response=client.execute(get);
if(HttpStatus.SC_OK==response.getStatusLine().getStatusCode()){
HttpEntity entity=response.getEntity();
String returnValue = EntityUtils.toString(entity,CommonConstants.CHARSET_DEFAULT);
// 解码判断
if(StringUtils.equals(isDecode, CommonConstants.DECODE_Y)){
returnValue = URLDecoder.decode(returnValue, CommonConstants.CHARSET_DEFAULT);
}
logger.debug("->getRequest:returnValue from remoteUrl: " + returnValue);
respVO = mapper.readValue(returnValue, ResponseVO.class);
}else if(HttpStatus.SC_NO_CONTENT==response.getStatusLine().getStatusCode()){
respVO = new ResponseVO();
respVO.setResponseCode("-1");
respVO.setResponseMessage("远程连接未能接通!");
}else if(HttpStatus.SC_NOT_FOUND==response.getStatusLine().getStatusCode()){
respVO = new ResponseVO();
respVO.setResponseCode("-1");
respVO.setResponseMessage("远程连接地址未找到!");
}else if(HttpStatus.SC_BAD_REQUEST ==response.getStatusLine().getStatusCode()) {
respVO = new ResponseVO();
respVO.setResponseCode("-1");
respVO.setResponseMessage("远程接口需求数据与本地数据不匹配!");
}
} catch (ClientProtocolException e) {
respVO = new ResponseVO();
respVO.setResponseCode("-1");
respVO.setResponseMessage("远程连接出现错误!");
e.printStackTrace();
} catch (IOException e) {
respVO = new ResponseVO();
respVO.setResponseCode("-1");
respVO.setResponseMessage("远程端口出现错误!");
e.printStackTrace();
}
logger.debug("<<<getRemoteReqData(String url, String specifyUrl, String isDecode)");
return respVO;
} /**
* GET方式请求远端服务器流,
* 因返回InputStream输入流,因此一定要try catch,关闭
* @param url
* @return InputStream
* @throws IOException
* @throws ClientProtocolException
*/
protected InputStream getRemoteReqStream(String url) throws ClientProtocolException, IOException{
logger.debug(">>>getRemoteReqStream(String url)");
logger.debug("url:" + url);
return getRemoteReqStream(url, null);
}
/**
* GET方式请求远端服务器流,
* 因返回InputStream输入流,因此一定要try catch,关闭
* @param url
* @return InputStream
* @throws IOException
* @throws ClientProtocolException
*/
protected InputStream getRemoteReqStream(String url, String specifyUrl) throws ClientProtocolException, IOException{
logger.debug(">>>getRemoteReqStream(String url, String specifyUrl)");
logger.debug("url:" + url);
logger.debug("specifyUrl:" + specifyUrl);
// 主库判断
if(StringUtils.isNotEmpty(specifyUrl)){
url = specifyUrl + url;
}else{
url = getHostUrl() + url;
}
logger.debug("-> getStreamUrl:" + url);
// 开启服务
CloseableHttpClient client = getHttpClients(specifyUrl);
HttpGet get=new HttpGet(url);
InputStream is = null;
HttpResponse response=client.execute(get);
if(HttpStatus.SC_OK==response.getStatusLine().getStatusCode()){
HttpEntity entity=response.getEntity();
is = entity.getContent();
}
logger.debug("<<<getRemoteReqStream(String url, String specifyUrl)");
return is;
} /**
* POST方式请求远端服务器数据
* @param url
* @return ResponseVO
*/
@SuppressWarnings("rawtypes")
protected ResponseVO postRemoteReqData(String url, HttpEntity entity){
logger.debug(">>>postRemoteReqData(String url, HttpEntity entity)");
logger.debug("url:" + url);
logger.debug("entity:{}", entity);
return postRemoteReqData(url, entity, null);
}
/**
* 默认此方法不采用解码形式
* POST方式请求远端服务器数据
* @param url
* @return ResponseVO
*/
@SuppressWarnings("rawtypes")
protected ResponseVO postRemoteReqData(String url, HttpEntity entity, String specifyUrl){
logger.debug(">>>postRemoteReqData(String url, HttpEntity entity)");
logger.debug("url:" + url);
logger.debug("entity:{}", entity);
logger.debug("specifyUrl:" + specifyUrl);
return postRemoteReqData(url, entity, specifyUrl, CommonConstants.DECODE_N);
} /**
* post请求
* @param rEMOTE_URL_GESTURE_SAVE
* @param createParams
* @param specifyUrl(指定url)
* @return ResponseVO
*/
@SuppressWarnings({"rawtypes"})
public ResponseVO postRemoteReqData(String url, HttpEntity entity, String specifyUrl, String isDecode) {
logger.debug(">>>postRemoteReqData(String url, HttpEntity entity, String specifyUrl, String isDecode)");
logger.debug("url:" + url);
logger.debug("entity:{}", entity);
logger.debug("specifyUrl:" + specifyUrl);
logger.debug("isDecode:" + isDecode);
// 主库判断
if(StringUtils.isNotEmpty(specifyUrl)){
url = specifyUrl + url;
}
else{
url = getHostUrl() + url;
}
logger.debug("-> postUrl:" + url);
// 开启服务
CloseableHttpClient client = getHttpClients(specifyUrl);
//POST的URL
HttpPost httpPost = new HttpPost(url);
// 返回值
ResponseVO respVO = null;
//添加参数
httpPost.setEntity(entity);
HttpResponse response;
try {
response = client.execute(httpPost); if(HttpStatus.SC_OK==response.getStatusLine().getStatusCode()){
String returnValue = EntityUtils.toString(response.getEntity(),CommonConstants.CHARSET_DEFAULT);
// 解码判断
if(StringUtils.equals(isDecode, CommonConstants.DECODE_Y)){
returnValue = URLDecoder.decode(returnValue, CommonConstants.CHARSET_DEFAULT);
}
logger.debug("->getRequest:returnValue from remoteUrl: " + returnValue);
respVO = mapper.readValue(returnValue, ResponseVO.class);
}else if(HttpStatus.SC_NO_CONTENT==response.getStatusLine().getStatusCode()){
respVO = new ResponseVO();
respVO.setResponseCode("-1");
respVO.setResponseMessage("远程连接未能接通!");
}else if(HttpStatus.SC_NOT_FOUND==response.getStatusLine().getStatusCode()){
respVO = new ResponseVO();
respVO.setResponseCode("-1");
respVO.setResponseMessage("远程连接地址未找到!");
}else if(HttpStatus.SC_BAD_REQUEST ==response.getStatusLine().getStatusCode()) {
respVO = new ResponseVO();
respVO.setResponseCode("-1");
respVO.setResponseMessage("远程接口需求数据与本地数据不匹配!");
}
} catch (ClientProtocolException e) {
respVO = new ResponseVO();
respVO.setResponseCode("-1");
respVO.setResponseMessage("远程连接出现错误!");
e.printStackTrace();
} catch (IOException e) {
respVO = new ResponseVO();
respVO.setResponseCode("-1");
respVO.setResponseMessage("远程端口出现错误!");
e.printStackTrace();
}
logger.debug("respVO:{}", respVO);
logger.debug("<<<postRemoteReqData(String url, HttpEntity entity, String specifyUrl, String isDecode)");
return respVO;
} /**
* 构建Request的Post String参数
* @param names String[]
* @param values String[]
* @return HttpEntity
* @throws UnsupportedEncodingException
*/
protected HttpEntity createParams(String[] names, String[] values) {
logger.debug(">>>createParams(String[] names, String[] values)");
logger.debug("names:{}", names.toString());
logger.debug("values:{}", values.toString());
List<NameValuePair> paramsList = new ArrayList<NameValuePair>();
HttpEntity entity = null;
for(int i = 0; i < names.length; i++){
paramsList.add(new BasicNameValuePair(names[i], values[i]));
}
try{
entity = new UrlEncodedFormEntity(paramsList, CommonConstants.CHARSET_DEFAULT);
}catch(UnsupportedEncodingException e){
logger.debug("->UnsupportedEncodingException:", e);
}
logger.debug("paramsList:{}", paramsList);
logger.debug("<<<createParams(String[] names, String[] values)");
return entity;
} /**
* 构建Request的Post Json格式对象参数
* @throws UnsupportedEncodingException
*/
protected HttpEntity createJsonParams(Object jsonObject) {
logger.debug(">>> createJsonParams(Object jsonObject)");
logger.debug("jsonObject:{}", jsonObject);
StringEntity entity = null;
try{
entity = new StringEntity(H5Utils.mapper.writeValueAsString(jsonObject), CommonConstants.CHARSET_DEFAULT);
entity.setContentEncoding(CommonConstants.CHARSET_DEFAULT);
entity.setContentType("application/json");
} catch (JsonProcessingException e) {
logger.debug("->JsonProcessingException:", e);
}
logger.debug("entity:{}", entity);
logger.debug("<<<createJsonParams(Object jsonObject)");
return entity;
} /**
* 获取服务地址
* @return
*/
private String getHostUrl(){
logger.debug(">>>getHostUrl()");
String url = HOST_PATH;
logger.debug("url:" + url);
logger.debug("<<<getHostUrl()");
return url;
} /**
* 根据http请求或者https请求,获取httpClients
* @return
*/
private CloseableHttpClient getHttpClients(String specifyUrl) {
logger.debug(">>>getHttpClients(String specifyUrl)");
logger.debug("specifyUrl:" + specifyUrl);
// https问题
CloseableHttpClient httpClient = null;
if(StringUtils.isNotEmpty(specifyUrl) && specifyUrl.indexOf("https:") > 0){
httpClient = HttpClients.custom().setSSLSocketFactory(createSSLConnSocketFactory()).setConnectionManager(connMgr).setDefaultRequestConfig(requestConfig).build();
}else{
httpClient = HttpClients.custom().setConnectionManager(connMgr).setDefaultRequestConfig(requestConfig).build();
logger.debug("provIp: " + specifyUrl);
}
logger.debug("<<<getHttpClients(String specifyUrl)");
return httpClient;
} /**
* 转化List为对象List
* @param class1
* @return
*/
@SuppressWarnings("rawtypes")
protected List<?> convertListToObject(List originalList,Class<?> class1) {
logger.debug(">>>convertListToObject(List originalList,Class<?> class1)");
logger.debug("originalList:{}", originalList);
logger.debug("class1:{}", class1);
List<Object> list = null;
try{
if(!CollectionUtils.isEmpty(originalList)){
list = new ArrayList<Object>();
for(Object obj : originalList){
Object target = class1.newInstance();
BeanUtils.copyProperties(target, obj);
list.add(target);
}
}
} catch(Exception e){
e.printStackTrace();
list = null;
}
logger.debug("<<<convertListToObject(List originalList,Class<?> class1)");
return list;
} /**
* 创建SSL安全连接
*
* @return
*/
private static SSLConnectionSocketFactory createSSLConnSocketFactory() {
logger.debug(">>>createSSLConnSocketFactory()");
SSLConnectionSocketFactory sslsf = null;
try {
SSLContext sslContext = new SSLContextBuilder().loadTrustMaterial(null, new TrustStrategy() { @Override
public boolean isTrusted(X509Certificate[] chain, String authType) throws CertificateException {
return true;
}
}).build();
sslsf = new SSLConnectionSocketFactory(sslContext, new X509HostnameVerifier() { @Override
public boolean verify(String arg0, SSLSession arg1) {
return true;
} @Override
public void verify(String host, SSLSocket ssl) throws IOException {
} @Override
public void verify(String host, X509Certificate cert) throws SSLException {
} @Override
public void verify(String host, String[] cns, String[] subjectAlts) throws SSLException {
}
});
} catch (GeneralSecurityException e) {
e.printStackTrace();
}
logger.debug("sslsf:{}", sslsf);
logger.debug("<<<createSSLConnSocketFactory()");
return sslsf;
} }
简单的remote Request:
HttpClient client = new DefaultHttpClient();
HttpPost post = new HttpPost(url);
// 请求超时
client.getParams().setParameter(CoreConnectionPNames.CONNECTION_TIMEOUT, 2000);
post.addHeader("Content-type","application/x-www-form-urlencoded;charset=utf-8");
post.setEntity(entity);
try {
client.execute(post);
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
remote Request的更多相关文章
- Adaptively handling remote atomic execution based upon contention prediction
In one embodiment, a method includes receiving an instruction for decoding in a processor core and d ...
- Java基础常见英语词汇
Java基础常见英语词汇(共70个) ['ɔbdʒekt] ['ɔ:rientid]导向的 ['prəʊɡræmɪŋ]编程 OO: object ...
- IT软件开发常用英语词汇
Aabstract 抽象的abstract base class (ABC)抽象基类abstract class 抽象类abstraction 抽象.抽象物.抽象性access 存取.访问access ...
- computer English
算法常用术语中英对照Data Structures 基本数据结构Dictionaries 字典PriorityQueues 堆Graph Data Structures 图Set Data Struc ...
- A javascript library providing cross-browser, cross-site messaging/method invocation. http://easyxdm.net
easyXDM - easy Cross-Domain Messaging easyXDM is a Javascript library that enables you as a develope ...
- [Web] What Is JSONP?
JSONP—or JSON with padding—is a sneaky technique that web developers came up with to work around the ...
- nginx整合tomcat集群并做session共享----测试案例
最近出于好奇心,研究了一下tomcat集群配置,并整合nginx,实现负载均衡,session共享,写篇记录,防止遗忘.---------菜鸡的自我修炼. 说明:博主采用一个web项目同时部署到两台t ...
- js实现省市区联动
先来看看效果图吧,嘻嘻~~~~~~~~~~~~~~~~~~~· 代码在下面: 示例一: html: <!DOCTYPE html> <html> <head> &l ...
- IBM flex system P260
CMM 机箱管理模块 提供如下功能: 电力控制 风扇管理 机箱和计算节点初始化 交换机管理 诊断:机箱.IO选项和计算节点 资源发现和库存管理 资源告警和监控 机箱和计算节点的电源管理 安全策略管理 ...
随机推荐
- stenciljs 学习二 pwa 简单应用开发
stenciljs 介绍参考官方网站,或者 https://www.cnblogs.com/rongfengliang/p/9706542.html demo 项目使用脚手架工具 创建项目 使用脚手架 ...
- vue-resource 知识点
vue-resource 发送json到后端: Content-Type字段的类型是application/json,就会有options请求. http://www.ruanyifeng.com/b ...
- Jenkins进阶-Gitlab使用Webhook实现Push代码自动部署(3)
1.Jenkins 安装完成以后,首先我们在Jenkins中需要安装一下,Gitlab Hook Plugin 插件: 2.插件安装完成我们创建任务,在任务重构建触发器下获取回调URL: 注意: 注意 ...
- java Scanner中的hasNext()方法
hasNext()方法判断输入(文件.字符串.键盘等输入流)是否还有下一个输入项,若有,返回true,反之false. Scanner sc = new Scanner(new File(" ...
- Openwrt 3g模块
支持Huawei E367 一.编译选项的选择 都选上 都选上 Network目录下 Utiles Luci 二.USB连接3G模块时,显示如下,表示成功 三.没找到:
- CSS Grid布局入门
相信大家都比较熟悉flex布局了,最近有空研究了波grid布局,感觉虽然兼容性还不是太高,应用不是太普遍,但是功能非常强大.未来应该是grid+flex为主流,grid是二维布局,很灵活,适合整体构架 ...
- Qt5布局管理(二)——QDockWidget停靠窗口类
转载:LeeHDsniper 停靠窗口类QDockWidget 实例效果 如右图所示,左半部分MainWindow是该窗口的中心窗口,右边的最下面两个停靠窗口可以跳出该窗口: 但是第一个停靠窗口只能停 ...
- bzoj1047 理想的正方形
Description 有一个a*b的整数组成的矩阵,现请你从中找出一个n*n的正方形区域,使得该区域所有数中的最大值和最小值的差最小. Input 第一行为3个整数,分别表示a,b,n的值第二行至第 ...
- canvas基础之变换
2D绘制上下文支持各种基本的绘制变换: rotate(angle):围绕原点旋转图像angle弧度.(举例:如需旋转 5 度,可规定下面的公式:5*Math.PI/180.) scale(scaleX ...
- 杂项-TOOL:NPIO
ylbtech-杂项-TOOL:NPIO NPOI是指构建在POI 3.x版本之上的一个程序,NPOI可以在没有安装Office的情况下对Word或Excel文档进行读写操作.NPOI是一个开源的Ja ...