first commit
This commit is contained in:
82
config/base.py
Normal file
82
config/base.py
Normal file
@@ -0,0 +1,82 @@
|
||||
"""
|
||||
基础配置类
|
||||
包含所有环境通用的配置项
|
||||
"""
|
||||
import os
|
||||
from datetime import timedelta
|
||||
|
||||
class Config:
|
||||
"""
|
||||
基础配置类
|
||||
所有环境配置都继承此类
|
||||
"""
|
||||
|
||||
# Flask基础配置
|
||||
SECRET_KEY = os.environ.get('SECRET_KEY')
|
||||
if not SECRET_KEY:
|
||||
raise ValueError("SECRET_KEY 环境变量未设置,请在.env文件中配置")
|
||||
|
||||
# 数据库配置
|
||||
SQLALCHEMY_DATABASE_URI = os.environ.get('DATABASE_URL') or 'sqlite:///app.db'
|
||||
SQLALCHEMY_TRACK_MODIFICATIONS = False
|
||||
SQLALCHEMY_ENGINE_OPTIONS = {
|
||||
'pool_pre_ping': True, # 连接前检查连接是否有效
|
||||
'pool_recycle': 300, # 连接回收时间(秒)
|
||||
}
|
||||
|
||||
# 跨域配置
|
||||
CORS_ORIGINS = os.environ.get('CORS_ORIGINS', '*').split(',')
|
||||
|
||||
# 日志配置
|
||||
LOG_LEVEL = os.environ.get('LOG_LEVEL', 'INFO')
|
||||
LOG_FILE = os.environ.get('LOG_FILE', 'logs/app.log')
|
||||
|
||||
# 缓存配置
|
||||
CACHE_TYPE = os.environ.get('CACHE_TYPE', 'simple')
|
||||
CACHE_DEFAULT_TIMEOUT = int(os.environ.get('CACHE_DEFAULT_TIMEOUT', 300))
|
||||
|
||||
# Redis缓存配置(当CACHE_TYPE=redis时使用)
|
||||
REDIS_URL = os.environ.get('REDIS_URL', 'redis://localhost:6379/0')
|
||||
|
||||
# 会话配置
|
||||
PERMANENT_SESSION_LIFETIME = timedelta(
|
||||
hours=int(os.environ.get('SESSION_LIFETIME_HOURS', 24))
|
||||
)
|
||||
|
||||
# 文件上传配置
|
||||
MAX_CONTENT_LENGTH = int(os.environ.get('MAX_CONTENT_LENGTH', 16 * 1024 * 1024)) # 16MB
|
||||
UPLOAD_FOLDER = os.environ.get('UPLOAD_FOLDER', 'uploads')
|
||||
|
||||
# 安全配置
|
||||
WTF_CSRF_ENABLED = os.environ.get('WTF_CSRF_ENABLED', 'True').lower() == 'true'
|
||||
WTF_CSRF_TIME_LIMIT = int(os.environ.get('WTF_CSRF_TIME_LIMIT', 3600))
|
||||
|
||||
@staticmethod
|
||||
def init_app(app):
|
||||
"""
|
||||
初始化应用配置
|
||||
创建必要的目录和配置日志
|
||||
"""
|
||||
# 创建必要的目录
|
||||
os.makedirs('logs', exist_ok=True)
|
||||
os.makedirs('uploads', exist_ok=True)
|
||||
|
||||
# 配置日志
|
||||
import logging
|
||||
from logging.handlers import RotatingFileHandler
|
||||
|
||||
if not app.debug and not app.testing:
|
||||
file_handler = RotatingFileHandler(
|
||||
Config.LOG_FILE,
|
||||
maxBytes=10240000, # 10MB
|
||||
backupCount=10
|
||||
)
|
||||
file_handler.setFormatter(logging.Formatter(
|
||||
'%(asctime)s %(levelname)s: %(message)s [in %(pathname)s:%(lineno)d]'
|
||||
))
|
||||
file_handler.setLevel(getattr(logging, Config.LOG_LEVEL))
|
||||
app.logger.addHandler(file_handler)
|
||||
|
||||
app.logger.setLevel(getattr(logging, Config.LOG_LEVEL))
|
||||
app.logger.info('应用启动')
|
||||
|
||||
Reference in New Issue
Block a user