打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Google Chrome 浏览器历史记录的获取与清除
转:http://blog.csdn.net/itmes/article/details/7594871

以前做的一款产品要求能够获取IE浏览器的历史记录,并能够进行彻底删除,当时chrome浏览器、FireFox浏览器都刚刚兴起不久,索性将此功能进行扩展,实现对多浏览器的支持。

查找历史记录这种东西,主要就是找到其存储的位置,分析其文件的格式,IE的就不说了,微软有相应的API。Google Chrome浏览器使用小型桌面数据库SQLLite存储其历史记录信息,其实就是一个数据库文件,一些数据库表。

那么我们自己编写一个获取chrome历史记录的小工具都需要哪些准备呢?首先,我们要找到chrome浏览器历史记录文件存在的位置,并能够编程获得这个位置。其次,我们要能够读取sqllite数据库文件,并能够对其进行操作。

1、获得chrome浏览器历史记录数据库文件的存储位置,参考以下代码片段:

#include <shlobj.h> 
#include "Shlwapi.h"
#pragma  comment(lib,"Shlwapi.lib")

#define CSIDL_LOCAL_APPDATA                   0x001c


char path[MAX_PATH];
    SHGetSpecialFolderPathA(this->GetSafeHwnd(),path,CSIDL_LOCAL_APPDATA,FALSE);
    
    strcat_s(path,"\\google\\chrome\\User Data\\default\\history");


注意,这里的history文件没有扩展名

2、打开并读取历史记录数据库文件

chrome在运行的时候会打开这个数据库文件,所以我们要先检测chrome是否在运行,如果在运行就不能读取数据库了,因为会有共享冲突。

读取sqllite数据库文件需要有相应的api支持,这里我用了一个封装的比较好的c++类库CppSQLite3,这样读取sqllite数据库就简单多了

网页历史记录存储在表urls中,懂点SQL语句的可就简单多了 用这么一条语句"select url,title from urls",就可以将历史记录都读取出来了。

那删除呢?也是一条语句“delete from urls”,这不是很简单么。

不过还有一点要注意,sqllite数据库文件中默认存储的编码格式是 UTF8,我们需要将其转换为可以显示的gbk格式,否则只能看到乱码了。

参考以下代码片段:


bool ChromeHistory::GetUrlHistroy(CStringArray history[])
{
    char path[MAX_PATH];
    SHGetSpecialFolderPathA(this->GetSafeHwnd(),path,CSIDL_LOCAL_APPDATA,FALSE);   
    strcat_s(path,"\\google\\chrome\\User Data\\default\\history");
    if (PathFileExistsA(path))
    {        
        if (IsRunning(_T("chrome.exe")))
        {
            //MessageBox(_T("chrome正在运行,请关闭后再试 !"));
            return FALSE;
        }
        //
        try
        {
            CppSQLite3DB db;
            CppSQLite3Query query;
            
            db.open(path);
            query=db.execQuery("select url,title from urls");
            while(!query.eof())
            {
                //MessageBox(query.fieldValue("title"));
                CStringA utf8url;
                utf8url=query.fieldValue("url");
                CStringA utf8title;
                utf8title=query.fieldValue("title");
                ConvertUtf8ToGBK(utf8url);
                ConvertUtf8ToGBK(utf8title);
                //MessageBox(utf8url);
                history[0].Add(CString(utf8url));
                history[1].Add(CString(utf8title));            
                query.nextRow();                
            }
            db.close();
        }
        catch (CppSQLite3Exception& e)
        {
            //MessageBox((LPWSTR)e.errorMessage());
            return FALSE;            
        }        
    }
    return TRUE;
}

3、补充:若要完全清除chrome的历史记录,上面的方法是不够的,chrome 浏览器在打开网页的时候会先把网页存放到缓存中,这个缓存会一直保留在本机上,但缓存文件是google自定义的特殊格式,需要自行解析,所以要完全清除chrome历史记录需要将缓存目录也安全删除掉。


源码已上传,可自由下载。http://download.csdn.net/detail/itmes/4323836

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
在B站学习Python爬虫小白学习笔记-初步认识requests
trackback的原理与实现 trackback扫盲
ALTRun 国产快捷启动辅助类软件神作
你在浏览器输入了baidu.com 并按下回车后,背后到底发生了什么?
第 59 天:Python Django 模型概述与应用
使用ZEOS控件在DELPHI2007下连接SQLITE文件的乱码问题
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服