cas搭建之客户端搭建

 1、添加客户端到你的项目中

Maven的pom.xml配置中添加

           <dependency>

              <groupId>org.jasig.cas.client</groupId>

              <artifactId>cas-client-core</artifactId>

              <version>3.3.3</version>

           </dependency>

           <dependency>

              <groupId>commons-logging</groupId>

              <artifactId>commons-logging</artifactId>

              <version>1.2</version>

           </dependency>

Webapp所在工程的pom.xml中添加

       <dependency>

           <groupId>org.jasig.cas.client</groupId>

           <artifactId>cas-client-core</artifactId>

       </dependency>

       <dependency>

           <groupId>commons-logging</groupId>

           <artifactId>commons-logging</artifactId>

       </dependency>

2、在客户端项目的web.xml配置过滤器

添加

<!-- ======================== 单点登录开始 ======================== -->

    <!-- 用于单点退出,该过滤器用于实现单点登出功能,可选配置 -->

    <listener>

       <listener-class>org.jasig.cas.client.session.SingleSignOutHttpSessionListener</listener-class>

    </listener>

 

    <!-- 该过滤器用于实现单点登出功能,可选配置。 -->

    <filter>

       <filter-name>CAS Single Sign Out Filter</filter-name>

       <filter-class>org.jasig.cas.client.session.SingleSignOutFilter</filter-class>

    </filter>

    <filter-mapping>

       <filter-name>CAS Single Sign Out Filter</filter-name>

       <url-pattern>/*</url-pattern>

    </filter-mapping>

 

    <!-- 该过滤器负责用户的认证工作,必须启用它 -->

    <filter>

       <filter-name>CASFilter</filter-name>

       <filter-class>org.jasig.cas.client.authentication.AuthenticationFilter</filter-class>

       <init-param>

           <param-name>casServerLoginUrl</param-name>

           <param-value>https://www.yunhetong.com:8443/cas/login</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>CASFilter</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://www.yunhetong.com:8443/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>

 

    <!-- 该过滤器负责实现HttpServletRequest请求的包裹,比如允许开发者通过HttpServletRequestgetRemoteUser()方法获得SSO登录用户的登录名,可选配置。 -->

    <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>

 

    <!-- 该过滤器使得开发者可以通过org.jasig.cas.client.util.AssertionHolder来获取用户的登录名。比如AssertionHolder.getAssertion().getPrincipal().getName()

       <filter>-->

    <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>

    <!-- ======================== 单点登录结束 ======================== -->

代码重新编译发布后,访问原先地址http://www.yunhetong.com:7777/resource

自动跳转到cas单点登录的界面


输入用户名和密码后自动跳转回需要访问的界面

 

        

五、本地测试

需要上linux系统上把/home/java/keys/demo.crt文件拷贝到本地,然后倒入到本地的jre中才能进行运行

猜你喜欢

转载自blog.csdn.net/cailianren1/article/details/46457633