python 通過郵件控制實(shí)現(xiàn)遠(yuǎn)程控制電腦操作
0x00 思路
之前在博客上看到了使用python通過微信的接口,與微信交互的方式來控制電腦的攝像頭、開關(guān)機(jī)等。但是這種方式需要首先在python上登錄自己的微信才可以,同時(shí)微信端也會(huì)有已經(jīng)在網(wǎng)頁(yè)端登錄的字樣,很顯眼。因此想到了另外一種交互方式,通過郵件進(jìn)行交互。
通過郵件的方式不要求用戶實(shí)時(shí)在線,只需要程序隔一段時(shí)間掃描一下郵箱的新郵件即可。這種交互方式更為方便。其次,這種方式也更為隱蔽,不會(huì)干擾微信的使用。
0x01 需要用到的庫(kù)
主要是python的一些用于收發(fā)郵件的庫(kù)
import smtplib from email.parser import Parser from email.header import decode_header from email.utils import parseaddr import poplib import pyautogui from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart from email.header import Header import os
0x02 具體實(shí)現(xiàn)
首先,實(shí)現(xiàn)郵件的讀取功能。讀取最新的一封郵件內(nèi)容,這條內(nèi)容中包含我們要做的事情,比如查詢ip地址、獲取屏幕截圖等。
在獲取內(nèi)容之前,先將郵箱的登錄等做好初始化
def email_init(): email = 'xxxxx@qq.com' #登錄的郵箱賬號(hào) password = 'xxxxx' # 注意這里不是郵箱密碼 是要登錄的郵箱的授權(quán)碼 pop3_server = 'pop.qq.com' # 連接到POP3服務(wù)器: server = poplib.POP3_SSL(pop3_server, 995) server.set_debuglevel(0) server.user(email) server.pass_(password) resp, mails, octets = server.list() index = len(mails) resp, lines, octets = server.retr(index) # 這里index代表讀取最后一封郵件 也就是第一封 msg_content = b'\r\n'.join(lines).decode('utf-8') msg = Parser().parsestr(msg_content) return msg, server
要注意密碼不是郵箱的密碼,是授權(quán)碼,具體獲取方式可以百度。
隨后就可以將進(jìn)行郵件的讀取了。
def print_info(msg, indent=0): if indent == 0: for header in ['From', 'To', 'Subject']: value = msg.get(header, '') if value: if header == 'Subject': value = decode_str(value) else: hdr, addr = parseaddr(value) name = decode_str(hdr) value = u'%s <%s>' % (name, addr) print('%s%s: %s' % (' ' * indent, header, value)) if msg.is_multipart(): parts = msg.get_payload() for n, part in enumerate(parts): print('%spart %s' % (' ' * indent, n)) print('%s--------------------' % (' ' * indent)) return print_info(part, indent + 1) else: content_type = msg.get_content_type() if content_type=='text/plain' or content_type=='text/html': content = msg.get_payload(decode=True) charset = guess_charset(msg) if charset: content = content.decode(charset) print('%sText: %s' % (' ' * indent, content)) return content else: print('%sAttachment: %s' % (' ' * indent, content_type))
將上一步得到的msg參數(shù)傳入到讀取函數(shù)中,通過遞歸調(diào)用查詢郵件內(nèi)容并解碼。其中涉及到遞歸調(diào)用中的輸出問題,我再上一篇文章中有提到:http://www.dbjr.com.cn/article/182761.htm
另外,涉及的解析函數(shù)decode_str()如下
def decode_str(s): value, charset = decode_header(s)[0] if charset: value = value.decode(charset) return value
在郵件中讀取相關(guān)命令后,就是對(duì)命令執(zhí)行,然后在通過郵件的形式反饋命令結(jié)果了。
這里以返回屏幕截圖以及執(zhí)行dos命令為例
def send_result(kind, result): # 第三方 SMTP 服務(wù) mail_host = "smtp.163.com" mail_user = "@163.com" #發(fā)送信息的郵箱 這里我是用的163郵箱 mail_pass = "xxxxxxx" # 郵箱的授權(quán)碼 sender = 'xxxxxx@163.com' #發(fā)送方地址 receivers = ['xxxxx@qq.com'] #收件地址 if kind == 1: # 第一方式 反饋屏幕截圖 print('Sending screenshot.') # 創(chuàng)建一個(gè)帶附件的實(shí)例 message = MIMEMultipart() message['From'] = '<hacker_center@163.com>' message['To'] = '<niu5512@qq.com>' subject = 'Hacker Center reply' message['Subject'] = Header(subject, 'utf-8') # 郵件正文內(nèi)容 message.attach(MIMEText('Hacker Server replay', 'plain', 'utf-8')) if os.path.exists("./screenshot.jpg"): # 構(gòu)造附件1,傳送當(dāng)前目錄下的 test.txt 文件 att1 = MIMEText(open('./screenshot.jpg', 'rb').read(), 'base64', 'utf-8') att1["Content-Type"] = 'application/octet-stream' # 這里的filename可以任意寫,寫什么名字,郵件中顯示什么名字 att1["Content-Disposition"] = 'attachment; filename="screenshot.jpg"' message.attach(att1) try: smtpObj = smtplib.SMTP_SSL(mail_host, 465) # 啟用SSL發(fā)信, 端口一般是465 smtpObj.login(mail_user, mail_pass) # 登錄驗(yàn)證 smtpObj.sendmail(sender, receivers, message.as_string()) # 發(fā)送 print("mail has been send successfully.") except smtplib.SMTPException as e: print(e) if kind == 2: #第二種方式 返回dos命令結(jié)果 message = MIMEText(result, 'plain', 'utf-8') message['From'] = '<hacker_center@163.com>' message['To'] = '<niu5512@qq.com>' subject = 'Hacker Center reply' message['Subject'] = Header(subject, 'utf-8') smtpObj = smtplib.SMTP_SSL(mail_host, 465) smtpObj.login(mail_user, mail_pass) smtpObj.sendmail(sender, receivers, message.as_string()) print("mail has been send successfully.")
其中執(zhí)行dos命令的函數(shù)如下:
def manage_cmd(cmd): print('The command is:%s' % cmd) kind = 0 result = 'Nothing happen.' if 'screenshot' in cmd: img = pyautogui.screenshot() img.save('./screenshot.jpg') kind = 1 if 'dos cmd' in cmd: dos_result = '' index = cmd.find(':') cmd = cmd[index+1:] if os.system(cmd): result = 'command err.' else: info = os.popen(cmd) for line in info: dos_result = dos_result + line kind = 3 if dos_result != '': result = dos_result return kind, result
傳入的cmd參數(shù)就是解析出的郵件內(nèi)容,通過判斷郵件內(nèi)容來進(jìn)行郵件反饋。
0x03 實(shí)驗(yàn)結(jié)果
發(fā)送郵箱查詢本機(jī)ip地址
收到的反饋如下:
總結(jié)
到此這篇關(guān)于python 通過郵件控制電腦實(shí)現(xiàn)遠(yuǎn)程控制電腦操作的文章就介紹到這了,更多相關(guān)python郵件遠(yuǎn)程控制電腦內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
8段用于數(shù)據(jù)清洗Python代碼(小結(jié))
這篇文章主要介紹了8段用于數(shù)據(jù)清洗Python代碼(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10python實(shí)現(xiàn)canny邊緣檢測(cè)
本文主要講解了canny邊緣檢測(cè)原理:計(jì)算梯度幅值和方向、根據(jù)角度對(duì)幅值進(jìn)行非極大值抑制、用雙閾值算法檢測(cè)和連接邊緣以及python 實(shí)現(xiàn)2020-09-09Python While循環(huán)語句實(shí)例演示及原理解析
這篇文章主要介紹了Python While循環(huán)語句實(shí)例演示及原理解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01Python實(shí)現(xiàn)實(shí)時(shí)顯示進(jìn)度條的6種方法
相信大家對(duì)進(jìn)度條一定不陌生了,很多安裝或者下載都會(huì)出現(xiàn)進(jìn)度條,本文主要介紹了Python實(shí)現(xiàn)實(shí)時(shí)顯示進(jìn)度條的6種方法,具有一定的參考價(jià)值,感興趣的可以了解一下2021-12-12Python持續(xù)監(jiān)聽文件變化代碼實(shí)例
這篇文章主要介紹了Python持續(xù)監(jiān)聽文件變化代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07