Rumah Kewangan Peribadi Bagaimana Menghindari Suntikan Kod di C ++ - dummies

Bagaimana Menghindari Suntikan Kod di C ++ - dummies

Video: Tips Mengatasi Tinta Kering Di Cartridge 2025

Video: Tips Mengatasi Tinta Kering Di Cartridge 2025
Anonim

Peraturan pertama mengelakkan kod suntikan ke dalam program C ++ tidak pernah, pernah, membenarkan input pengguna diproses oleh juru bahasa bahasa tujuan umum. Kesalahan biasa dengan suntikan SQL adalah bahawa program menerima input pengguna seolah-olah ia sentiasa diterima dan memasukkannya ke dalam pertanyaan SQL yang kemudiannya dihantar ke enjin pangkalan data untuk diproses.

Sebagai contoh, program yang meminta input pengguna pada tarikh boleh digodam. Pendekatan paling selamat dan paling mesra pengguna adalah untuk menyediakan pengguna graf grafik kalendar yang mana ia boleh memilih tarikh mula dan akhir. Program ini kemudiannya akan membuat tarikh berdasarkan apa yang diklik pengguna.

Jika ini tidak mungkin, program ini semestinya perlu memeriksa input dengan teliti untuk memastikan input dalam format yang betul untuk tarikh, dalam kes ini yyyy / mm / dd < - dengan kata lain, empat digit diikuti dengan slit diikuti oleh dua digit dan slash dan akhirnya dua digit lagi. Tiada lagi yang perlu dipertimbangkan sebagai input yang boleh diterima. Kadangkala anda tidak boleh menjadi spesifik mengenai format tersebut. Sekiranya anda perlu membenarkan pengguna memasuki teks yang fleksibel, maka anda boleh sekurang-kurangnya mengelakkan aksara khas. Contohnya, tidak mustahil untuk melakukan suntikan kod SQL tanpa menggunakan sebutan tunggal atau berganda.

Anda tidak boleh memasukkan tag HTML tanpa menggunakan tanda kurang daripada (). Atau anda hanya boleh mengambil pendekatan bahawa apa-apa selain teks ASCII tidak akan diterima:

// semak beberapa rentetan 'untuk memastikan ia bersaiz ASCII size_type off = s. find_first_not_of ("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ01234567890_"); jika (off! = string:: npos) {cerr << "errorn";}

Kod ini mencari rentetan

s untuk karakter yang bukan salah satu aksara A melalui Z,, 0 hingga 9, atau garis bawah. Jika ia menemui watak sedemikian, maka program menolak input.

Jika anda hanya membenarkan watak-watak Latin yang ditunjukkan di sini, permohonan anda tidak boleh digunakan di banyak pasaran asing seperti yang tidak menggunakan set aksara Bahasa Inggeris (seperti bahasa Arab, Cina, Ibrani atau Rusia, untuk menamakan beberapa). Anda mungkin perlu mengambil pendekatan bertentangan dan hanya mencari watak buruk.
Bagaimana Menghindari Suntikan Kod di C ++ - dummies

Pilihan Editor

Bagaimana Menghubungkan Item Menu ke Kategori di Joomla - dummies

Bagaimana Menghubungkan Item Menu ke Kategori di Joomla - dummies

Untuk artikel yang dikategorikan dalam Joomla untuk dilihat oleh pengguna laman web anda, anda perlu memautkan item menu Joomla anda ke kategori Joomla yang mengandungi artikel yang ingin anda siarkan. Dengan menyambungkan kategori ke item menu, semua artikel dalam kategori boleh didapati melalui item menu yang berkaitan. Untuk membuat ...

Cara Memasang Joomla CMS pada Server Jauh - dummies

Cara Memasang Joomla CMS pada Server Jauh - dummies

Sebaik sahaja anda telah memuatkan fail Joomla yang tidak diturunkan di pelayan jauh dan sediakan MySQL untuk Joomla, anda sudah bersedia untuk memasang Sistem Pengurusan Kandungan Joomla (CMS). Navigasi ke tapak anda di pelayan tuan rumah. Anda melihat halaman pemasangan Joomla pertama. Pilih bahasa. Klik Seterusnya. Semua item dalam pane bahagian atas ...

Cara Membiarkan Pengguna Menguruskan Akaun Sendiri di Joomla - dummies

Cara Membiarkan Pengguna Menguruskan Akaun Sendiri di Joomla - dummies

Walaupun anda boleh mengurus pengguna dari hujung belakang, Joomla menyediakan kemudahan yang baik yang membolehkan pengguna menguruskan diri mereka juga. Anda boleh membuat halaman di mana pengguna boleh mendaftar, log masuk, menetapkan semula kata laluan mereka, diingatkan kata laluan mereka, dan sebagainya. Buat laman pengurusan pengguna Untuk membuat halaman yang membolehkan pengguna mengurus sendiri, anda ...

Pilihan Editor

Pengguna dan Definisi SharePoint berbeza - dummies

Pengguna dan Definisi SharePoint berbeza - dummies

SharePoint mempunyai banyak jenis pengguna yang berbeza, dan bergantung di mana peranan anda sesuai , anda mungkin mempunyai pengalaman yang sangat berbeza dari pengguna SharePoint yang lain. Sebagai contoh, anda mungkin ditugaskan untuk membuat dan mentadbir laman web SharePoint untuk pasukan anda. Dalam kes ini, anda mungkin melihat ke hadapan fungsi yang luas SharePoint ...

Dan Microblog dalam SharePoint - dummies

Dan Microblog dalam SharePoint - dummies

Microblogging dibuat terkenal oleh Twitter. SharePoint 2013 membawa mikroblogging ke dunia korporat. Menggunakan Twitter, anda menghantar mesej ringkas kepada dunia. Anda boleh mengikuti orang lain dan menarik pengikut anda sendiri. Anda menyebut orang lain menggunakan simbol @ yang diikuti dengan nama mereka dan boleh menanda topik menggunakan # ...

Mengeksport Table Akses ke Senarai Dalam Talian SharePoint - dummies

Mengeksport Table Akses ke Senarai Dalam Talian SharePoint - dummies

Jika anda mempunyai meja dalam Akses yang ada pangkalan data yang anda ingin sediakan untuk ahli pasukan anda yang tidak mempunyai aplikasi MS Access 2010, cara terbaik untuk melakukan ini adalah untuk mengeksport jadual tersebut ke dalam senarai SharePoint. Ikuti langkah-langkah berikut: Dari pangkalan data anda, klik kanan pada jadual di ...

Pilihan Editor

Penyediaan aSVAB: Akar - patung

Penyediaan aSVAB: Akar - patung

Menjadi akrab dengan akar untuk ASVAB. Akar adalah kebalikan dari kuasa atau eksponen. Terdapat pelbagai jenis akar tak terhingga. Anda mempunyai akar kuadrat, yang bermaksud "membuang" asas kepada kuasa kedua; akar kubus, yang bermaksud "membuang" asas yang dinaikkan kepada kuasa ketiga; akar yang keempat, untuk ...

ASVAB Penyediaan: Bekerja dengan Perpuluhan - patung

ASVAB Penyediaan: Bekerja dengan Perpuluhan - patung

Anda perlu tahu bagaimana untuk bekerja dengan perpuluhan untuk ASBAB . Perpuluhan adalah kaedah menulis nombor pecahan tanpa menggunakan pengangka dan penyebut. Anda boleh menulis pecahan 7/10 sebagai perpuluhan 0. 7; anda menyebutnya "tujuh persepuluh" atau "titik nol tujuh. "Tempoh atau titik perpuluhan menunjukkan bahawa nombor itu ...

ASVAB Subtest Details - dummies

ASVAB Subtest Details - dummies

Tergantung di mana dan untuk tujuan apa yang anda ambil ujian, anda mungkin menghadapi beberapa versi ASVAB. Versi terkomputer dari ASVAB (CAT-ASVAB) mengandungi sembilan subtest masa yang berasingan. Pada CAT-ASVAB, Maklumat Auto dan Maklumat Kedai dipisahkan kepada dua ujian berbeza, sedangkan mereka digabungkan pada versi kertas. Lihatlah ...