情况如下:我们的一个项目要做为子系统集成到已有的门户当中去,其中就有CAS的单点登录功能。我们这边的链接转到集成商那里,登录后,然后再转回来,会带有登录的用户名信息,这个信息用CASClientUtils.getLoginName(request);方法获取,调试是没有问题的,我本机,包括公司的windows server 2003上测试全部通过。可到了现场之后,问题出来了,获取不到登录的用户名,直接引起我们整个系统不能访问。问题很严重,找了一天,从软件代码上没有找出任何问题,因为我们在我本地及公司的2003服务器上反复测试是没有问题的,可一到用户的2008 server上,就会出现上述问题各位有没有人遇到过类似的问题?或者知道是否在2008 server上需要有什么特殊的配置?如能解决,不胜感激

解决方案 »

  1.   

    客户端的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> 获取方法struts2   你也可以写到filter里来获取
    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(); 
                
    }
    可能帮不上太多忙、ps:csdn为什么不能插入xml的代码了呢,以前是能的喔、
      

  2.   

    CASClientUtils.getLoginName(request);
    转发的问题?
    会不会是浏览器的问题?
    浏览器禁用cookie了?或者其他设置?兼容问题?