Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimana untuk Menyambung ke Pangkalan Data dengan Aksara Khas dalam Kata Laluan?

Bagaimana untuk Menyambung ke Pangkalan Data dengan Aksara Khas dalam Kata Laluan?

Linda Hamilton
Linda Hamiltonasal
2024-11-10 15:42:021068semak imbas

How to Connect to a Database with Special Characters in the Password?

Menyambung ke Pangkalan Data Walaupun Aksara Khas dalam Kata Laluan

Apabila membuat sambungan pangkalan data dengan SQLalchemy, pengguna sering menghadapi cabaran apabila kata laluan mereka mengandungi khas watak. Aksara ini boleh mengganggu sintaks rentetan sambungan, yang membawa kepada ralat sambungan.

Untuk menangani isu ini, pengaturcara biasanya menggunakan alternatif, seperti menggunakan engine.URL.create() dan menyediakan bukti kelayakan secara eksplisit. Walau bagaimanapun, mengekalkan rentetan sambungan yang kemas selalunya diutamakan untuk kebolehbacaan dan kebolehselenggaraan.

Nasib baik, wujud penyelesaian yang membenarkan pengekodan kata laluan dalam rentetan sambungan. Dengan pengekodan URL bahagian kata laluan, aksara khas ditukar kepada format yang boleh dihuraikan dengan betul:

from urllib.parse import quote_plus
from sqlalchemy.engine import create_engine

engine = create_engine(
    "postgres://user:%s@host/database" % quote_plus("p@ss")
)

Fungsi quote_plus yang disediakan oleh urllib.parse melaksanakan pengekodan URL yang diperlukan, memastikan sebarang aksara khas dalam kata laluan diwakili dengan sewajarnya.

Di bawah hud, kelas URL sambungan pangkalan data SQLAlchemy mengikut pendekatan yang serupa. Apabila menukar tika URL kepada rentetan, ia melepaskan kata laluan menggunakan teknik pengekodan URL yang sama, memastikan keserasian dengan proses sambungan pangkalan data.

Atas ialah kandungan terperinci Bagaimana untuk Menyambung ke Pangkalan Data dengan Aksara Khas dalam Kata Laluan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn