BackFilter.java

主要解决基于HttpGet/HttpPost以及基于HttpPost的附件流转发
import java.io.IOException;
import java.io.InputStream;
import java.util.Collection;
import java.util.Date;
import java.util.Enumeration;
import java.util.HashMap;
import java.util.Map;
import java.util.Properties; import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import org.apache.http.Header;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.multipart.MultipartHttpServletRequest;
import org.springframework.web.multipart.commons.CommonsMultipartResolver; import com.xinhe99.utils.DateUtil; public class BackFilter implements Filter{ public void destroy() { } public void doFilter(ServletRequest req, ServletResponse res,
FilterChain chain) throws IOException, ServletException {
System.out.println("--------------filter--------------------------");
HttpServletRequest request=(HttpServletRequest) req;
HttpServletResponse response=(HttpServletResponse) res; request.setCharacterEncoding(HttpClientBack.encodeUTF);
Map<String, String> params = new HashMap<String, String>();
String method = request.getMethod(); //获取提交类型
String IP = getRemoteHost(request); //获取真实Ip
String requestURI = request.getRequestURI();//获取请求URI
System.out.println(request.getRequestURI());
System.out.println(request.getRequestURL());
System.out.println(request.getQueryString());
String scheme = request.getScheme(); //获取协议名称(http或https)
String realName = "10.168.110.247:8080"; //读取的域名
String strUr="://";
String url=scheme + strUr + realName + requestURI;
Enumeration<String> parameterNames = request.getParameterNames();
while(parameterNames.hasMoreElements()){
String key = parameterNames.nextElement();
String value = request.getParameter(key);
params.put(key, value);
} byte[]b=new byte[1024];
ResponseResult result = null;
// if("post".equalsIgnoreCase(method)){
// b = HttpClientBack.post(url, params,IP);
// }
// if("get".equalsIgnoreCase(method)){
// b= HttpClientBack.get(url,IP);
// } if("post".equalsIgnoreCase(method)){
// 创建一个通用的多部分解析器
CommonsMultipartResolver multipartResolver = new CommonsMultipartResolver(
request.getSession().getServletContext());
// 判断 request 是否有文件上传,即多部分请求
InputStream in = null;
if (multipartResolver.isMultipart(request)) {
System.out.println("wenjian============");
MultipartHttpServletRequest mreqest = multipartResolver
.resolveMultipart(request);
Map<String, MultipartFile> filesMap = mreqest.getFileMap();
Collection<MultipartFile> fileList = filesMap.values();
for (MultipartFile mf : fileList) {
//获取原始文件名
String originalFilename =mf.getOriginalFilename();
//获取文件流,可以进行处理
in = mf.getInputStream();
result = HttpClientBack.postMuti(url, params, IP,originalFilename,in); }
}else
{
result = HttpClientBack.post(url, params,IP);
}
}
if("get".equalsIgnoreCase(method)){
// add query string
if(null != request.getQueryString()){
url += "?" + request.getQueryString();
}
result= HttpClientBack.get(url,IP);
} if(null != result){
b = result.getBody();
}else{
///do you wangcan beibei xietong chuli
}
//文件名用日期加时间戳
String filename=DateUtil.getDate(new Date()).replaceAll("-", "")+String.valueOf(new Date().getTime());
//设置相应头
Header[] headers = result.getHeaders();
if(null != headers && 0 < headers.length){
for(Header header : headers){
response.setHeader(header.getName(), header.getValue());
}
}
// response.setHeader("Content-type", "application/xls;charset=UTF-8");
// response.setContentType("application/x-msdownload");
// response.setHeader("Content-Disposition", "attachment;filename="+filename+".xls;charset=UTF-8"); if(b.length !=-1){
response.getOutputStream().write(b);
}else{
response.getOutputStream().write(-1);
} } public void init(FilterConfig arg0) throws ServletException { } public String getRemoteHost(javax.servlet.http.HttpServletRequest request){
String ip = request.getHeader("x-forwarded-for");
if(ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)){
ip = request.getHeader("Proxy-Client-IP");
}
if(ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)){
ip = request.getHeader("WL-Proxy-Client-IP");
}
if(ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)){
ip = request.getRemoteAddr();
}
return ip.equals("0:0:0:0:0:0:0:1")?"127.0.0.1":ip;
} public String getUrl() {
Properties props = new Properties(); InputStream in = BackFilter.class.getResourceAsStream("/config/config.properties"); try {
props.load(in);
in.close();
} catch (IOException e) {
e.printStackTrace();
}
// 读取特定属性
String key = "target.url";
String url = props.getProperty(key);
return url;
} }

  HttpClientBack.java

import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.UnsupportedEncodingException;
import java.nio.charset.Charset;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Set; import org.apache.http.Consts;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
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.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.methods.HttpUriRequest;
import org.apache.http.entity.ContentType;
import org.apache.http.entity.mime.HttpMultipartMode;
import org.apache.http.entity.mime.MultipartEntityBuilder;
import org.apache.http.entity.mime.content.InputStreamBody;
import org.apache.http.entity.mime.content.StringBody;
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.message.BasicNameValuePair;
import org.apache.http.util.Args;
import org.apache.http.util.ByteArrayBuffer;
import org.apache.http.util.CharsetUtils;
import org.apache.http.util.EntityUtils;
import org.apache.xmlbeans.impl.common.IOUtil; public class HttpClientBack { public static final String encodeUTF = "UTF-8"; // 发送post请求
public static ResponseResult post(String url, Map<String, String> params,
String ip) {
CloseableHttpClient httpclient = HttpClientBuilder.create().build();
byte[] body = new byte[1024]; // body = invoke(httpclient, post,ip); ResponseResult result = null;
try {
HttpPost post = postForm(url, params);
// HttpGet get = new HttpGet(url);
result = invoke(httpclient, post, ip);
httpclient.close();
return result;
} catch (IOException e) {
e.printStackTrace();
return null;
} // try {
// httpclient.close();
// } catch (IOException e) {
// e.printStackTrace();
// }
//
// return body;
} // 发送get请求
public static ResponseResult get(String url, String ip) {
CloseableHttpClient httpclient = HttpClientBuilder.create().build();
// byte[] body = new byte[1024];
ResponseResult result = null;
try {
HttpGet get = new HttpGet(url);
result = invoke(httpclient, get, ip);
httpclient.close();
return result;
} catch (IOException e) {
e.printStackTrace();
return null;
} // return body;
} // 执行
private static ResponseResult invoke(CloseableHttpClient httpclient,
HttpUriRequest httpost, String ip) { httpost.setHeader("x-forwarded-for_new", ip);
HttpResponse response = sendRequest(httpclient, httpost);
return new ResponseResult(paseResponse(response),
response.getAllHeaders());
} // 解析
private static byte[] paseResponse(HttpResponse response) {
HttpEntity entity = response.getEntity(); byte[] body = null;
try { body = EntityUtils.toByteArray(entity);
} catch (Exception e) {
e.printStackTrace();
} return body;
} // 正式发送
private static HttpResponse sendRequest(CloseableHttpClient httpclient,
HttpUriRequest httpost) {
HttpResponse response = null; try {
response = httpclient.execute(httpost);
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return response;
} // post方式获取并包装参数
private static HttpPost postForm(String url, Map<String, String> params) { HttpPost httpost = new HttpPost(url);
List<NameValuePair> nvps = new ArrayList<NameValuePair>(); Set<String> keySet = params.keySet();
for (String key : keySet) {
nvps.add(new BasicNameValuePair(key, params.get(key)));
} try {
httpost.setEntity(new UrlEncodedFormEntity(nvps,
HttpClientBack.encodeUTF));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return httpost;
}
/**
* 处理附件上传
* @param url
* @param params
* @param ip
* @param fileName
* @param targetIn
* @return
*/
public static ResponseResult postMuti(String url,
Map<String, String> params, String ip, String fileName,
InputStream targetIn) {
RequestConfig defaultRequestConfig = RequestConfig.custom()
.setSocketTimeout(5000)
.setConnectTimeout(5000)
.setConnectionRequestTimeout(5000).build();
CloseableHttpClient httpClient = HttpClientBuilder.create().setDefaultRequestConfig(defaultRequestConfig).build(); ResponseResult result = new ResponseResult();
InputStream localIn = targetIn;
HttpEntity reqEntity = null;
InputStream responseIn = null;
CloseableHttpResponse response = null;
byte[] datas =null;
try {
HttpPost httpPost = postForm(url, params);
httpPost.setHeader("x-forwarded-for_new", ip);
InputStreamBody bin = new InputStreamBody(targetIn, fileName);
StringBody uploadFileName = new StringBody(fileName,
ContentType.create("text/plain", Consts.UTF_8));
// 以浏览器兼容模式运行,防止文件名乱码。
reqEntity = MultipartEntityBuilder.create()
.setMode(HttpMultipartMode.BROWSER_COMPATIBLE)
.addPart("file", bin).addPart("filename", uploadFileName)
.setCharset(CharsetUtils.get("UTF-8")).build();
httpPost.setEntity(reqEntity);
System.out.println("发起请求的页面地址 " + httpPost.getRequestLine());
// 发起请求 并返回请求的响应
response = httpClient.execute(httpPost);
responseIn = response.getEntity().getContent();
datas = toByteArray(responseIn);
// 打印响应状态
System.out.println(response.getStatusLine());
// 获取响应对象
HttpEntity resEntity = response.getEntity();
if (resEntity != null) {
// 打印响应长度
System.out.println("Response content length: "
+ resEntity.getContentLength());
// 打印响应内容
System.out.println(new String(datas,Charset.forName("UTF-8")));
}
// 销毁
//EntityUtils.consume(resEntity);
result.setBody(datas);
result.setHeaders(response.getAllHeaders());
} catch (Exception ex) {
ex.printStackTrace();
return null;
} finally {
try {
if (response != null) {
response.close();
}
if (localIn != null) {
localIn.close();
}
if (responseIn != null) {
responseIn.close();
}
if (httpClient != null) {
httpClient.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
return result;
}
private static byte[] toByteArray(InputStream input) throws IOException {
ByteArrayOutputStream output = new ByteArrayOutputStream();
try{
byte[] buffer = new byte[4096];
int n = 0;
while (-1 != (n = input.read(buffer))) {
output.write(buffer, 0, n);
}
}finally{
if(output!=null){
output.close();
}
}
return output.toByteArray();
}
}

  

HttpClient filter中间转发从A tomcat转发至B tomcat的更多相关文章

  1. Apache 实现ProxyPass转发URL到Tomcat并实现http自动转https【转载】

    转自 Apache 实现ProxyPass转发URL到Tomcat并实现http自动转https - OPEN 开发经验库http://www.open-open.com/lib/view/open1 ...

  2. 通过一个tomcat端口访问多个tomcat项目 tomcat转发

    需求是这样的,有一个tomcat,是80端口,现在我要通过这个tomcat转发到服务器其他tomcat,其他tomcat的端口不是80.这样做就可以避免这样www.baidu.com:8081的情况. ...

  3. Tomcat是什么:Tomcat与Java技、Tomcat与Web应用以及Tomcat基本框架及相关配置

    1.Tomcat是什么       Apache Tomcat是由Apache Software Foundation(ASF)开发的一个开源Java WEB应用服务器. 类似功能的还有:Jetty. ...

  4. Tomcat请求处理过程(Tomcat源代码解析五)

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/ ...

  5. springboot放到linux启动报错:The temporary upload location [/tmp/tomcat.8524616412347407692.8111/work/Tomcat/localhost/ROOT/asset] is not valid

    1.背景 笔者的springboot在一个非root用户环境下运行,这种环境下可以保证不被潜在的jar/开源框架漏洞提权. 比如在防火墙上把外网访问来的443端口映射到本地8443的java web端 ...

  6. Tomcat目录结构及Tomcat Server处理一个http请求的过程

    http://blog.sina.com.cn/s/blog_62cb15980101jh9x.html 1.Tomcat的结构概述     Tomcat服务器是由一系列可配置的组件构成,其核心组件是 ...

  7. How Tomcat works — 四、tomcat启动(3)

    上一节说到StandardService负责启动其子组件:container和connector,不过注意,是有先后顺序的,先启动container,再启动connector,这一节先来看看conta ...

  8. Tomcat配置(二):tomcat配置文件server.xml详解和部署简介

    */ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...

  9. Tomcat(五):nginx/httpd + tomcat及负载均衡tomcat

    */ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...

随机推荐

  1. loading.io一个loading图标网站,跟大家分享

    loading.io是官方网址在首页选一款loading图标,看到左上角的 Try it now中有选中的图标后,可通过光标滑动选择图标大小,然后再点右边的get svg或get css等下载即可

  2. js验证IP及子网掩码的合法性

    function checkIP(ip) {     obj=ip;    var exp=/^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0 ...

  3. CSS 简介、语法、派生选择器、id 选择器、类选择器、属性选择器

    CSS 概述 CSS 指层叠样式表 (Cascading Style Sheets) 样式定义如何显示 HTML 元素 样式通常存储在样式表中 把样式添加到 HTML 4.0 中,是为了解决内容与表现 ...

  4. FLV格式详解

    Overview Flash Video(简称FLV),是一种流行的网络格式.目前国内外大部分视频分享网站都是采用的这种格式. File Structure 从整个文件上开看,FLV是由The FLV ...

  5. Fiddler 模拟请求的操作方法

    此文记录使用Fidder Web Debugger工具,模拟请求的操作步骤! 首先简述一下fiddler的使用: 1.下载安装Fidder抓包工具. 2.打开fiddler发现有左边的栏有请求的url ...

  6. 玩转spring boot——结合阿里云持续交付

    前言 在互联网项目中,项目测试.部署往往需要花费大量时间.传统方式是在本地打包.测试完毕程序,然后通过ftp上传至服务器,再把测试的配置文件修改为生产环境的配置文件,最后重新运行服务.这一过程如果交给 ...

  7. android: activity切换之效果

    Activity是android应用的重要部分;为了提高用户的体验度,加了Activity之间切换的动画效果,现在介绍的一种切换动画: 是什么效果,大家自已动手测试一下便知道: 先看进入的动画: pa ...

  8. 离职了,在家温故而知新----1 设计模式 & 开头

    工作四年有余,编写的代码都是业务代码.不涉及低层. 目前离职在家,过年完了,准备找工作了. 决定温故而知新,复习也是学习. 本着随遇而安的原则,随便从之前设计的众多条目中选择了一条开始复习. 设计模式 ...

  9. JAVA中的基本数类型据

    一.基本类型​ byte: java中最小的数据类型.1字节/8位.-128(2^7)~127(2^7-1),默认值0. short: 短整型,2字节/16位,取值范围-32768(--2^15)~3 ...

  10. 关于C++的const对象

    对于const类对象,类指针, 类引用, 只能调用类的const成员函数. 1.const成员函数不允许被修改它所在对象的任何一个成员变量. 2.const成员函数能访问对象的const成员, 而其他 ...