python實現(xiàn)批量監(jiān)聽頁面并發(fā)送郵件
一、程序樣式
1.listen.ini配置文件

2.監(jiān)控頁面

3.日志

二、核心點
smtplib庫:這里使用了smtp.qq.com與smtp.163.com兩個發(fā)送郵件的地址,使用郵箱用戶名與授權碼來實現(xiàn)登錄,端口都使用465,最后拋出異常,finally里面最好判斷一下srv這個變量存不存在,有可能斷網就會導致登錄失敗,從而srv變量沒有,最后srv.quit()最后報錯
try:
# 不能直接使用smtplib.SMTP來實例化,第三方郵箱會認為它是不安全的而報錯
# 使用加密過的SMTP_SSL來實例化,它負責讓服務器做出具體操作,它有兩個參數(shù)
# 第一個是服務器地址,但它是bytes格式,所以需要編碼
# 第二個參數(shù)是服務器的接受訪問端口,SMTP_SSL協(xié)議默認端口是465 25
srv = smtplib.SMTP_SSL(smtp_srv.encode(), 465)
# 使用授權碼登錄郵箱
srv.login(from_addr, from_pwd)
# 使用sendmail方法來發(fā)送郵件,它有三個參數(shù)
# 第一個是發(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配置文件:實現(xiàn)已定義參數(shù),配置發(fā)件人、郵件郵箱,選擇郵箱地址smtp.qq.com/smtp.163.com、郵件標題、監(jiān)控頁面地址(批量)、郵件人郵箱(批量)等參數(shù),這里獲取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: 配置參數(shù)
: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ā)郵件,并且當郵件數(shù)量達到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) + ' 請檢查服務運行情況'
# 定義郵件數(shù)量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來實例化,它負責讓服務器做出具體操作,它有兩個參數(shù)
# 第一個是服務器地址,但它是bytes格式,所以需要編碼
# 第二個參數(shù)是服務器的接受訪問端口,SMTP_SSL協(xié)議默認端口是465 25
srv = smtplib.SMTP_SSL(smtp_srv.encode(), 465)
# 使用授權碼登錄QQ郵箱
srv.login(from_addr, from_pwd)
# 使用sendmail方法來發(fā)送郵件,它有三個參數(shù)
# 第一個是發(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) + ' 請檢查服務運行情況'
# 定義郵件數(shù)量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: 配置參數(shù)
: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 configlisten.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實現(xiàn)批量監(jiān)聽頁面并發(fā)送郵件的詳細內容,更多關于python監(jiān)聽頁面的資料請關注腳本之家其它相關文章!
相關文章
Python實現(xiàn)matplotlib顯示中文的方法詳解
這篇文章主要介紹了Python實現(xiàn)matplotlib顯示中文的方法,結合實例形式詳細總結分析了Python使用matplotlib庫繪圖時顯示中文的相關操作技巧與注意事項,需要的朋友可以參考下2018-02-02
使用TensorFlow-Slim進行圖像分類的實現(xiàn)
這篇文章主要介紹了使用TensorFlow-Slim進行圖像分類的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-12-12
深入探究Python如何實現(xiàn)100個并發(fā)請求
在Web開發(fā)和數(shù)據抓取等領域,并發(fā)請求是提高效率和性能的重要手段,本文將深入探討如何使用Python實現(xiàn)100個并發(fā)請求,感興趣的小伙伴可以了解下2025-02-02

