2024-02-08 21:18:27 +08:00
|
|
|
|
import sqlite3
|
|
|
|
|
import sys
|
|
|
|
|
import traceback
|
|
|
|
|
|
2024-02-17 22:21:31 +08:00
|
|
|
|
import requests
|
|
|
|
|
|
|
|
|
|
from app.person import Me
|
|
|
|
|
|
2024-02-08 21:18:27 +08:00
|
|
|
|
|
|
|
|
|
class ExceptionHanding:
|
|
|
|
|
def __init__(self, exc_type, exc_value, traceback_):
|
|
|
|
|
self.exc_type = exc_type
|
|
|
|
|
self.exc_value = exc_value
|
|
|
|
|
self.traceback = traceback_
|
|
|
|
|
self.error_message = ''.join(traceback.format_exception(exc_type, exc_value, traceback_))
|
|
|
|
|
|
|
|
|
|
def parser_exc(self):
|
|
|
|
|
if isinstance(self.exc_value, PermissionError):
|
2024-02-09 17:38:15 +08:00
|
|
|
|
return f'权限错误,请使用管理员身份运行并将文件夹设置为可读写'
|
2024-02-08 21:18:27 +08:00
|
|
|
|
elif isinstance(self.exc_value, sqlite3.DatabaseError):
|
|
|
|
|
return '数据库错误,请删除app文件夹后重启电脑再运行软件'
|
|
|
|
|
elif isinstance(self.exc_value, OSError) and self.exc_value.errno == 28:
|
|
|
|
|
return '空间磁盘不足,请预留足够多的磁盘空间以供软件正常运行'
|
|
|
|
|
elif isinstance(self.exc_value, TypeError) and 'NoneType' in str(self.exc_value) and 'not iterable' in str(
|
|
|
|
|
self.exc_value):
|
|
|
|
|
return '数据库错误,请删除app文件夹后重启电脑再运行软件'
|
|
|
|
|
else:
|
2024-02-14 19:07:44 +08:00
|
|
|
|
return '未知错误类型,可参考 https://blog.lc044.love/post/7 解决该问题\n温馨提示:重启电脑可解决80%的问题'
|
2024-02-08 21:18:27 +08:00
|
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
|
errmsg = f'{self.error_message}\n{self.parser_exc()}'
|
|
|
|
|
return errmsg
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def excepthook(exc_type, exc_value, traceback_):
|
|
|
|
|
# 将异常信息转为字符串
|
|
|
|
|
|
|
|
|
|
# 在这里处理全局异常
|
|
|
|
|
|
|
|
|
|
error_message = ExceptionHanding(exc_type, exc_value, traceback_)
|
|
|
|
|
txt = '您可添加QQ群发送log文件以便解决该问题'
|
|
|
|
|
msg = f"Exception Type: {exc_type.__name__}\nException Value: {exc_value}\ndetails: {error_message}\n\n{txt}"
|
|
|
|
|
print(msg)
|
|
|
|
|
|
|
|
|
|
# 调用原始的 excepthook,以便程序正常退出
|
|
|
|
|
sys.__excepthook__(exc_type, exc_value, traceback_)
|
2024-02-17 22:21:31 +08:00
|
|
|
|
|
|
|
|
|
def send_error_msg( message):
|
|
|
|
|
url = "http://api.lc044.love/error"
|
|
|
|
|
if not message:
|
|
|
|
|
return {
|
|
|
|
|
'code': 201,
|
|
|
|
|
'errmsg': '日志为空'
|
|
|
|
|
}
|
|
|
|
|
data = {
|
|
|
|
|
'username': Me().wxid,
|
|
|
|
|
'error': message
|
|
|
|
|
}
|
|
|
|
|
try:
|
|
|
|
|
response = requests.post(url, json=data)
|
|
|
|
|
if response.status_code == 200:
|
|
|
|
|
resp_info = response.json()
|
|
|
|
|
return resp_info
|
|
|
|
|
else:
|
|
|
|
|
return {
|
|
|
|
|
'code': 503,
|
|
|
|
|
'errmsg': '服务器错误'
|
|
|
|
|
}
|
|
|
|
|
except:
|
|
|
|
|
return {
|
|
|
|
|
'code': 404,
|
|
|
|
|
'errmsg': '客户端错误'
|
|
|
|
|
}
|