#知识点
1、信息收集-Web应用-源码获取-已知指纹&未知指纹
2、信息收集-Web应用-源码获取-泄漏问题&发现指纹
一、参考文章:
https://www.secpulse.com/archives/124398.html
data:image/s3,"s3://crabby-images/e5331/e53318c0a645e024992e910cd81b944c3cddafea" alt=""
https://mp.weixin.qq.com/s/QgLDdaefXlZtvlSiFQShZw
data:image/s3,"s3://crabby-images/d5903/d5903bc6e4841cc570e8b3fe8128ced0fa8f81e5" alt=""
二、源码泄漏原因:
由于开发者不好的习惯或者开发工具,如IDEA、vscode等,有时还会在公网,如github、gitee、oschina上遗留下历史存档(或者说是备份),给攻击者获取网站源代码提供了切入口;
1、从源码本身的特性入口
2、从管理员不好的习惯入口
3、从管理员习惯的开发入口
4、从管理员不好的配置入口
5、从管理员不好的意识入口
6、从管理员资源信息搜集入口
三、源码泄漏大概集合:
1、Webpack打包器泄漏(前端技术出现)
一般在Vue、Node.js的前端技术,用js传输的,造成泄露(用php、java语言写的后端是看不到的);这两种语言开发的,一般会用到webpack打包器做存档
识别泄露的步骤:
①通过指纹识别->发现使用了webpack打包器
data:image/s3,"s3://crabby-images/172e0/172e0e9bdbcd9b2db1e9adceee149ba3485eeb05" alt=""
②利用chrome浏览器的source detector插件->获取到泄露的部分源代码
data:image/s3,"s3://crabby-images/d47c2/d47c233580a6a11664c7d3889e25499570c22a0c" alt=""
案例1:https://mp.weixin.qq.com/s/zhjxW2mUEgq6dFAp3kBcgQ
data:image/s3,"s3://crabby-images/6e6c0/6e6c0ce8f6a0bbb6b22eff1d9bf98bc256404815" alt=""
案例2:SRC挖掘-js.map泄露到接管云上域控
https://mp.weixin.qq.com/s/QZsNjbTiaqC1qwzARVAiGQ
data:image/s3,"s3://crabby-images/8a363/8a3634cd4aaebd998ab1f2d663323f653e6adc57" alt=""
2、composer.json
一般出现在php语言开发的网站,PHP语言在composer的功能和python语言中的pip类似,主要用来管理调用的第三方库的框架等信息;
3、GitHub源码泄漏
最好使GitHub处于登录状态,再进行源码搜索
data:image/s3,"s3://crabby-images/20ce2/20ce237fb7174ad71ec6359b70e2956f32dff422" alt=""
①特定文件->GitHub搜索
data:image/s3,"s3://crabby-images/19706/19706ec7f504b136c713dbaabe8880a036432f3c" alt=""
data:image/s3,"s3://crabby-images/b3655/b3655dba503e36c5ce09c4e7aba9c46bc2b70ac3" alt=""
data:image/s3,"s3://crabby-images/41468/4146871629caed86ae2c01b897451900b06d183e" alt=""
②特征联系方式->如qq号、手机邮箱等->github搜索
data:image/s3,"s3://crabby-images/a0652/a0652d89de66c4612a3a4880d4df013ff610a5b0" alt=""
③对github进行监控,有些源码作者上传后,后因某种原因,可能删除;这时持续对GitHub进行监控就有一定的必要,可以及时获得源码资源,以免后期资源找不着( 除了源码,漏洞更新,工具更新等都有用处)
补:GitHub搜索需注意目标使用的源码是开源还是闭源,是否公开,github可以搜到的一般是开源的、公开的源码泄露;
4、git源码泄露
data:image/s3,"s3://crabby-images/c4c0d/c4c0d64cc4ba790f5786878448bbc51542b55eef" alt=""
实验:
data:image/s3,"s3://crabby-images/e8bff/e8bffcdf3e1e7c04a0cebac84b07f29425de3882" alt=""
data:image/s3,"s3://crabby-images/3334b/3334bd625faa5d4d737983b98f4238ecf75b782d" alt=""
data:image/s3,"s3://crabby-images/fdca1/fdca15b4d0aa2c71f6a7dae37af6b36e6598110d" alt=""
5、svn源码泄露
data:image/s3,"s3://crabby-images/f05b7/f05b7f2672f5d3684efaab67e69b11cef02152a2" alt=""
实验:
data:image/s3,"s3://crabby-images/69338/693387fac9c8a7aa1f74393937689797f792ae9e" alt=""
data:image/s3,"s3://crabby-images/c7fa4/c7fa401331274827fd53fb6be92faabfbc3b650f" alt=""
data:image/s3,"s3://crabby-images/a80e5/a80e508676528c4a4af26b71e6cde6846f3d80cb" alt=""
data:image/s3,"s3://crabby-images/e025c/e025c6ba2733454ebfb0bbf5e6253e7b8a194028" alt=""
6、网站备份压缩文件如.zip文件
思路:利用工具进行目录扫描->发现.zip文件->url地址访问.zip文件->成功下载该文件
.zip文件里面可能打包了所有的网站源代码
data:image/s3,"s3://crabby-images/5844b/5844b11e7b0c2d7d9ef3f69885524b5d11072750" alt=""
7、DS_Store文件泄露
data:image/s3,"s3://crabby-images/1f977/1f9777e19b2274dee5bb5789c66fc98a813a9c23" alt=""
实验:
data:image/s3,"s3://crabby-images/af166/af1668de534d918322e91ede1a8ef167605688b8" alt=""
data:image/s3,"s3://crabby-images/aa4d3/aa4d3eb0dcc96ef0a1bde0b31ebb9c5bac177c09" alt=""
类似案例:渗透测试实战---某资金盘信息收集(.idea目录泄露)
https://mp.weixin.qq.com/s/7cSrDZci_drE6wTGvQOOHw
data:image/s3,"s3://crabby-images/85b31/85b3107f8501f1c1e5491ca0dcca0c4acd040bbe" alt=""
8、hg源码泄漏
9、SWP 文件泄露
10、CVS泄露
11、Bzr泄露
12、'WEB-INF/web.xml 泄露
四、源码搜集思路点:
1、使用指纹识别平台获取到目标是什么名字的源码程序(指纹已识别的情况)
通过搜索引擎获取到源码
2、使用指纹识别平台不能获取目标信息(指纹不能识别的情况)
后端:借助svn git composer.json ds_store 备份扫描(.zip)等配置泄漏安全
前端:webpack打包 谷歌插件source detector获取源码
如果没有这些问题 还想获取源码怎么办 见下面方法
3、借助资源平台去搜索(github gitee oschina等源码)
-特定文件
-特征联系方式,如手机号、邮箱等
-github监控( 除了源码,漏洞更新,工具更新等都有用处)
目标使用的源码是开源还是闭源,是否公开
五、Github资源搜索-未知指纹识别获取源码途径
*拓展:配合后期监控保证第一时间通知
资源搜索语法:
in:name test #仓库标题搜索含有关键字
in:descripton test #仓库描述搜索含有关键字
in:readme test #Readme文件搜素含有关键字
stars:>3000 test #stars数量大于3000的搜索关键字
stars:1000..3000 test #stars数量大于1000小于3000的搜索关键字 forks:>1000 test #forks数量大于1000的搜索关键字
forks:1000..3000 test #forks数量大于1000小于3000的搜索关键字 size:>=5000 test #指定仓库大于5000k(5M)的搜索关键字 pushed:>2019-02-12 test #发布时间大于2019-02-12的搜索关键字 created:>2019-02-12 test #创建时间大于2019-02-12的搜索关键字 user:test #用户名搜素
license:apache-2.0 test #明确仓库的 LICENSE 搜索关键字 language:java test #在java语言的代码中搜索关键字
user:test in:name test #组合搜索,用户名test的标题含有test的
关键字配合谷歌搜索:
site:Github.com smtp
site:Github.com smtp @qq.com
site:Github.com smtp @126.com
site:Github.com smtp @163.com
site:Github.com smtp @sina.com.cn
site:Github.com smtp password
site:Github.com String password smtp
六、另类目标源码获取
一般是不正规网站,多采用的网站源码选择地址
这些不正规网站,还可以通过网站的icon图标(一般不会改),在fofa等网络空间引擎搜索,从而找到源码
data:image/s3,"s3://crabby-images/f7d1f/f7d1f65648220677ba18b23c780de3259d6f03d0" alt=""
data:image/s3,"s3://crabby-images/4d66a/4d66ac35206ffb05c8a72e4169dd75a8b075b305" alt=""
从目标转到寻找源码系统上,从源码系统上找应用目标