Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimana untuk Membuat Jadual dengan Selamat dengan Nama Dinamik dalam SQLite?

Bagaimana untuk Membuat Jadual dengan Selamat dengan Nama Dinamik dalam SQLite?

Patricia Arquette
Patricia Arquetteasal
2024-11-09 02:54:02359semak imbas

How to Safely Create Tables with Dynamic Names in SQLite?

Nama Jadual Pembolehubah dalam SQLite

Dalam SQLite, anda mungkin menghadapi situasi di mana anda perlu mencipta jadual secara dinamik dengan nama yang disimpan dalam pembolehubah. Walaupun biasa menggunakan pembina rentetan untuk tujuan ini, kebimbangan keselamatan timbul kerana potensi serangan suntikan SQL.

Malangnya, SQLite tidak membenarkan penggantian parameter untuk nama jadual. Walau bagaimanapun, amalan terbaik menentukan penggunaan penggantian parameter untuk melindungi daripada serangan suntikan.

Penyelesaian Alternatif: Menggosok Pembolehubah

Memandangkan nama jadual tidak boleh diparameterkan secara langsung, a penyelesaian yang berdaya maju adalah dengan menggosok pembolehubah yang mengandungi nama jadual sebelum menghantarnya ke CREATE TABLE pernyataan.

Anda boleh mencipta fungsi yang membersihkan pembolehubah dengan mengalih keluar semua aksara kecuali abjad angka. Sebagai contoh, fungsi Python berikut menghilangkan tanda baca, ruang kosong dan aksara bukan abjad angka yang lain:

def scrub(table_name):
    return ''.join( chr for chr in table_name if chr.isalnum() )

scrub('); drop tables --') # returns 'droptables'

Menggunakan fungsi ini, anda boleh mencipta jadual dengan nama jadual berubah, memastikan aksara berniat jahat dialih keluar , mencegah serangan suntikan:

table_name = 'StarFrame' + self.name
cursor.execute('CREATE TABLE {} (etc etc)'.format(scrub(table_name)))

Atas ialah kandungan terperinci Bagaimana untuk Membuat Jadual dengan Selamat dengan Nama Dinamik dalam SQLite?. 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