import os import sys def get_base_path(): """获取运行时路径 (兼容打包后的 exe 和开发环境)""" if getattr(sys, 'frozen', False): return os.path.dirname(sys.executable) return os.path.dirname(os.path.abspath(__file__)) def get_static_path(): """获取 dist 静态资源路径""" if getattr(sys, 'frozen', False): return os.path.join(sys._MEIPASS, 'dist') return os.path.join(os.path.dirname(os.path.abspath(__file__)), 'dist') class Config: BASE_DIR = get_base_path() # 数据库路径:保存在运行目录下,文件名为 monitor_data.db # Windows 下路径需要注意转义,这里使用 os.path.join 最安全 SQLALCHEMY_DATABASE_URI = f'sqlite:///{os.path.join(BASE_DIR, "monitor_data.db")}' SQLALCHEMY_TRACK_MODIFICATIONS = False # --- 定时任务配置 --- SCHEDULER_API_ENABLED = True SCHEDULER_TIMEZONE = "Asia/Shanghai" # 👈 必须加这个,否则 APScheduler 可能报错 # --- 爬虫配置 (Service层会读取这里) --- CRAWLER_CONFIG = { "106": { "base_url": "http://106.75.72.40:7500/api/proxy/tcp", "primary_auth": "Basic YWRtaW46bGljYWhr", "login_payload": {"username": "admin", "password": "licahk", "recaptcha": ""} }, "82": { "base_url": "http://82.156.1.111/weather/php", "login": {'username': 'renlixin', 'password': 'licahk', 'login': '123'} } }