《5分钟配置cas3.5.2+tomcat7》配置了服务器端,这节课我们来了解客户端的配置。服务器端是指运行cas的web服务器,客户端是指使用cas进行身份认证的项目。
一、cas-client-core-3.2.1.jar
根据《5分钟配置cas3.5.2+tomcat7》配置好服务器端后,运行部署cas的tomcatweb服务器,找到cas/WEB-INF/lib/cas-client-core-3.2.1.jar,这个jar需要放到客户端项目的lib中。
二、新建一个客户端项目
1、新建一个web项目(mycas),将cas-client-core-3.2.1.jar拷贝到/WEB-INF/lib中
2、修改web.xml配置文件,添加如下信息:
<!-- 配置单点退出。如果此处不配置,不能单点退出,并且要放到所有过滤器的最前面 --> <listener> <listener-class>org.jasig.cas.client.session.SingleSignOutHttpSessionListener</listener-class> </listener> <filter> <filter-name>SingleSignOutFilter</filter-name> <filter-class>org.jasig.cas.client.session.SingleSignOutFilter</filter-class> </filter> <filter-mapping> <filter-name>SingleSignOutFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!-- cas过滤器 --> <filter> <filter-name>CAS Authentication Filter</filter-name> <filter-class>org.jasig.cas.client.authentication.AuthenticationFilter</filter-class> <init-param> <param-name>casServerLoginUrl</param-name> <param-value>https://login.luoshengsha.com/cas/login</param-value><!--此处配置cas服务器端的登录地址--> </init-param> <init-param> <param-name>serverName</param-name> <param-value>http://localhost:8080</param-value><!-- 此处配置客户端地址(即项目访问地址) --> </init-param> </filter> <filter-mapping> <filter-name>CAS Authentication Filter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!-- ticket过滤器 --> <filter> <filter-name>CAS Validation Filter</filter-name> <filter-class> org.jasig.cas.client.validation.Cas20ProxyReceivingTicketValidationFilter </filter-class> <init-param> <param-name>casServerUrlPrefix</param-name> <param-value>https://login.luoshengsha.com/cas</param-value> </init-param> <init-param> <param-name>serverName</param-name> <param-value>http://localhost:8080</param-value> </init-param> </filter> <filter-mapping> <filter-name>CAS Validation Filter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!--允许cas包裹HttpServletRequest,客户端就可以使用getRemoteUser和getPrincipal获取到服务器端返回的相关信息--> <filter> <filter-name>CAS HttpServletRequest Wrapper Filter</filter-name> <filter-class> org.jasig.cas.client.util.HttpServletRequestWrapperFilter </filter-class> </filter> <filter-mapping> <filter-name>CAS HttpServletRequest Wrapper Filter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
3、创建一个index.jsp,内容如下:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ page import="org.jasig.cas.client.authentication.*" %> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <% AttributePrincipal principal = (AttributePrincipal) request.getUserPrincipal(); String username = principal.getName(); %>
第一种获取用户名:<%=principal %>
<br>第二种获取用户名:<%=username%> </body> </html>
4、启动tomcat
(1)、启动服务器端tomcat(即部署cas的tomcat)
(2)、将以上创建的项目(mycas)放至一个新的tomcat(客户端)中,启动客户端tomcat。
(3)、在地址栏中输入:http://localhost:8080/mycas/index.jsp,此时项目会跳转到服务器端cas,要求输入用户名和密码,如图:
(4)、输入用户名和密码(都是admin),服务器端验证通过后跳回至客户端的index.jsp页面,显示如下:
5、退出登录
如果你想退出登录,可以访问:http://login.luoshengsha.com/cas/logout,当你重新访问http://localhost:8080/mycas/index.jsp,客户端又会跳转至服务器端重新进行登录。
至此,cas客户端的配置就已结束!!!
参考资料:https://wiki.jasig.org/display/CASC/Configuring+the+Jasig+CAS+Client+for+Java+in+the+web.xml
本文出自 luoshengsha.com,欢迎转载,转载时请注明出处及相应链接。
本文永久链接: http://www.luoshengsha.com/438.html