解读若依框架中的 @Xss 注解

文章目录

  • 1. 背景与问题定义
    • 什么是 XSS 攻击?
    • XSS 的常见类型
    • 传统解决方案的局限性
  • 2. @Xss 注解详解
    • @Xss 注解源码解析
      • 注解核心要素
    • XssValidator 实现解析
      • 核心逻辑
  • 3. 应用场景
    • 场景一:表单输入校验
      • 示例代码
    • 场景二:API 接口参数校验
      • 示例代码
  • 4. 深入比较与扩展
    • 扩展思路:支持自定义校验规则
      • 示例:扩展校验器
  • 5. 案例:消息通知系统中的 XSS 防护
    • 需求
      • 实现步骤
  • 6. 总结与建议
    • 总结
    • 建议

在 Java Web 开发中,防止跨站脚本攻击(XSS)是保障系统安全的重要环节。若依框架为了应对这一问题,提供了一个自定义的 @Xss 注解,结合验证器实现了对输入数据的自动校验。本文将详细解析 @Xss 注解的实现原理、应用场景及其扩展性。


1. 背景与问题定义

什么是 XSS 攻击?

跨站脚本攻击(XSS,Cross-Site Scripting)是一种常见的 Web 安全漏洞,攻击者通过在输入字段中注入恶意脚本代码,在页面中执行这些代码,从而窃取用户信息、劫持会话等。

XSS 的常见类型

  1. 存储型 XSS:恶意脚本存储在服务器端(如数据库),其他用户访问时执行。
  2. 反射型 XSS:恶意脚本通过 URL 参数或请求发送,并立即执行。
  3. DOM 型 XSS:恶意脚本直接通过前端 JavaScript 操作 DOM 被执行。

传统解决方案的局限性

  • 手动校验:在每个输入字段中手动添加防护逻辑,容易遗漏。
  • 统一过滤器:对所有请求进行过滤,可能误杀合法输入,缺乏灵活性。

为了解决这些问题,若依框架通过 @Xss 注解实现了针对性、模块化的 XSS 校验。


2. @Xss 注解详解

@Xss 注解源码解析

@Retention(RetentionPolicy.RUNTIME)
@Target(value = { ElementType.METHOD, ElementType.FIELD, ElementType.CONSTRUCTOR, ElementType.PARAMETER })
@Constraint(validatedBy = { XssValidator.class })
public @interface Xss {
    String message() default "不允许任何脚本运行";

    Class<?>[] groups() default {};

    Class<? extends Payload>[] payload() default {};
}

注解核心要素

  • @Retention(RetentionPolicy.RUNTIME):注解在运行时可被反射读取,确保验证逻辑能够动态生效。
  • @Target({ … }):指定注解的适用范围,包括方法、字段、构造函数和方法参数。
    以上两个注解参数的相关文章:Java 注解详解:RetentionPolicy 与 ElementType
  • @Constraint(validatedBy = { XssValidator.class }):绑定验证器 XssValidator,实现注解的功能。
  • message():校验失败时返回的错误信息。
  • groups() 和 payload():用于分组校验或扩展元数据。

XssValidator 实现解析

public class XssValidator implements ConstraintValidator<Xss, String> {
    private static final String HTML_PATTERN = "<(\\S*?)[^>]*>.*?|<.*? />";

    @Override
    public boolean isValid(String value, ConstraintValidatorContext constraintValidatorContext) {
        if (StringUtils.isBlank(value)) {
            return true;
        }
        return !containsHtml(value);
    }

    public static boolean containsHtml(String value) {
        Pattern pattern = Pattern.compile(HTML_PATTERN);
        Matcher matcher = pattern.matcher(value);
        return matcher.find();
    }
}

核心逻辑

  • HTML_PATTERN:使用正则表达式匹配 HTML 标签,识别潜在的恶意脚本。
  • isValid 方法
    • 如果输入值为空,则直接通过校验。
    • 调用 containsHtml 方法,判断输入中是否存在 HTML 标签。
  • containsHtml 方法:逐字符匹配 HTML 标签,如果存在标签则返回 true

3. 应用场景

场景一:表单输入校验

在用户提交评论、反馈等场景中,避免用户通过 HTML 或 JavaScript 注入攻击。

示例代码

public class Comment {
    @Xss
    private String content;

    // Getter 和 Setter
}

场景二:API 接口参数校验

通过 @Xss 注解,防止客户端提交的 JSON 数据中包含恶意脚本。

示例代码

@PostMapping("/submit")
public AjaxResult submit(@RequestBody @Valid Comment comment) {
    return AjaxResult.success();
}

4. 深入比较与扩展

传统解决方案@Xss 注解解决方案
手动对每个字段添加校验逻辑使用注解即可实现集中校验,减少重复代码
通常依赖过滤器,对所有请求统一处理精细化校验,可按需应用到特定字段和参数
难以动态扩展可通过自定义注解和验证器扩展校验规则

扩展思路:支持自定义校验规则

假如需要对某些字段增加特定的校验规则,例如限制输入字符长度,可以扩展 XssValidator

示例:扩展校验器

public class CustomXssValidator implements ConstraintValidator<Xss, String> {
    private static final String HTML_PATTERN = "<(\\S*?)[^>]*>.*?|<.*? />";

    @Override
    public boolean isValid(String value, ConstraintValidatorContext context) {
        if (StringUtils.isBlank(value)) {
            return true;
        }
        return !containsHtml(value) && value.length() <= 100;
    }

    private boolean containsHtml(String value) {
        Pattern pattern = Pattern.compile(HTML_PATTERN);
        return pattern.matcher(value).find();
    }
}

5. 案例:消息通知系统中的 XSS 防护

需求

开发一个消息通知系统,支持用户发布消息并允许其他用户评论。需要确保消息内容和评论字段不包含恶意脚本。

实现步骤

  1. 数据库设计

    • message 表:保存消息标题和内容。
    • comment 表:保存评论内容及其关联的消息 ID。
  2. 实体类

    public class Message {
        private Long id;
    
        @Xss
        private String title;
    
        @Xss
        private String content;
    
        // Getter 和 Setter
    }
    
    public class Comment {
        private Long id;
    
        @Xss
        private String content;
    
        private Long messageId;
    
        // Getter 和 Setter
    }
    
  3. 接口开发

    @RestController
    @RequestMapping("/messages")
    public class MessageController {
    
        @PostMapping("/publish")
        public AjaxResult publishMessage(@RequestBody @Valid Message message) {
            // 保存消息
            return AjaxResult.success();
        }
    
        @PostMapping("/comment")
        public AjaxResult addComment(@RequestBody @Valid Comment comment) {
            // 保存评论
            return AjaxResult.success();
        }
    }
    

6. 总结与建议

总结

  • @Xss 注解通过结合验证器提供了高效的 XSS 防护机制。
  • 其模块化设计符合 Java 开发最佳实践,便于代码复用和扩展。
  • 在实际应用中,可灵活扩展校验逻辑以适应不同业务场景。

建议

  1. 正则优化:当前的正则表达式对 HTML 标签的匹配存在误判可能性,可结合 HTML 解析库(如 Jsoup)增强准确性。
  2. 性能考量:在高并发场景中,大量正则匹配可能影响性能,需结合具体业务进行优化。
  3. 整体安全方案:@Xss 注解是输入防护的一部分,还需要结合 CSP(内容安全策略)等前端防护手段,实现全方位的安全保障。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/950655.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Linux】shell脚本编程

目录 概念&#xff1a; shell脚本的本质&#xff1a; shell脚本编程&#xff1a; shell变量&#xff1a; 变量的定义格式&#xff1a; 变量的分类 自定义变量&#xff1a; 环境变量&#xff1a; 命令变量与命令行参数&#xff1a; 预定义变量&#xff1a; shell中的…

Onedrive精神分裂怎么办(有变更却不同步)

Onedrive有时候会分裂&#xff0c;你在本地删除文件&#xff0c;并没有同步到云端&#xff0c;但是本地却显示同步成功。 比如删掉了一个目录&#xff0c;在本地看已经删掉&#xff0c;onedrive显示已同步&#xff0c;但是别的电脑并不会同步到这个删除操作&#xff0c;在网页版…

CSS——1.优缺点

<!DOCTYPE html> <html><head><meta charset"UTF-8"><title></title><link rel"stylesheet" type"text/css" href"1-02.css"/></head><body><!--css&#xff1a;层叠样式表…

软件23种设计模式完整版[附Java版示例代码]

一、什么是设计模式 设计模式是在软件设计中反复出现的问题的通用解决方案。它们是经过多次验证和应用的指导原则,旨在帮助软件开发人员解决特定类型的问题,提高代码的可维护性、可扩展性和重用性。 设计模式是一种抽象化的思维方式,可以帮助开发人员更好地组织和设计他们…

(2023|NIPS,LLaVA-Med,生物医学 VLM,GPT-4 生成自指导指令跟随数据集,数据对齐,指令调优)

LLaVA-Med: Training a Large Language-and-Vision Assistant for Biomedicine in One Day 目录 LLaVA-Med: Training a Large Language-and-Vision Assistant for Biomedicine in One Day 0. 摘要 1. 简介 2. 相关工作 3. 生物医学视觉指令数据 4. 将多模态对话模型适配…

深入理解Mybatis原理》MyBatis的sqlSessi

sqlSessionFactory 与 SqlSession 正如其名&#xff0c;Sqlsession对应着一次数据库会话。由于数据库会话不是永久的&#xff0c;因此Sqlsession的生命周期也不应该是永久的&#xff0c;相反&#xff0c;在你每次访问数据库时都需要创建它&#xff08;当然并不是说在Sqlsession…

Numpy数组的属性

NumPy中最重要的一个特点就是其n维数组对象&#xff0c;即ndarray(别名array)对象&#xff0c;该对象具有矢量算术能力和复杂的广播能力&#xff0c;可以执行一些科学计算。不同于Python内置的数组类型&#xff0c; array对象拥有对高维数组的处理能力&#xff0c;这也是数值计…

(十)提示词任务分解的策略探讨

&#x1f4e2;&#x1f4e2;&#x1f4e2; 大家好&#xff0c;我是云楼Yunlord&#xff0c;CSDN博客之星人工智能领域前三名&#xff0c;多年人工智能学习工作经验&#xff0c;一位兴趣稀奇古怪的【人工智能领域博主】&#xff01;&#xff01;&#xff01;&#x1f61c;&#…

01 数据分析介绍及工具准备

数据分析介绍及工具准备 一、工具准备二、下载和使用Anaconda三、jupyter notebook常用快捷键 一、工具准备 数据科学库 NumPy&#xff0c;SciPy&#xff0c;Pandas&#xff0c;Scikit-Learn 数据可视化库 Matplotlib&#xff0c;Seaborn 编译器 Jupyter Notebook 数据科…

excel表格二维X、Y坐标散点图

excel中存在两列或两行数据&#xff0c;分别表示x坐标和对应的y坐标&#xff0c;同时选中两列或两行数据&#xff1a; 依次选择菜单&#xff0c;插入&#xff0c;图标&#xff0c;XY散点图 可以看到在表格中生成了以第1列为X轴&#xff0c;第2列为Y轴的二维XY散点图&#xff…

Cursor无限续杯——解决Too many free trials.

前情提要 我们都知道Cursor对新用户是有14天且500条免费限制的。 一般情况下&#xff0c;当14天过期&#xff0c;是可以注销账户再重新注册&#xff0c;这样就可以继续拥有14天的体验时长。 但是&#xff01;&#xff01;如果使用超过500次&#xff0c;Cusor就会把你的电脑I…

HCIE-day10-ISIS

ISIS ISIS&#xff08;Intermediate System-to-Intermediate System&#xff09;中间系统到中间系统&#xff0c;属于IGP&#xff08;内部网关协议&#xff09;&#xff1b;是一种链路状态协议&#xff0c;使用最短路径优先SPF算法进行路由计算&#xff0c;与ospf协议有很多相…

洛谷P1617———数字转英文

题目如下 思路&#xff1a;将1~9的英文和20~90的英文用字符串数组存储&#xff0c;把下标看作对应的数字进行输出&#xff0c;遇到0或连续多个0就输出“and”&#xff0c;定义l用来看枚举到哪一位了&#xff0c;如果是单独输入一个“0”&#xff0c;则直接输出zero然后结束。否…

UnityRenderStreaming使用记录(五)

UnityRenderStreaming不一样的错误&#xff0c;船新的版本 继续docker部署UnityRenderStreamingdockerfile一些命令出现了新的错误先解决一个报错不知道怎么解决&#xff0c;先跑个glxgears测试一下先解决MESA和glx的问题新的log&#xff0c;额新的错误尝试解决libnvidia-encod…

Unity-Mirror网络框架-从入门到精通之AdditiveScenes 示例

文章目录 前言Additive Levels和Additive ScenesAdditive Levels场景介绍Portal传送门FadeInOut特效 Additive Scenes示例介绍ZoneHandlerSceneMassage 最后 前言 在现代游戏开发中&#xff0c;网络功能日益成为提升游戏体验的关键组成部分。Mirror是一个用于Unity的开源网络框…

Mac-docker配置

1.配置的文件路径 cd ~/.docker (base) zhangyaweimacbookair .docker % ls buildx cli-plugins config.json contexts daemon.json desktop-build mutagen run (base) zhangyaweimacbookair .docker % cat daemon.json## 重启docker服务 sudo systemctl daemon-reload sudo…

PHP进阶-在Ubuntu上搭建LAMP环境教程

本文将为您提供一个在Ubuntu服务器上搭建LAMP&#xff08;Linux, Apache, MySQL, PHP&#xff09;环境的完整指南。通过本文&#xff0c;您将学习如何安装和配置Apache、MySQL、PHP&#xff0c;并将您的PHP项目部署到服务器上。本文适用于Ubuntu 20.04及更高版本。 一、系统更新…

Elasticsearch(看这一篇就够了)

目录&#xff1a; Elasticsearch介绍正排索引和倒排索引Elasticsearch安装安装ES服务安装服务安装kibana 索引操作创建索引查询索引库修改索引库删除索引库 Elasticsearch常用操作文档操作新增文档查询文档删除文档根据id批量查询文档查询所有文档修改文档部分字段 域的属性分词…

嵌入式技术之Linux(Ubuntu) 一

一、Linux入门 1.硬件和操作系统以及用户的关系 一个传感器&#xff0c;获得数据后&#xff0c;需要向服务器发送数据。传感器传数据给上位机。 上位机需要一个程序来接收数据&#xff0c;那么这个上位机是什么机器&#xff1f; 我们的笔记本电脑就可以当成上位机。 两个手…

【实用技能】如何使用 .NET C# 中的 Azure Key Vault 中的 PFX 证书对 PDF 文档进行签名

TX Text Control 是一款功能类似于 MS Word 的文字处理控件&#xff0c;包括文档创建、编辑、打印、邮件合并、格式转换、拆分合并、导入导出、批量生成等功能。广泛应用于企业文档管理&#xff0c;网站内容发布&#xff0c;电子病历中病案模板创建、病历书写、修改历史、连续打…