cas3.5.2客户端配置

本文详细介绍了如何在客户端项目中配置cas,包括引入cas-client-core-3.2.1.jar依赖,修改web.xml文件以集成cas认证,创建index.jsp页面以展示认证信息,以及如何实现登录和登出操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值