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的更多相关文章

  1. 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 ...

  2. Java基础常见英语词汇

    Java基础常见英语词汇(共70个) ['ɔbdʒekt] ['ɔ:rientid]导向的                             ['prəʊɡræmɪŋ]编程 OO: object ...

  3. IT软件开发常用英语词汇

    Aabstract 抽象的abstract base class (ABC)抽象基类abstract class 抽象类abstraction 抽象.抽象物.抽象性access 存取.访问access ...

  4. computer English

    算法常用术语中英对照Data Structures 基本数据结构Dictionaries 字典PriorityQueues 堆Graph Data Structures 图Set Data Struc ...

  5. 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 ...

  6. [Web] What Is JSONP?

    JSONP—or JSON with padding—is a sneaky technique that web developers came up with to work around the ...

  7. nginx整合tomcat集群并做session共享----测试案例

    最近出于好奇心,研究了一下tomcat集群配置,并整合nginx,实现负载均衡,session共享,写篇记录,防止遗忘.---------菜鸡的自我修炼. 说明:博主采用一个web项目同时部署到两台t ...

  8. js实现省市区联动

    先来看看效果图吧,嘻嘻~~~~~~~~~~~~~~~~~~~· 代码在下面: 示例一: html: <!DOCTYPE html> <html> <head> &l ...

  9. IBM flex system P260

    CMM 机箱管理模块 提供如下功能: 电力控制 风扇管理 机箱和计算节点初始化 交换机管理 诊断:机箱.IO选项和计算节点 资源发现和库存管理 资源告警和监控 机箱和计算节点的电源管理 安全策略管理 ...

随机推荐

  1. git 报错及解决

    报错:fatal: refusing to merge unrelated histories==== 解决办法:git pull加上参数,如:git pull –allow-unrelated-hi ...

  2. Sentry从0到1

    无Sentry 在没有sentry的情况下,他的权限逻辑是这样的:jdbc采用hive权限创建的表,只有hive用户可以看到:hue用户是无法看到的: Sentry 在启用sentry,就是基于sen ...

  3. 未能正确加载“VSTS for Database Professionals Sql Server Data-tier Application”包。(转)

    今天费了九牛二虎之力,重转好了vs2010之后,打开解决方案,报出下面的错误: ---------------------------Microsoft Visual Studio---------- ...

  4. DHCP服务器备份、还原、迁移

    备份DHCP服务器 $today = get-date $todayu = get-date -format 'yyyyMMdd' #备份DHCP数据库,用于还原到本地 Backup-DhcpServ ...

  5. 如何在eclipse中安装angularjs插件

    1,首先,在eclipse中使用angularjs的时候,由于没有相应的提示,导致在开发的时候给我们带来了很多的不便,需要在这上面耗费一些时间.那么这时候我们都在想可不可以让eclipse也和一些前端 ...

  6. jsoncpp解析拼装数组

    Cocos2d-x添加jsoncpp应该资料都有了,今天来讲讲数组的解析和拼装- int main() { 数组创建与分析: 例子一: string strValue = "{\" ...

  7. bzoj1193 马步距离

    Description 求点(xs,ys)走马步到(xp,yp)的最小步数   Input 只包含4个整数,它们彼此用空格隔开,分别为xp,yp,xs,ys.并且它们的都小于10000000. Out ...

  8. PAT 乙级 1037 在霍格沃茨找零钱(20)C++版

    1037. 在霍格沃茨找零钱(20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 如果你是哈利·波特迷,你会知 ...

  9. AppScan代理扫描app/H5安全测试(没试过,记录在此)

    标签: 1.首先设置AppScan代理,设置如下:

  10. 学习笔记之C/C++指针使用常见的坑

    https://mp.weixin.qq.com/s/kEHQjmhNtSmV3MgHzw6YeQ 避免内存泄露 不再用到的内存没有释放,就叫做内存泄露 在C/C++中,通过动态内存分配函数(如mal ...