修复sql特殊密码无法连接的问题

This commit is contained in:
try2love
2025-11-06 13:59:33 +00:00
parent 01dc676fd0
commit 148aafb2a8
4 changed files with 13 additions and 8 deletions
+3 -2
View File
@@ -13,6 +13,7 @@ import argparse
from pathlib import Path
from datetime import datetime, timedelta
from loguru import logger
from urllib.parse import quote_plus
# 添加项目根目录到路径
project_root = Path(__file__).parent.parent
@@ -36,9 +37,9 @@ class DatabaseManager:
try:
dialect = (settings.DB_DIALECT or "mysql").lower()
if dialect in ("postgresql", "postgres"):
url = f"postgresql+psycopg://{settings.DB_USER}:{settings.DB_PASSWORD}@{settings.DB_HOST}:{settings.DB_PORT}/{settings.DB_NAME}"
url = f"postgresql+psycopg://{settings.DB_USER}:{quote_plus(settings.DB_PASSWORD)}@{settings.DB_HOST}:{settings.DB_PORT}/{settings.DB_NAME}"
else:
url = f"mysql+pymysql://{settings.DB_USER}:{settings.DB_PASSWORD}@{settings.DB_HOST}:{settings.DB_PORT}/{settings.DB_NAME}?charset={settings.DB_CHARSET}"
url = f"mysql+pymysql://{settings.DB_USER}:{quote_plus(settings.DB_PASSWORD)}@{settings.DB_HOST}:{settings.DB_PORT}/{settings.DB_NAME}?charset={settings.DB_CHARSET}"
self.engine = create_engine(url, future=True)
logger.info(f"成功连接到数据库: {settings.DB_NAME}")
except Exception as e:
+2 -1
View File
@@ -13,7 +13,7 @@ from __future__ import annotations
import asyncio
import os
from typing import Optional
from urllib.parse import quote_plus
from loguru import logger
from sqlalchemy.ext.asyncio import create_async_engine
@@ -49,6 +49,7 @@ def _build_database_url() -> str:
port = str(settings.DB_PORT or ("3306" if dialect == "mysql" else "5432"))
user = settings.DB_USER or "root"
password = settings.DB_PASSWORD or ""
password = quote_plus(password)
db_name = settings.DB_NAME or "mindspider"
if dialect in ("postgresql", "postgres"):