import os import sys def get_base_path(): """获取运行时路径 (兼容打包后的 exe 和开发环境)""" if getattr(sys, 'frozen', False): # 打包后:exe 所在目录 return os.path.dirname(sys.executable) # 开发时:当前文件所在目录 return os.path.dirname(os.path.abspath(__file__)) def get_static_path(): """获取 web_dist 静态资源路径""" if getattr(sys, 'frozen', False): return os.path.join(sys._MEIPASS, 'web_dist') return os.path.join(os.path.dirname(os.path.abspath(__file__)), 'web_dist') class Config: BASE_DIR = get_base_path() # 规范化 instance 目录 INSTANCE_DIR = os.path.join(BASE_DIR, 'instance') # 确保 instance 目录存在(防止第一次运行时报错) if not os.path.exists(INSTANCE_DIR): try: os.makedirs(INSTANCE_DIR) except Exception: pass # [修改] 绝对路径拼接,并强制将 Windows 的 \ 转换为 /,避免 SQLite URI 报错 # 最终结果类似: sqlite:///D:/project/instance/monitor_data.db _db_path = os.path.join(INSTANCE_DIR, "monitor_data.db").replace('\\', '/') SQLALCHEMY_DATABASE_URI = f'sqlite:///{_db_path}' SQLALCHEMY_TRACK_MODIFICATIONS = False # --- 定时任务配置 --- SCHEDULER_API_ENABLED = True SCHEDULER_TIMEZONE = "Asia/Shanghai" # --- 爬虫配置 --- 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'} } } # --- IoT 物联网卡接口配置 --- IOT_BASE_URL = "https://iot.huskyiot.cn" IOT_APP_ID = "44aQHTpx" IOT_SECRET = "26833abf8786167a5cff5355cfc249981985124a" IOT_USERNAME = "yrsy" IOT_PASSWORD = "123456789" IOT_URL_LOGIN = "/iot-api/system/auth/v1/get/token" IOT_URL_PAGE = "/iot-api/platform/v1/card-info/query/page" IOT_URL_DETAIL = "/iot-api/platform/v1/card-info/query/batch-card-detail" # [Debug] 打印路径确认 print(f"配置文件已加载,数据库路径: {SQLALCHEMY_DATABASE_URI}")