求教windows 2008 server下CAS单点登录问题,看者有分
情况如下:
我们的一个项目要做为子系统集成到已有的门户当中去,其中就有CAS的单点登录功能。
我们这边的链接转到集成商那里,登录后,然后再转回来,会带有登录的用户名信息,这个信息用CASClientUtils.getLoginName(request);方法获取,调试是没有问题的,我本机,包括公司的windows server 2003上测试全部通过。
可到了现场之后,问题出来了,获取不到登录的用户名,直接引起我们整个系统不能访问。
问题很严重,找了一天,从软件代码上没有找出任何问题,因为我们在我本地及公司的2003服务器上反复测试是没有问题的,可一到用户的2008 server上,就会出现上述问题
各位有没有人遇到过类似的问题?或者知道是否在2008 server上需要有什么特殊的配置?
如能解决,不胜感激
[最优解释]
这个问题倒没遇到过。 没人用2008 部署。
关注一下。
[其他解释]
客户端的jdk版本和你测试的jdk版本一样吗?
生产环境和测试环境一样吗?要尽量保持一样、
CASClientUtils.getLoginName(request);
这个是yalu大学那个cas 版本吗?
cas 2.+ yalu 的不太清楚
若是cas 3.+ jasig的话
需要在client 端web.xml配置信息
<filter>
<filter-name>CAS Assertion Thread Local Filter</filter-name>
<filter-class>org.jasig.cas.client.util.AssertionThreadLocalFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>CAS Assertion Thread Local Filter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
HttpSession sessions = ServletActionContext.getRequest().getSession();
Object object = sessions.getAttribute("_const_cas_assertion_");
if(object != null){
AttributePrincipal principal = (AttributePrincipal)ServletActionContext.getRequest().getUserPrincipal();
String username = principal.getName();
}