应用接入CAS后,org.jasig.cas.client.session.SingleSignOutFilter导致request.getInputStream()取不到的问题

来源:互联网 发布:手机dpk解压软件 编辑:程序博客网 时间:2024/06/14 05:27
     CAS 单点退出Filter加上后,

前台传json数据到后台,后台使用request.getInputStream()然后转字符串,

结果取不到。
------------------------
原因我知道,是退出Filter里从request取参数了,导致request流已经被解析,

流只能解析一次,所以无法再通过Stream的方式读取。
--------------------------
最后的解决方法是:


var strPara = strSql + "&" + strStart + "&" + strLargeFlag + "&" + strLimitFlag;
        Request = new ActiveXObject("Microsoft.XMLHTTP");
        Request.open("POST",strURL, false);
        Request.setRequestHeader("Content-Type","application/json");
        //Request.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
        Request.send(strPara);

   


前台pos请求时,指定contentType为application/json即可。
--------------------------
为什么这样可以?
--------------------------
在tomcat的Request.parseParameters方法里,
对于application/x-www-form-urlencoded是有做判断的,
对这种编码会去解析body里的数据,填充到parameters里,
所以后续想再通过流的方式读取body是读不到的(除非你没有触发过getParameter相关的方法)。
--------------------------
简单的说,request.getParameter里面判断了content-type,
只有是application/x-www-form-urlencoded时才进行解析,
调用后,后面就无法再次读取流了。

如果变成了application/json什么的,也就没事了,即使用了getParameter方法,也没影响。



转载请注明:http://blog.csdn.net/HEL_WOR/article/details/52123712

http请求
场景:
前端:SDK通过http发送请求/页面Ajax提交。
后台:Springboot服务,Rest风格,需在controller层之前拦截请求。

Springboot支持Rest风格给编码带来了很好的便捷性,@RequestBody让我们可以直接以application/json请求并在到达controller层获得已反序列化的对象,当有拦截的需求,这种方式却不再奏效。

application/x-www-form-urlencoded通过表单提交,在sevlet实现中,mutipart/form-data和application/x-www-form-urlencoded会被特殊处理,请求参数将被放置于request.paramter,这是一个map。我们可以从map中获取参数进行验证,或者其他拦截需求,map的获取类似hibernate的延迟加载,当调用request.getparamter()方法,servlet才会从请求流中读取请求参数加载入map。InputStream也会存有这份数据,但如果这份数据被读取,那么到了controller层将无法读出数据,同样,拦截之后到达controller层时请求数据已经被加载入了controller层方法实参,实参对象需要有set方法,框架会以反射的方式调用属性的set方法注入数据,数据只会被注入到已有的属性。

当以application/json的content-type传送数据,被传送的对象只需被json序列化。当以application/x-www-form-urlencoded的方式传送数据。请求的内容需要以..=..&..=..的格式提交,在请求体内内容将会以”&”和“ = ”进行拆分。

    app.controller('mailController', function($scope, $http) {            $scope.guest = {};            $scope.authError = null;            $scope.send = function() {                var req = {                    method:'POST',                    url:'/mail/send',                    headers: {                        'Accept':'application/json',                        'Content-Type':'application/x-www-form-urlencoded'                    },                    data:"from=" + $scope.guest.from + '&' + "subject=" + $scope.guest.subject + '&' + "content=" + $scope.guest.content                };

Fiddler:
这里写图片描述

将提交数据格式改一下:

data:$scope.guest.serialize()

Fiddler:
这里写图片描述

request.paramter中将以
key:{“from”:”awtrmml91@163.com”,”subject”:”主题”,”content”:”正文”}
value:””
的形式出现。

后台将无法读取提交数据,这种情况下json数据解析正常:
这里写图片描述
但你需要使用content-type=application/json且后台使用@RequestBody,你无法再从paramter中获取请求数据。

选择application/x-www-form-urlencoded还是application/json,得看你是否有从request.paramter获取请求数据的需求。

阅读全文
0 0