解决maven工程中依赖漏洞问题

工程上不可避免的引入的依赖发生CVE漏洞的情况,像比较有名的log4j 1.x的远程执行漏洞,对于已知的漏洞可以使用dependency check来进行漏洞扫描,发现工程上的漏洞。本文旨在如何发现工程上的漏洞,如何解决依赖漏洞。

1、dependency check

官网 可以下载command line来执行扫描,第一次运行需要下载很多信息,时间较长(猜测是CVE相关的数据),查看帮助:

shell 复制代码
 bin/dependency-check.sh --help

扫描产出:

shell 复制代码
bin/dependency-check.sh -s /path/to/jar -o /output

2、maven依赖分析

两个命令:

查看maven工程的依赖树

shell 复制代码
mvn dependency:tree

查看具体某个依赖坐标的情况,比如查看groovy的依赖引入情况:

shell 复制代码
mvn dependency:tree -Dverbose -Dincludes=org.codehaus.groovy:groovy

这样我们能看到依赖是如何引入的,以及引入的scope,在修复完成后,也能通过这种方式来验证依赖全部修复完成。

3、处理漏洞

发现了漏洞就需要对依赖做升级或者剔除处理:

  • 升级 ,在maven中央仓库中寻找高版本,不含有CVE漏洞的,进行版本升级,版本升级有可能涉及到工程代码的变动,比如log4j1.x升级到log4j2.x配置文件会有变动,版本之间的兼容性问题需要考虑和解决。
  • 剔除,对于引入漏洞的jar包,我们可以进行定向剔除,追踪到引入漏洞的依赖,定点排除无用的jar,善用
xml 复制代码
<exclusions>
    <exclusion>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
    </exclusion>
</exclusions>
  • 剔除and升级 , 当依赖的jartransitive scopecompile来引入的,如果做简单的剔除,代码有问题,这时候可以做定向升级,做法是先进行定向排除,再单独引入高版本进行升级处理。比如:
xml 复制代码
<dependency>
    <groupId>xxxxx</groupId>
    <artifactId>xxxx</artifactId>
    <version>x.x.x</version>
    <exclusions>
        <exclusion>
            <groupId>org.apache.avro</groupId>
            <artifactId>avro</artifactId>
        </exclusion>
   </exclusions>
</dependency>

<dependency>
    <groupId>org.apache.avro</groupId>
    <artifactId>avro</artifactId>
    <version>1.11.0</version>
</dependency>
相关推荐
ZSYP-S10 分钟前
Day 15:Spring 框架基础
java·开发语言·数据结构·后端·spring
Yuan_o_1 小时前
Linux 基本使用和程序部署
java·linux·运维·服务器·数据库·后端
程序员一诺1 小时前
【Python使用】嘿马python高级进阶全体系教程第10篇:静态Web服务器-返回固定页面数据,1. 开发自己的静态Web服务器【附代码文档】
后端·python
DT辰白2 小时前
如何解决基于 Redis 的网关鉴权导致的 RESTful API 拦截问题?
后端·微服务·架构
thatway19892 小时前
AI-SoC入门:15NPU介绍
后端
陶庵看雪2 小时前
Spring Boot注解总结大全【案例详解,一眼秒懂】
java·spring boot·后端
Q_19284999063 小时前
基于Spring Boot的图书管理系统
java·spring boot·后端
ss2733 小时前
基于Springboot + vue实现的汽车资讯网站
vue.js·spring boot·后端
一只IT攻城狮3 小时前
华为云语音交互SIS的使用案例(文字转语音-详细教程)
java·后端·华为云·音频·语音识别
星月前端4 小时前
springboot中使用gdal将表中的空间数据转shapefile文件
java·spring boot·后端