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

 
 
   
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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值