python實現批量監(jiān)聽頁面并發(fā)送郵件
一、程序樣式
1.listen.ini配置文件
2.監(jiān)控頁面
3.日志
二、核心點
smtplib庫:這里使用了smtp.qq.com與smtp.163.com兩個發(fā)送郵件的地址,使用郵箱用戶名與授權碼來實現登錄,端口都使用465,最后拋出異常,finally里面最好判斷一下srv這個變量存不存在,有可能斷網就會導致登錄失敗,從而srv變量沒有,最后srv.quit()最后報錯
try: # 不能直接使用smtplib.SMTP來實例化,第三方郵箱會認為它是不安全的而報錯 # 使用加密過的SMTP_SSL來實例化,它負責讓服務器做出具體操作,它有兩個參數 # 第一個是服務器地址,但它是bytes格式,所以需要編碼 # 第二個參數是服務器的接受訪問端口,SMTP_SSL協(xié)議默認端口是465 25 srv = smtplib.SMTP_SSL(smtp_srv.encode(), 465) # 使用授權碼登錄郵箱 srv.login(from_addr, from_pwd) # 使用sendmail方法來發(fā)送郵件,它有三個參數 # 第一個是發(fā)送地址 # 第二個是接受地址,是list格式,可以同時發(fā)送給多個郵箱 # 第三個是發(fā)送內容,作為字符串發(fā)送 for to_addr in to_addrs: srv.sendmail(from_addr, [to_addr], msg.as_string()) # srv.sendmail(from_addr, [to_addr1], msg.as_string()) logger.info(to_addr+'發(fā)送成功') except Exception as e: logger.error('發(fā)送失敗 '+str(e)) finally: #無論發(fā)送成功還是失敗都要退出你的QQ郵箱 檢測srv是否存在 不檢測會程序報錯 if 'srv' in globals(): srv.quit()
2.讀取ini配置文件:實現已定義參數,配置發(fā)件人、郵件郵箱,選擇郵箱地址smtp.qq.com/smtp.163.com、郵件標題、監(jiān)控頁面地址(批量)、郵件人郵箱(批量)等參數,這里獲取linten.ini配置文件的絕對路徑有個問題,需要使用 sys.agrv[0]獲取真實路徑,不然就可能獲取的是打包的程序.exe的系統(tǒng)路徑temp了
#獲取當前目錄路徑 proDir = os.path.dirname(os.path.realpath(sys.argv[0]))
import os import configparser import sys # 讀取配置文件 def getConfig(filename, section, option): """ :param filename 文件名稱 :param section: 服務 :param option: 配置參數 :return:返回配置信息 """ # 獲取當前目錄路徑 proDir = os.path.dirname(os.path.realpath(sys.argv[0])) # print(proDir) # 拼接路徑獲取完整路徑 configPath = os.path.join(proDir, filename) # print(configPath) # 創(chuàng)建ConfigParser對象 conf = configparser.ConfigParser() # 讀取文件內容 conf.read(configPath,'utf-8') config = conf.get(section, option) return config
# 發(fā)件人 from_name = getConfig('listen.ini','listen','from_name') # 發(fā)件郵箱 from_addr = getConfig('listen.ini','listen','from_addr') # 發(fā)件郵箱授權碼,注意不是QQ郵箱密碼 from_pwd = getConfig('listen.ini','listen','from_pwd') # 收件郵箱 to_addrs = getConfig('listen.ini','listen','to_addrs') to_addrs = to_addrs.split(',') # 郵件標題 my_title = getConfig('listen.ini','listen','my_title')
3.日志輸入:logger.error()、logger.info()、 logger.warning()、 logger.debug()
logger = logging.getLogger() logger.setLevel(logging.INFO) #設置將日志輸出到文件中,并且定義文件內容 now = datetime.datetime.now().strftime("%Y-%m-%d_%H-%M-%S") fileinfo = logging.FileHandler(f"listen_{now}.log") fileinfo.setLevel(logging.INFO) #設置將日志輸出到控制臺 controlshow = logging.StreamHandler() controlshow.setLevel(logging.INFO) #設置日志的格式 formatter = logging.Formatter("%(asctime)s - %(levelname)s: %(message)s") fileinfo.setFormatter(formatter) controlshow.setFormatter(formatter) logger.addHandler(fileinfo) logger.addHandler(controlshow)
4.requests監(jiān)控頁面
這里我判斷了status_code
,如果不是200
就會發(fā)郵件,并且寫了幾個異常情況,也同樣會記錄日志與發(fā)郵件,并且當郵件數量達到5封,就會延時30分鐘后,在檢測,如果依舊有問題,就再發(fā)五封。
urls = getConfig('listen.ini','listen','urls') urls = urls.split(',') while True: for url in urls: try: response = requests.get(url,timeout=5) code = response.status_code body = str(url) + ' 運行異常,狀態(tài)碼:' + str(code) + ' 請檢查服務運行情況' # 定義郵件數量5 i = 0 if code != 200: i += 1 logger.error(body) send_mail(body) if i >= 5: # 延時30分鐘 time.sleep(1800) i = 0 except exceptions.HTTPError as e: logger.error("發(fā)生HTTP錯誤,原因是:"+ str(e)) send_mail("發(fā)生HTTP錯誤,原因是:"+ str(e)) time.sleep(5) except exceptions.Timeout as e: logger.error("訪問超時,原因是:"+ str(e)) send_mail("訪問超時,原因是:"+ str(e)) time.sleep(5) except Exception as e: logger.error("未知錯誤,原因是:" + str(e)) send_mail("未知錯誤,原因是:" + str(e)) time.sleep(5)
三、完整代碼
listen.py
import smtplib from email.mime.text import MIMEText from email.utils import formataddr import requests import logging import datetime import time from requests import exceptions from getConfig import getConfig def send_mail(body): # 發(fā)件人 from_name = getConfig('listen.ini','listen','from_name') # 發(fā)件郵箱 from_addr = getConfig('listen.ini','listen','from_addr') # 發(fā)件郵箱授權碼,注意不是QQ郵箱密碼 from_pwd = getConfig('listen.ini','listen','from_pwd') # 收件郵箱 to_addrs = getConfig('listen.ini','listen','to_addrs') to_addrs = to_addrs.split(',') # 郵件標題 my_title = getConfig('listen.ini','listen','my_title') # 郵件正文 msg = MIMEText(body, 'plain', 'utf-8') msg['From'] = formataddr([from_name, from_addr]) # 郵件的標題 msg['Subject'] = my_title # SMTP服務器地址,QQ郵箱的SMTP地址是"smtp.qq.com" # smtp_srv = "smtp.qq.com" smtp_srv = getConfig('listen.ini','listen','smtp_srv') try: # 不能直接使用smtplib.SMTP來實例化,第三方郵箱會認為它是不安全的而報錯 # 使用加密過的SMTP_SSL來實例化,它負責讓服務器做出具體操作,它有兩個參數 # 第一個是服務器地址,但它是bytes格式,所以需要編碼 # 第二個參數是服務器的接受訪問端口,SMTP_SSL協(xié)議默認端口是465 25 srv = smtplib.SMTP_SSL(smtp_srv.encode(), 465) # 使用授權碼登錄QQ郵箱 srv.login(from_addr, from_pwd) # 使用sendmail方法來發(fā)送郵件,它有三個參數 # 第一個是發(fā)送地址 # 第二個是接受地址,是list格式,可以同時發(fā)送給多個郵箱 # 第三個是發(fā)送內容,作為字符串發(fā)送 for to_addr in to_addrs: srv.sendmail(from_addr, [to_addr], msg.as_string()) # srv.sendmail(from_addr, [to_addr1], msg.as_string()) logger.info(to_addr+'發(fā)送成功') except Exception as e: logger.error('發(fā)送失敗 '+str(e)) finally: #無論發(fā)送成功還是失敗都要退出你的QQ郵箱 檢測srv是否存在 不檢測會程序報錯 if 'srv' in globals(): srv.quit() if __name__ == '__main__': logger = logging.getLogger() logger.setLevel(logging.INFO) #設置將日志輸出到文件中,并且定義文件內容 now = datetime.datetime.now().strftime("%Y-%m-%d_%H-%M-%S") fileinfo = logging.FileHandler(f"listen_{now}.log") fileinfo.setLevel(logging.INFO) #設置將日志輸出到控制臺 controlshow = logging.StreamHandler() controlshow.setLevel(logging.INFO) #設置日志的格式 formatter = logging.Formatter("%(asctime)s - %(levelname)s: %(message)s") fileinfo.setFormatter(formatter) controlshow.setFormatter(formatter) logger.addHandler(fileinfo) logger.addHandler(controlshow) # os.system('pause') print( " ...............正在監(jiān)聽V8移動端wechat...............") print( " .....................阿彌陀佛.......................") print( " _oo0oo_ ") print( " o8888888o ") print( ' 88" . "88 ') print( " (| -_- |) ") print( " 0\\ = /0 ") print( " ___/‘---'\\___ ") print( " .' \\| |/ '. ") print( " / \\\\||| : |||// \\ ") print( " / _||||| -卍-|||||_ \\ ") print( " | | \\\\\\ - /// | | ") print( " | \\_| ''\\---/'' |_/ | ") print( " \\ .-\\__ '-' ___/-. / ") print( " ___'. .' /--.--\\ '. .'___ ") print( " ."" ‘< ‘.___\\_<|>_/___.'>' "". ") print( " | | : ‘- \\‘.;‘\\ _ /';.'/ - ' : | | ") print( " \\ \\ ‘_. \\_ __\\ /__ _/ .-' / / ") print( " =====‘-.____‘.___ \\_____/___.-'___.-'===== ") print( " ‘=---=' ") print( " ") print( "..................佛祖保佑, 一直監(jiān)聽..................") urls = getConfig('listen.ini','listen','urls') urls = urls.split(',') while True: for url in urls: try: response = requests.get(url,timeout=5) code = response.status_code body = str(url) + ' 運行異常,狀態(tài)碼:' + str(code) + ' 請檢查服務運行情況' # 定義郵件數量5 i = 0 if code != 200: i += 1 logger.error(body) send_mail(body) if i >= 5: # 延時30分鐘 time.sleep(1800) i = 0 except exceptions.HTTPError as e: logger.error("發(fā)生HTTP錯誤,原因是:"+ str(e)) send_mail("發(fā)生HTTP錯誤,原因是:"+ str(e)) time.sleep(5) except exceptions.Timeout as e: logger.error("訪問超時,原因是:"+ str(e)) send_mail("訪問超時,原因是:"+ str(e)) time.sleep(5) except Exception as e: logger.error("未知錯誤,原因是:" + str(e)) send_mail("未知錯誤,原因是:" + str(e)) time.sleep(5)
getConfig.py
import os import configparser import sys # 讀取配置文件 def getConfig(filename, section, option): """ :param filename 文件名稱 :param section: 服務 :param option: 配置參數 :return:返回配置信息 """ # 獲取當前目錄路徑 proDir = os.path.dirname(os.path.realpath(sys.argv[0])) # print(proDir) # 拼接路徑獲取完整路徑 configPath = os.path.join(proDir, filename) # print(configPath) # 創(chuàng)建ConfigParser對象 conf = configparser.ConfigParser() # 讀取文件內容 conf.read(configPath,'utf-8') config = conf.get(section, option) return config
listen.ini
[listen] #發(fā)件人 from_name = XXX #登錄郵箱地址 smtp.qq.com smtp.163.com smtp_srv = smtp.163.com #發(fā)件郵箱 from_addr = xxxxxxxxxx@163.com #發(fā)件郵箱授權碼,請在qq 163郵箱賬戶選項里面查詢 from_pwd = xxxxxxxxxxxx #收件郵箱 to_addrs = xxxxx@dingtalk.com #郵件標題 my_title = XXXXXXX異常告警 #監(jiān)控地址 urls = http://ecard.swpu.edu.com,127.0.0.1:80,xxxxxxxxx
以上就是python實現批量監(jiān)聽頁面并發(fā)送郵件的詳細內容,更多關于python監(jiān)聽頁面的資料請關注腳本之家其它相關文章!