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
Lepaskan: 2024-11-09 02:54:02
asal
360 orang telah melayarinya

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'
Salin selepas log masuk

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)))
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan