学了一个礼拜Python之后写的,代码很粗糙,只是为了完成利用163邮箱远程关电脑功能。直接把代码发上来吧。要执行的话得先安装一些模块,看import语句。
十月初写的,写完这个之后就没怎么写python了,忘得厉害。
- 本来想从mail.163.com模拟登录的,但这个网页提交按钮是个, 有点复杂,搞了几个小时搞不定。
- 我就绕了一下,从
http://reg.163.com/logins.jsp 登录。这个页面登录会被拦截,还是到不了邮箱。但确实是登录成功,我们能得到一个登录认证。
- 再访问
http://entry.mail.163.com,这样就登录邮箱成功了,但因为进了邮箱之后,页面也是太复杂了。还是不好拿到邮件信息。
- 从第三步取得sid,生成一个URL,从这个URL直接访问邮件的XML文档页面。
- 然后就简单啦,把页面抓下来解析一下邮件内容,按照邮件内容执行命令。所以其实不止能关电脑,在windows下还能远程写个批处理脚本。修改一下代码,linux也能执行。
halla.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48 1import requests
2import mechanicalsoup
3import bs4
4import re
5import TEST
6import time
7import argparse
8from datetime import datetime
9import lxml
10
11parser = argparse.ArgumentParser(description='Login to GitHub.')
12parser.add_argument("username")
13parser.add_argument("password")
14args = parser.parse_args()
15
16n = 0
17startime = datetime.strptime(datetime.now().strftime('%Y-%m-%d %H:%M:%S'),'%Y-%m-%d %H:%M:%S')
18while True:
19 #打开“浏览器”
20 browser = mechanicalsoup.Browser()
21 #第一个页面url
22 url = "http://reg.163.com/logins.jsp?type=1&product=mail163&url=http://entry.mail.163.com/coremail/fcg/ntesdoor2?lightweight%3D1%26verifycookie%3D1%26language%3D-1%26style%3D1"
23 #打开网易登录页面
24 login_page = browser.get(url)
25 #输入账户密码然后提交表单
26 login_form = login_page.soup.select("#fLogin")[0]
27 login_form.select("#username")[0]['value'] = args.username
28 login_form.select("#password")[0]['value'] = args.password
29 page2 = browser.submit(login_form, login_page.url)
30 #获取page2内容
31 page2_soup = bs4.BeautifulSoup(page2.content)
32 #用page2的cookies登录网易邮箱
33 cookie = page2.cookies.get_dict()
34 page3 = browser.get('http://entry.mail.163.com/coremail/fcg/ntesdoor2')
35 #获取page3的url中的sid,给出XMLurl
36 sid = re.findall(r'(?<==).*(?=&)',page3.url)
37 XMLurl = 'http://mail.163.com/js6/s?sid='+sid[0]+'&func=mbox:listMessages&topNav_mobileIcon_show=1&TopTabReaderShow=1&TopTabLofterShow=1&welcome_welcomemodule_mailrecom_click=1&LeftNavfolder1Click=1&mbox_folder_enter=1'
38 #打开XMLurl页面,获取邮件
39 page4 = browser.post(XMLurl)
40
41 with open(r'q.xml','w',encoding='utf-8') as q:
42 q.write(page4.text)
43
44 TEST.PPP(r'q.xml',startime).ppp()
45 n+=1
46 print("循环执行第"+str(n)+'次')
47 time.sleep(30)
48
TEST.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29 1import lxml.etree
2import os
3from datetime import datetime
4
5
6class PPP():
7 def __init__(self, src, startime):
8 self.src = src
9 self.startime = startime
10
11 def ppp(self):
12 parser = lxml.etree.XMLParser(recover=True)
13 tree = lxml.etree.parse(self.src, parser)
14 root = tree.getroot()
15 array = root.find('array')
16
17 for objects in array:
18 FLAG = False
19 for items in objects:
20 if items.get('name') == 'subject':
21 if items.text == '999':
22 FLAG = True
23
24 if items.get('name') == 'sentDate':
25 raw_sentData = items.text
26 sentData = datetime.strptime(raw_sentData,'%Y-%m-%d %H:%M:%S')
27 if self.startime<sentData and FLAG==True:
28 print('shutdown -s -t 60')
29