复现
项目地址:https://github.com/cristianeph/vulnerability-actuator-log-viewer
下载后使用IDEA打开工程,该漏洞是由spring-boot-actuator-logview 0.2.13之前的版本导致的。 data:image/s3,"s3://crabby-images/e3340/e334025ce497621cd5798182b628ea16b1bbb7ce" alt="在这里插入图片描述" 运行项目,打开网址 data:image/s3,"s3://crabby-images/ff0a7/ff0a769589aa28c616cbc43a81ec8ed77ffa2b36" alt="在这里插入图片描述" poc如下:
http://localhost:8887/manage/log/view?filename=/etc/group&base=../../../../../../../../../../../../
验证如下: data:image/s3,"s3://crabby-images/0f373/0f37395a3bf52ef9dc19e08894bd3cfe315227d5" alt="在这里插入图片描述" 通过报错可以知道漏洞代码出发位置eu.hinsch.spring.boot.actuator.logview.LogViewEndpoint#view: data:image/s3,"s3://crabby-images/28a15/28a15b43ca153aa4af7aaf66471c4dfcd7a996b0" alt="在这里插入图片描述" 进入函数,漏洞触发主要原因是:view函数对filename参数进行合法性校验,但是没有对base参数进行合法性校验 data:image/s3,"s3://crabby-images/5f44c/5f44cb9e472e0c9360f77e178c752ed31d7b7f87" alt="在这里插入图片描述" filename的校验函数 data:image/s3,"s3://crabby-images/71b95/71b95668db1d881227572fb95c91af34558705bb" alt="在这里插入图片描述"
修复
升级到0.2.13 data:image/s3,"s3://crabby-images/9faa1/9faa1d3fb9dc5f66b29c2e4293629d889507ba2b" alt="在这里插入图片描述" 发现使用getCanonicalPath函数对跨目录符号进行了过滤
private void securityCheck(Path base, String filename) {
try {
String canonicalLoggingPath = (filename != null ? new File(base.toFile().toString(), filename) : new File(base.toFile().toString())).getCanonicalPath();
String baseCanonicalPath = (new File(this.loggingPath)).getCanonicalPath();
String errorMessage = "File " + base.toString() + "/" + filename + " may not be located outside base path " + this.loggingPath;
Assert.isTrue(canonicalLoggingPath.startsWith(baseCanonicalPath), errorMessage);
} catch (IOException var6) {
throw new IllegalStateException(var6);
}
}
|