还是手机银行嵌入办事通的项目,这个项目比较坑的地方在于没有项目文档,没有数据交互规范,都是摸石头过河。所以上了生产以后,发现了一个大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啦。。