还是手机银行嵌入办事通的项目,这个项目比较坑的地方在于没有项目文档,没有数据交互规范,都是摸石头过河。所以上了生产以后,发现了一个大Bug,收不到IOS的请求数据(测试过程我没参与,怀疑测试过程可能没有IOS测试)!
经过与建行手机银行总行联系,才知道由于手机银行开发框架限制,IOS请求只能发Post请求,所以请求分为两种:Android -- GET请求
Ios -- POST请求
所以就需要更新代码,需要分别适配两种请求模式,读取其中的参数为我所用。开发框架采用SpringMvc,由于传递参数少,所以之前就只考虑了Get请求,取参数也十分顺利,现在需要增加post请求判断,,先上代码:
String userinfo = null;
if (request.getQueryString() != null) {
String requestStr = request.getRequestURL() + "?" + request.getQueryString();
log.info("Get请求=====" + requestStr);
userinfo = request.getParameter("userInfo");
if (userinfo != null && userinfo.length() > 0) {
userinfo = userinfo.replaceAll(" ", "+");
log.info("Get请求取到的userInfo的值为=====" + userinfo);
} else {
log.error("userInfo的值为null");
}
} else {
StringBuffer sb = new StringBuffer();
InputStream is;
String requestStr = null;
BufferedReader br = null;
try {
is = request.getInputStream();
InputStreamReader isr = new InputStreamReader(is);
br = new BufferedReader(isr);
String s = "";
while ((s = br.readLine()) != null) {
sb.append(s);
}
requestStr = sb.toString();
log.info("Post请求=====" + requestStr);
String[] user = requestStr.split("&");
for (int i = 0; i < user.length; i++) {
if (user[i].contains("userInfo")) {
String[] userStrSub = user[i].split("=");
userinfo = userStrSub[1];
break;
}
}
if (userinfo != null && userinfo.length() > 0) {
userinfo = userinfo.replaceAll("%2B", "+");
log.info("Post请求取到的userInfo值为==" + userinfo);
} else {
log.error("userInfo的值为null");
}
} catch (IOException e1) {
log.error(e1.getMessage());
} finally {
try {
if (br != null) {
br.close();
}
} catch (IOException e) {
log.error(e.getMessage());
}
}
}
该项目springMvc框架,接收post和get请求, @RequestMapping(value = "") 结果利用postMan发送post请求时,postMan加一个'/'和不加'/' 结果大不一样,比如:
postMan发送POST请求:http://localhost:8080/yndist 通过读取request的io流,结果为null
postMan发送POST请求:http://localhost:8080/yndist/ 通过读取request的io流,结果能取到json串
为什么加一个'/'和不加'/'结果会不一样??利用request.getRequestURI()
结果取到的都是/yndist/
,那为什么打印IO流的时候会结果大相庭径呢?
这个有机会研究下,暂时不考虑这个因素。。。
利用抓包工具,结果加'/'和不加'/'都拿到了数据,这个时候,说明程序某个地方出现了Bug,可是这个为什么会出现这样的原因,暂时我也没找到。。。。
解释下@RequestMapping(value = "")这个地方设置为null的原因:
总行提供服务器,默认监听8080端口,所以https://zwfw.yn.gov.cn/yndist
默认指向服务器的ip+port+yndist,就是这样:127.0.0.1:8080/yndist,所以这个指向跟WEB服务路径特别类似,所以这个地方就设置为NUll了。
所以根据这个https://zwfw.yn.gov.cn/yndist
写死的访问url,我把项目名也改为了yndist
,但是接收post请求时,打印的IO流为null,无论怎么都取不到值,利用postMan测试,就出现了加'/'和不加'/'的区别。
想不到其他办法,就利用Nginx做了一个反向代理,配置也特别简单:
server {
listen 8080;
server_name 127.0.0.1; //如有需要,需更改为自己服务器Ip
#access_log logs/host.access.log main;
location /yndist {
# 转发请求到后端服务网关
proxy_pass http://127.0.0.1:7070/yndist/index.do;
}
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|css|js|properties|json)$ {
proxy_pass http://127.0.0.1:7070;
}
}
然后更改Tomcat默认端口为7070,@RequestMapping(value = "/index.do"),然后加拦截,调试OK!
其实这个地方可以不用Nginx,Tomcat也可以设置反向代理,但是试了几种,都没成功,有知道方法的大神可以指导下,所以就采用Nginx啦。。