Rumah >pembangunan bahagian belakang >tutorial php >Penapisan data PHP: menghalang suntikan perisian hasad

Penapisan data PHP: menghalang suntikan perisian hasad

王林
王林asal
2023-07-30 22:41:171645semak imbas

Penapisan Data PHP: Cegah Suntikan Perisian Hasad

Ikhtisar:
Dengan perkembangan Internet, isu keselamatan rangkaian telah menarik perhatian ramai. Suntikan perisian hasad adalah aspek penting dalam keselamatan siber. Sebagai bahasa pengaturcaraan sebelah pelayan yang biasa digunakan, PHP juga perlu menapis data masuk untuk mengelakkan suntikan perisian hasad. Artikel ini akan memperkenalkan beberapa kaedah penapisan data PHP biasa, dengan contoh kod.

1. Kaedah penapisan asas

  1. fungsi htmlspecialchars
    fungsi htmlspecialchars digunakan untuk melepaskan aksara khas untuk mengelakkan suntikan perisian hasad. Contohnya, larikan aksara khas dalam kod HTML untuk menghalangnya daripada dilaksanakan sebagai kod.

Contoh kod:

$username = $_POST['username'];
$password = $_POST['password'];

$username = htmlspecialchars($username);
$password = htmlspecialchars($password);
  1. strip_tags fungsi
    strip_tags fungsi digunakan untuk menanggalkan tag kod HTML dan hanya menyimpan kandungan teks. Kaedah ini boleh digunakan untuk menapis input pengguna untuk mengelakkan serangan suntikan perisian hasad melalui tag HTML.

Kod contoh:

$content = $_POST['content'];

$content = strip_tags($content);

2. Penapisan ungkapan biasa

Ungkapan biasa ialah alat pemprosesan rentetan yang berkuasa yang boleh menapis data mengikut peraturan yang sepadan. Ungkapan biasa boleh digunakan untuk menyemak sama ada data yang dimasukkan oleh pengguna memenuhi keperluan dan menapisnya jika ia tidak memenuhi keperluan.

Kod contoh:

$email = $_POST['email'];

if (!preg_match("/^[a-zA-Z0-9]+@[a-zA-Z0-9]+.[a-zA-Z0-9]+$/", $email)) {
    // 不符合邮箱格式要求,进行过滤处理
    $email = "";
}

3. Penapisan pangkalan data

  1. Gunakan penyata yang disediakan
    Pernyataan yang diproses secara berkesan boleh menghalang serangan suntikan SQL. Apabila menggunakan pernyataan yang disediakan, input data oleh pengguna mesti ditapis terlebih dahulu, dan kemudian data yang ditapis mesti terikat dengan pernyataan SQL.

Contoh kod:

$pdo = new PDO("mysql:host=localhost;dbname=test", "username", "password");

$username = $_POST['username'];
$password = $_POST['password'];

$stmt = $pdo->prepare("SELECT * FROM users WHERE username = :username AND password = :password");
$stmt->bindParam(':username', $username);
$stmt->bindParam(':password', $password);
$stmt->execute();
  1. Menggunakan kaedah penapisan dalam PDO
    PDO menyediakan beberapa kaedah terbina dalam untuk menapis data. Sebagai contoh, kaedah bindParam boleh menentukan jenis data parameter untuk menghalang suntikan perisian hasad.

Contoh kod:

$pdo = new PDO("mysql:host=localhost;dbname=test", "username", "password");

$username = $_POST['username'];
$password = $_POST['password'];

$stmt = $pdo->prepare("SELECT * FROM users WHERE username = ? AND password = ?");
$stmt->bindParam(1, $username, PDO::PARAM_STR);
$stmt->bindParam(2, $password, PDO::PARAM_STR);
$stmt->execute();

Kesimpulan:

Dalam pembangunan PHP, menapis data masuk adalah langkah yang sangat penting untuk mencegah suntikan perisian hasad dengan berkesan. Artikel ini memperkenalkan beberapa kaedah penapisan data PHP biasa, termasuk kaedah penapisan asas, penapisan ungkapan biasa dan penapisan pangkalan data. Dengan memilih dan menggunakan kaedah penapisan ini dengan betul, keselamatan aplikasi boleh dipertingkatkan dan keselamatan data pengguna boleh dilindungi.

Nota: Kod di atas adalah untuk rujukan sahaja, dan aplikasi sebenar perlu dilaraskan dan diperbaiki dengan sewajarnya mengikut situasi tertentu. Pada masa yang sama, penapisan data hanyalah satu langkah untuk mencegah suntikan perisian hasad, dan langkah keselamatan lain perlu diambil kira untuk memastikan keselamatan keseluruhan sistem.

Atas ialah kandungan terperinci Penapisan data PHP: menghalang suntikan perisian hasad. 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