CAS的service参数验证

CAS登录成功后会跳转到service参数提供的url,目前系统中这个参数是没有任何验证的,service参数随便赋一个网址就可以。为安全起见现在对这个service要作一下限制,比如只能是同源url才可以重定向。

下面是基于CAS 3.5.2对系统的改造过程。

系统比较老旧,之前也作过CAS方面的改造,基本思路是从login-webflow.xml中找到切入点,查看源代码,然后在配置文件中把相关的bean替换掉。具体分析过程这里不再赘述。

在argumentExtractorsConfiguration.xml中有

 <util:list id="argumentExtractors">
    <ref bean="casArgumentExtractor" />
    <ref bean="samlArgumentExtractor" />
 </util:list>

把casArgumentExtractor替换成customArgumentExtractor。上面那个配置文件里再加上

<bean id="customArgumentExtractor"
   class="org.jasig.cas.web.support.CustomArgumentExtractor"
     p:httpClient-ref="noRedirectHttpClient"
     p:disableSingleSignOut="${slo.callbacks.disabled:false}" />

这个customArgumentExtractor就是要自己新写的。代码很简单,里面只有一个方法

public final class CustomArgumentExtractor extends AbstractSingleSignOutEnabledArgumentExtractor{

    public WebApplicationService extractServiceInternal(HttpServletRequest request) {
        return CustomWebApplicationServiceImpl.createServiceFrom(request,getHttpClientIfSingleSignOutEnabled());
    }
}

CustomWebApplicationServiceImpl也是要自己写的,基于cas-server-core-3.5.2.jar里的SimpleWebApplicationServiceImpl上修改。

在里面的createServiceFrom方法加上验证即可

    public static CustomWebApplicationServiceImpl createServiceFrom(
            final HttpServletRequest request, final HttpClient httpClient)  {
        final String targetService = request
                .getParameter(CONST_PARAM_TARGET_SERVICE);
        final String method = request.getParameter(CONST_PARAM_METHOD);
        final String serviceToUse = StringUtils.hasText(targetService)
                ? targetService : request.getParameter(CONST_PARAM_SERVICE);

        if (!StringUtils.hasText(serviceToUse)) {
            return null;
        }

        //新加的service同host验证---------------
        try {
            URI url = new URI(serviceToUse);
            if (!host.equals(url.getHost())){ 
                return null;
            }
        } catch (URISyntaxException e) {
            return null;
        }
        //---------------验证结束

        final String id = cleanupUrl(serviceToUse);
        final String artifactId = request.getParameter(CONST_PARAM_TICKET);

        return new CustomWebApplicationServiceImpl(id, serviceToUse,
                artifactId, "POST".equals(method) ? Response.ResponseType.POST
                : Response.ResponseType.REDIRECT, httpClient);
    }

上面的host是配置文件里读的当前系统的域名。这里可以加自己的其他验证逻辑,比如二级子目录、通配符域名或者白名单列表。

 

最后还要修改一个地方,在uniqueIdGenerators.xml里

    <util:map id="uniqueIdGeneratorsMap">
        <entry
            key="org.jasig.cas.authentication.principal.SimpleWebApplicationServiceImpl"
            value-ref="serviceTicketUniqueIdGenerator" />
        <entry
            key="org.jasig.cas.support.openid.authentication.principal.OpenIdService"
            value-ref="serviceTicketUniqueIdGenerator" />
......

把SimpleWebApplicationServiceImpl换成CustomWebApplicationServiceImpl。

 

这样修改之后,当service参数的url跟你配置的域名不一致时,等同于service为null,即未配置。在我的系统里会跳转到一个只是简单提示登录成功的jsp页面。

 

原文链接:https://www.cnblogs.com/lichdr/p/17346151.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:CAS的service参数验证 - Python技术站

(0)
上一篇 2023年4月23日
下一篇 2023年4月23日

相关文章

  • struts2.2.3+spring3.1.0+mybatis3.1.0框架整合集成简单demo

    下面详细讲解“struts2.2.3+spring3.1.0+mybatis3.1.0框架整合集成简单demo”的完整攻略。 一、环境配置 下载并安装Java、Tomcat和MySQL; 搭建好Java和Tomcat的环境,配置好MySQL数据库。 二、搭建Struts2框架 创建Maven项目,引入Struts2的依赖,具体如下: <dependen…

    Java 2023年5月20日
    00
  • Apache log4j2-RCE 漏洞复现及修复建议(CVE-2021-44228)

    首先我们来简单介绍一下这个漏洞。 Apache log4j2是一款Java日志框架,它可以帮助开发者进行应用程序日志的记录和管理。CVE-2021-44228是Apache log4j2存在的一种远程代码执行漏洞,攻击者通过恶意构造log4j格式的请求,可以在服务器上执行任意代码,从而造成严重后果。 下面我们来具体讲解一下如何复现这个漏洞,并提供修复建议。 …

    Java 2023年6月2日
    00
  • JavaSpringBoot报错“PessimisticLockingFailureException”的原因和处理方法

    当使用Java的Spring Boot框架时,可能会遇到“OptimisticLockingFailureException”和“PessimisticLockingFailureException”错误。这些错误通常是由以下原因之一引起的: 乐观锁或悲观锁失败:如果使用乐观锁或悲观锁时失败,则可能会出现这些错误。在这种情况下,需要查找锁失败的原因并解决它。…

    Java 2023年5月5日
    00
  • springboot整合dubbo设置全局唯一ID进行日志追踪的示例代码

    下面就是 “springboot整合dubbo设置全局唯一ID进行日志追踪的示例代码” 的详细攻略。 先了解基本概念 在介绍示例代码之前,先了解一下基本概念,有助于更好地理解实现过程: Dubbo:一种高性能、轻量级的远程服务框架,支持 RPC 协议和多种注册中心。 TraceId:一条调用链路的唯一标识,常用于日志追踪,用于串联业务流程的各个步骤。 MDC…

    Java 2023年5月20日
    00
  • 理解Java面向对象编程设计

    理解Java面向对象编程设计的完整攻略 1. 理解什么是面向对象编程设计 面向对象编程设计(Object-Oriented Programming,OOP)是一种软件开发范式,基于对象的概念进行编程。其重点在于数据和行为的封装,通过封装来降低耦合度。面向对象的语言中,一切皆为对象。通过对象的封装、继承、多态等特性,编写出高效、灵活、可维护的程序。 2. Ja…

    Java 2023年5月30日
    00
  • 基于Java实现简单贪吃蛇游戏

    基于Java实现简单贪吃蛇游戏攻略 介绍 贪吃蛇作为一款经典的小游戏,一直受到人们的喜爱,同时也成为了学习编程的入门练手项目。通过这个项目,我们可以了解到Java中关于图形界面、面向对象编程等方面的知识。 实现步骤 设计UI界面:在Java中,常见的UI界面框架有Swing和JavaFX,本项目采用Swing实现。 编写贪吃蛇的逻辑:蛇的移动、食物的随机生成…

    Java 2023年5月26日
    00
  • Java 数据结构与算法系列精讲之字符串暴力匹配

    Java 数据结构与算法系列精讲之字符串暴力匹配 1. 基本概念 字符串匹配是一种非常常见的算法问题。给定一个字符串 A 和一个模式串 B,要求在字符串 A 中查找是否有 B 出现的位置,如果有,则返回第一次出现的位置,否则返回-1。字符串暴力匹配就是一种解决此问题的算法,它的基本思路就是从字符串 A 中从头开始一个字符一个字符地去匹配模式串 B 的每个字符…

    Java 2023年5月19日
    00
  • Mybatis中的Criteria条件查询方式

    Mybatis中的Criteria条件查询方式是一种高级的查询方式,它允许我们通过代码生成复杂的SQL查询语句,提高查询效率。下面是详细的攻略: 什么是Criteria条件查询方式 Criteria是Mybatis中提供的一种用于生成SQL语句的API。使用它可以构建复杂的查询语句,支持动态参数和多条件查询,可以避免手写SQL语句的繁琐和可能引发的SQL注入…

    Java 2023年5月20日
    00
合作推广
合作推广
分享本页
返回顶部