应用接入CAS后,org.jasig.cas.client.session.SingleSignOutFilter导致request.getInputStream()取不到的问题
来源:互联网 发布:手机dpk解压软件 编辑:程序博客网 时间:2024/06/14 05:27
前台传json数据到后台,后台使用request.getInputStream()然后转字符串,
结果取不到。
------------------------
原因我知道,是退出Filter里从request取参数了,导致request流已经被解析,
流只能解析一次,所以无法再通过Stream的方式读取。
--------------------------
最后的解决方法是:
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获取请求数据的需求。
- 应用接入CAS后,org.jasig.cas.client.session.SingleSignOutFilter导致request.getInputStream()取不到的问题
- org.jasig.cas.client.session.SingleSignOutHttpSessionListener
- CAS-Client客户端研究--SingleSignOutFilter
- jasig cas 4.0 注销后还能访问应用的问题
- CAS单点登录报错 org.jasig.cas.client.util.XmlUtils 必须由匹配的结束标记
- CAS-Client客户端研究(五)-SingleSignOutFilter
- CAS部署错误1:Ticket验证异常org.jasig.cas.client.validation.TicketValidationException:
- jasig.cas客户端认证成功后ConnectionTimedout
- 解决Content-Type :application/x-www-form-urlencoded 老是request.getInputStream()取不到值的问题
- 单点登录(四)-----遇到问题-----cas server 源码部署tomcat运行报错ClassNotFoundException: org.jasig.cas.CasEnvironmentCo
- spring-session导致request.getInputStream流数据丢失问题
- Jasig cas 单点登录系统Server&Java Client配置
- Jasig cas 单点登录系统Server&Java Client配置
- Jasig cas 单点登录系统Server&Java Client配置
- jasig cas配置过程
- jasig-CAS架构
- jasig CAS客户端配置
- struts smartupload 取不到 request.getInputStream()值
- Linux 账号管理--鸟哥私房菜读书笔记
- IP地址的判断
- Python编程:从入门到实践的动手试一试答案(第九章)
- c语言:99乘法表+输出素数
- Oracle wait event --- library cache: mutex X
- 应用接入CAS后,org.jasig.cas.client.session.SingleSignOutFilter导致request.getInputStream()取不到的问题
- 1013 C基础-求偶数和 C
- 模拟赛Day1完挂记
- 环形队列各种基本运算的算法
- linux下安装mysql
- CSS盒子和文字阴影
- Bluetooth 蓝牙
- 【第二篇blog】NOIP2017C++普及组基础部分试题解析
- linux中yum源的搭建