学了一个礼拜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
|
import requests import mechanicalsoup import bs4 import re import TEST import time import argparse from datetime import datetime import lxml parser = argparse.ArgumentParser(description = 'Login to GitHub.' ) parser.add_argument( "username" ) parser.add_argument( "password" ) args = parser.parse_args() n = 0 startime = datetime.strptime(datetime.now().strftime( '%Y-%m-%d %H:%M:%S' ), '%Y-%m-%d %H:%M:%S' ) while True : #打开“浏览器” browser = mechanicalsoup.Browser() #第一个页面url 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" #打开网易登录页面 login_page = browser.get(url) #输入账户密码然后提交表单 login_form = login_page.soup.select( "#fLogin" )[ 0 ] login_form.select( "#username" )[ 0 ][ 'value' ] = args.username login_form.select( "#password" )[ 0 ][ 'value' ] = args.password page2 = browser.submit(login_form, login_page.url) #获取page2内容 page2_soup = bs4.BeautifulSoup(page2.content) #用page2的cookies登录网易邮箱 cookie = page2.cookies.get_dict() page3 = browser.get( 'http://entry.mail.163.com/coremail/fcg/ntesdoor2' ) #获取page3的url中的sid,给出XMLurl sid = re.findall(r '(?<==).*(?=&)' ,page3.url) 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' #打开XMLurl页面,获取邮件 page4 = browser.post(XMLurl) with open (r 'q.xml' , 'w' ,encoding = 'utf-8' ) as q: q.write(page4.text) TEST.PPP(r 'q.xml' ,startime).ppp() n + = 1 print ( "循环执行第" + str (n) + '次' ) time.sleep( 30 ) |
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
|
import lxml.etree import os from datetime import datetime class PPP(): def __init__( self , src, startime): self .src = src self .startime = startime def ppp( self ): parser = lxml.etree.XMLParser(recover = True ) tree = lxml.etree.parse( self .src, parser) root = tree.getroot() array = root.find( 'array' ) for objects in array: FLAG = False for items in objects: if items.get( 'name' ) = = 'subject' : if items.text = = '999' : FLAG = True if items.get( 'name' ) = = 'sentDate' : raw_sentData = items.text sentData = datetime.strptime(raw_sentData, '%Y-%m-%d %H:%M:%S' ) if self .startime<sentData and FLAG = = True : print ( 'shutdown -s -t 60' ) |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://blog.csdn.net/u012674931/article/details/49788905