#知识点
1、安全开发-JavaEE-常见依赖-Actuator&Swagger
2、安全开发-JavaEE-安全问题-配置安全&接口测试
#开发框架-SpringBoot
参考:https://springdoc.cn/spring-boot/
data:image/s3,"s3://crabby-images/7774d/7774d145e4db9952a94fed630832d2b0f00d4ca2" alt=""
一、SpringBoot-监控依赖-Actuator
SpringBoot Actuator模块提供了生产级别的功能,比如健康检查,审计,指标收集,HTTP跟踪等,帮助我们监控和管理Spring Boot应用。
1、开发使用:
①引入依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
data:image/s3,"s3://crabby-images/75864/7586452f4e67570a223618dcaccf9194b80af783" alt=""
data:image/s3,"s3://crabby-images/27c7e/27c7ee061331fe3985ea25326a10ad7ae2d13d1e" alt=""
②配置监控
#暴露
暴露基于->application.properties文件
management.endpoints.web.exposure.include=* ->所有的都暴露
data:image/s3,"s3://crabby-images/f3e6e/f3e6e79fdb9218ddcdd3383269a323ff9326807b" alt=""
data:image/s3,"s3://crabby-images/ed263/ed2634368488f69c7f28086ee914ec544361da17" alt=""
data:image/s3,"s3://crabby-images/f07ea/f07ea3800ae9df8a440d421d755b31a68c30a862" alt=""
data:image/s3,"s3://crabby-images/60ebd/60ebdb5ed7ee3bc74f01546769bec9e516ebb540" alt=""
暴露基于->application.yml文件(该文件和上面的application.properties文件效果一样,看具体的项目里面是哪一个文件用来进行actuator进行监控配置)
management:
endpoints:
web:
exposure:
include: '*'
#安全配置: ->配置后,可以使上面的暴露的文件被有效控制住,不会所有的都暴露
安全配置基于->application.propertie文件
management.endpoints.jmx.exposure.include=health
management.endpoints.web.exposure.include=health
data:image/s3,"s3://crabby-images/979be/979be3ceee3333ee42317414022e0297ff183cdd" alt=""
data:image/s3,"s3://crabby-images/38eb3/38eb307ddc5f8b3fdf51455612126bef61fca5af" alt=""
data:image/s3,"s3://crabby-images/6cd45/6cd45524225b3ea451d77f186f6f22d8a5d2fc3c" alt=""
management.endpoint.env.enabled=false ->env不暴露
management.endpoint.heapdump.enabled=false ->headdump不暴露
data:image/s3,"s3://crabby-images/e205e/e205e8b18276ea20049af78ee524116279aa1e25" alt=""
安全配置基于->application.yml文件
management:
endpoint:
heapdump:
enabled: false #启用接口关闭
env:
enabled: false #启用接口关闭
2、 图像化Server&Client端界面
Server:引入Server依赖-开启(@EnableAdminServer)
data:image/s3,"s3://crabby-images/caab6/caab6c04be989ec6108954643c7b56b0f2987c6b" alt=""
data:image/s3,"s3://crabby-images/21f4a/21f4aa4e93100ec5d815d6c6bcabf24a0e2f93f4" alt=""
引入Server依赖-开启(@EnableAdminServer)
data:image/s3,"s3://crabby-images/156a6/156a6d4782e4e047a4466fe7df3448f435ecaa7f" alt=""
Client:引入Client依赖-配置(连接目标,显示配置等)
data:image/s3,"s3://crabby-images/8b288/8b2889f0d39f912d17a30bbe0a0ed2e0cde8c7b7" alt=""
data:image/s3,"s3://crabby-images/3d369/3d369b69f4c7337583489f0e571693e74a6864d2" alt=""
引入Client依赖-配置(连接目标,显示配置等)
data:image/s3,"s3://crabby-images/fe82c/fe82c7139bb4ad4c7241ea24c0d9494ed7313066" alt=""
启动客户端+服务端并访问
data:image/s3,"s3://crabby-images/c1287/c12874c9a174350d752563050a94b39c6c10a1eb" alt=""
点击上面的lan:8080即可显示客户端的actuator
data:image/s3,"s3://crabby-images/616b2/616b20c704e307e23696e46c0955e45f531bec93" alt=""
3、安全问题
/actuator/heapdump文件泄漏
data:image/s3,"s3://crabby-images/e442e/e442e53cdc9a86eec123864d23765fcd701b9525" alt=""
data:image/s3,"s3://crabby-images/3f216/3f2161b11c92f265ba1c4c082156758e90a4b71c" alt=""
data:image/s3,"s3://crabby-images/c3f35/c3f352818ec99167915f0a8062101b3e161a52cb" alt=""
data:image/s3,"s3://crabby-images/477f3/477f30cc1f285fe4d4f1f38404d8dd666d2db00f" alt=""
data:image/s3,"s3://crabby-images/a8795/a8795f9ac264bc2aab44cd521effc0f629fef310" alt=""
①JDumpSpider提取器:https://github.com/whwlsfb/JDumpSpider ->用来提取headdump文件中的泄露信息
data:image/s3,"s3://crabby-images/33e35/33e3540e44fa17280757fd6a1922f1956e1cc7e2" alt=""
data:image/s3,"s3://crabby-images/74e21/74e21ae31fd4a2bafe97ed19d83eadf5dc249365" alt=""
data:image/s3,"s3://crabby-images/99b72/99b726f2f0f57eac45051238cd015ad2fe027e86" alt=""
②heapdump_tool提取器:https://github.com/wyzxxz/heapdump_tool-\>用来提取headdump文件中的泄露信息->分析提取出敏感信息(配置帐号密码,接口信息 数据库 短信 云应用等配置)
data:image/s3,"s3://crabby-images/e3c92/e3c92f3bea3bd15acb369f14013452306f99a931" alt=""
实战案例:
https://mp.weixin.qq.com/s/IP8BHeZaroJpJBvmF64vAw
data:image/s3,"s3://crabby-images/70d91/70d91e1530cc35a05448a5521aef05c05b68d999" alt=""
4、额外安全:
https://github.com/LandGrey/SpringBootVulExploit
data:image/s3,"s3://crabby-images/1e7c2/1e7c285c94e5b3826b1f719dd04c0830d572af50" alt=""
https://github.com/wh1t3zer/SpringBootVul-GUI
data:image/s3,"s3://crabby-images/4b569/4b56917cd45d69ab8406536eb3560836f38f1554" alt=""
例子:SpringCloud Gateway RCE(CVE-2022-22947)
->创建SpringCloud Gateway+Actuator项目
data:image/s3,"s3://crabby-images/0b7a5/0b7a554ed21fa38ec784844fa235ba959a25b17a" alt=""
data:image/s3,"s3://crabby-images/03b4f/03b4fb1654a133822e9be7be0e7f05ddcb102444" alt=""
->更改项目版本及漏洞Gateway依赖版本
<spring-boot.version>2.5.2</spring-boot.version>
<spring-cloud.version>2020.0.3</spring-cloud.version>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
<version>3.1.0</version>
</dependency>
data:image/s3,"s3://crabby-images/0f4bb/0f4bb7fad381baa409c5beacc6fe955667f6e9dd" alt=""
->启动项目进行测试
data:image/s3,"s3://crabby-images/1a480/1a48036d3898f4c5b1e6656401b7f2ae64c0a05d" alt=""
参考:https://www.cnblogs.com/qgg4588/p/18104875
data:image/s3,"s3://crabby-images/b9917/b9917e8c08b3d84babf4a1a6d5eadb8d54ab94d0" alt=""
漏洞复现要成功->需先修改yml文件中的内容
data:image/s3,"s3://crabby-images/a6acb/a6acb13d376706987be7a822c5d2568b9b6fbdc5" alt=""
二、SpringBoot-接口依赖-Swagger
Swagger是当下比较流行的实时接口文文档生成工具。接口文档是当前前后端分离项目中必不可少的工具,在前后端开发之前,后端要先出接口文档,前端根据接口文档来进行项目的开发,双方开发结束后可通过swagger的API接口进行联调测试。
参考:https://blog.csdn.net/lsqingfeng/article/details/123678701
1、开发使用
data:image/s3,"s3://crabby-images/4c0eb/4c0eb2529d07fbee968f3b53f833b2b637905cfe" alt=""
data:image/s3,"s3://crabby-images/a7a9a/a7a9acb353f3ba2a77c39fa9438a4cdc42a642e1" alt=""
①引入依赖
<--2.9.2版本-->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.9.2</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.9.2</version>
</dependency>
data:image/s3,"s3://crabby-images/22b4f/22b4f113670c75642936a4c72084405311b4efcb" alt=""
<--3.0.0版本-->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-boot-starter</artifactId>
<version>3.0.0</version>
</dependency>
②配置访问
#application.properties
spring.mvc.pathmatch.matching-strategy=ant-path-matcher
data:image/s3,"s3://crabby-images/04244/042441df417e389eb681cf695b03e92bc66276f0" alt=""
#application.yml
spring
mvc:
pathmatch:
matching-strategy: ant_path_matcher
2.X版本启动需要注释@EnableSwagger2
data:image/s3,"s3://crabby-images/d9a37/d9a37838ed0f73c618ce40d5ee879e5dc1eb8cee" alt=""
3.X版本不需注释,写的话是@EnableOpenApi
2.X访问路径:http://ip:port/swagger-ui.html
data:image/s3,"s3://crabby-images/c1be6/c1be65b6fc635dfaf790f2ad0922f92dc646c1ef" alt=""
data:image/s3,"s3://crabby-images/17566/17566a54782d3fdba60624d96cafd79c2aadd18f" alt=""
data:image/s3,"s3://crabby-images/6737e/6737ed1175bacbbcde5d2fa01c47b6d92077dc53" alt=""
再此访问http://ip:port/swagger-ui.html
data:image/s3,"s3://crabby-images/30920/309203d405ecdb0caf4a606c6decf8b327bdacfa" alt=""
3.X版本访问路径:http://ip:port/swagger-ui/index.html
③安全问题
自动化测试:Apifox Reqable Postman
泄漏应用接口:用户登录,信息显示,上传文件等(swagger泄露的接口很多,无法一一测试,需要根据泄露的api接口名字,有针对性的去测试)
Apifox->是一款自动化测试接口的工具->可用其来测swagger的接口
data:image/s3,"s3://crabby-images/418ab/418ab11c7adadc63731a4ee7670082daa25f0085" alt=""
可用于对未授权访问,信息泄漏,文件上传等安全漏洞的测试.