当前位置: 首页 > news >正文

大型企业网站建设制作口碑营销案例及分析

大型企业网站建设制作,口碑营销案例及分析,博客类网站怎么做,短视频seo系统1、EL注入简介 Expression Language Injection (EL注入)是一种安全漏洞,攻击者能够注入并执行恶意的EL表达式,导致服务器端代码执行、敏感信息泄露或服务拒绝等安全问题。在Java EE环境中,特别是使用JSP(JavaServer Pages&#x…

1、EL注入简介

Expression Language Injection (EL注入)是一种安全漏洞,攻击者能够注入并执行恶意的EL表达式,导致服务器端代码执行、敏感信息泄露或服务拒绝等安全问题。在Java EE环境中,特别是使用JSP(JavaServer Pages)技术的应用程序中,EL用于简化页面逻辑处理和数据展示。如果未正确处理用户输入,攻击者可以通过构造恶意输入来执行任意代码或者访问敏感信息。

EL注入的工作原理类似于其他注入攻击:

1、应用程序接收用户输入

2、未经验证或转义就将用户输入作为EL表达式处理

3、服务器解析并执行这些表达式,可能导致恶意操作

2、攻击原理

2.1、EL 表达式的解析

在 buildConstraintViolationWithTemplate 中,${...} 是一种表达式语言(EL)语法,Hibernate Validator 默认会解析这些表达式。

如果用户输入的内容直接被嵌入到错误消息模板中,并且没有经过适当的清理或转义,攻击者可以通过构造恶意输入来执行任意 EL 表达式。

2.2、潜在风险

  1. 攻击者可以利用 EL 表达式访问系统对象(如环境变量、文件系统等),甚至执行任意代码。
  2. 这种漏洞可能导致信息泄露、权限提升或其他严重后果。

2.3、示例攻击

假设某个字段允许用户输入值,并且该值直接被插入到错误消息模板中:

@Overridepublic boolean isValid(String value, ConstraintValidatorContext context) {if (value == null || value.isEmpty()) {context.disableDefaultConstraintViolation(); context.buildConstraintViolationWithTemplate("Invalid value: ${validatedValue}")               .addConstraintViolation();        return false;    }    return true;
}

如果用户输入如下内容:

${T(java.lang.Runtime).getRuntime().exec('rm -rf /')}

当 EL 表达式被解析时,这将尝试执行系统命令 rm -rf /,从而导致严重的安全问题。

3、Spring 中易导致EL注入的API

以下Spring框架中的API容易导致EL注入问题:

1、Spring Expression Language (SpEL)

  1. SpelExpressionParserEvaluationContext ConstraintValidatorContext 相关方法(如:buildConstraintViolationWithTemplate),这些类用于解析和评估Spring表达式语言(SpEL),如果开发者不谨慎处理用户输入,就可能存在注入风险。
  2. @Value 注解中使用SpEL表达式,在Spring配置类或组件中使用@Value注解时,如果值来源于不可信来源且包含SpEL表达式,则可能导致安全问题。

2、JSP EL表达式

在JSP页面中直接使用 ${userInput}

3、Spring MVC 视图层

Thymeleaf、FreeMarker等模板引擎中不安全的表达式处理Spring Boot默认支持Thymeleaf作为视图层技术,虽然Thymeleaf默认是安全的,但如果启用了不安全的特性或错误地配置了模板引擎,仍有可能导致类似的注入问题。

4、Spring Data查询

使用SpEL的 @Query 注解

4、EL注入的解决方案

为了避免这种攻击,可以采取以下措施:

1 禁用 EL 表达式解析
  • Hibernate Validator 允许通过配置禁用 EL 表达式的解析。这是最直接和推荐的方法。 
  • 设置系统属性 hibernate.validator.el.enabled 为 false
  • System.setProperty("hibernate.validator.el.enabled", "false");
  • 在 Spring Boot 应用中,通过 application.properties 配置:
spring.jpa.properties.hibernate.validator.el.enabled=false

2、避免直接使用用户输入作为模板内容

不要直接将用户输入嵌入到错误消息模板中。可以通过硬编码模板或对用户输入进行严格的验证和清理来避免问题。

@Overridepublic boolean isValid(String userInput, ConstraintValidatorContext context) { if (!isValidLogic(userInput)) {        String safeMessage = "Invalid input"; // 使用固定的错误消息        context.disableDefaultConstraintViolation();context.buildConstraintViolationWithTemplate(safeMessage).addConstraintViolation();        return false;    }    
return true;
}

3、使用占位符而非 EL 表达式

  • 如果需要动态生成错误消息,可以使用占位符(如 {0}),并通过参数化的方式传递值,而不是依赖 EL 表达式。
@Overridepublic boolean isValid(String userInput, ConstraintValidatorContext context) {if (!isValidLogic(userInput)) {        context.disableDefaultConstraintViolation();context.buildConstraintViolationWithTemplate("Invalid input: {0}") .addPropertyNode("fieldName").addConstraintViolation();        return false;    }    return true;
}

4、升级到最新版本 

    • 确保使用的 Hibernate Validator 和相关库是最新版本,因为较新的版本可能已经修复了已知的安全漏洞。

    5、输入验证与过滤

      • 对所有用户输入进行严格的验证。
      • 过滤或转义EL表达式特殊字符如 ${}, #, T(), new 等

      6、使用安全的API配置

        // 使用SimpleEvaluationContext代替StandardEvaluationContextEvaluationContext context = SimpleEvaluationContext.forReadOnlyDataBinding().build();

        5、总结

        • 风险点
          • buildConstraintViolationWithTemplate 方法默认支持 EL 表达式解析,如果用户输入被直接嵌入到模板中,可能导致 EL 注入攻击。
        • 解决方案
          1. 禁用 EL 表达式解析(推荐)。
          2. 避免直接使用用户输入作为模板内容。
          3. 使用占位符或硬编码的错误消息。
          4. 升级到最新的 Hibernate Validator 版本。
          5. 输入验证与过滤
          6. 使用安全的API配置

        通过采取上述措施,可以有效防止 buildConstraintViolationWithTemplate 导致的 EL 注入攻击,确保应用程序的安全性。

        http://www.lryc.cn/news/616944.html

        相关文章:

      1. 我想投资谁有项目台州关键词首页优化
      2. 东莞网站建设定制下载百度app并安装
      3. 哈尔滨市建筑企业管理站网站优化是什么
      4. 专做视频和ppt的网站南京网站推广排名
      5. 做个网站得多少钱制作一个简单的网站
      6. 做网络竞拍的网站需要什么seo怎么学在哪里学
      7. 网站建设的行业市场的特点百度广告服务商
      8. 小说网站开发的实际意义手机软文广告300字
      9. 工商网站查询企业谷歌浏览器官方app下载
      10. 建立个机密网站nba哈登最新消息
      11. 表情包做旧网站河北seo关键词排名优化
      12. 福田网站建设价格韩国搜索引擎排名
      13. 镇江做网站要多少钱长沙网站定制公司
      14. 盐城网站开发建设宣传推广计划
      15. 深圳制作网站制作公司哪家好做任务赚佣金一单10块
      16. 网站网络推广运营山东seo推广
      17. 广州网站建设电话优化营商环境应当坚持什么原则
      18. 女人动漫做受网站seo快速优化
      19. 人力资源做网站的好处站长统计推荐
      20. 表格制作excel基础教学武汉网络优化知名乐云seo
      21. 如何建立和设计公司网站作文推广手段有哪些
      22. 咸阳网站建设哪家好网络营销企业案例分析
      23. 快普网站怎么做采购退货今天国际新闻大事
      24. 绍兴建站模板系统宁波网络优化seo
      25. 网站建设普票seo站内优化教程
      26. 上传网站工具模板建站网页
      27. 自己可以做网站优化大师免费下载
      28. 武汉给政府做网站的公司如何创建个人网站免费
      29. 苏州网站建设建站网交换友情链接的方法
      30. beego做网站网上在线看视频为什么卡