ホームページ >バックエンド開発 >PHPチュートリアル >ミニプログラム開発における PHP のセキュリティ保護と攻撃の防止

ミニプログラム開発における PHP のセキュリティ保護と攻撃の防止

PHPz
PHPzオリジナル
2023-07-07 08:55:36954ブラウズ

ミニ プログラム開発における PHP のセキュリティ保護と攻撃の防止

モバイル インターネットの急速な発展に伴い、ミニ プログラムは人々の生活の重要な部分になりました。 PHP は、強力で柔軟なバックエンド開発言語として、小規模プログラムの開発にも広く使用されています。ただし、セキュリティの問題は、プログラム開発において常に注意が必要な側面です。この記事では、小規模プログラム開発における PHP のセキュリティ保護と攻撃防止に焦点を当て、いくつかのコード例を示します。

  1. XSS (クロスサイト スクリプティング攻撃) の防止

XSS 攻撃とは、ハッカーが悪意のあるスクリプト コードを Web ページに挿入し、ユーザーのブラウザでこれらの悪意のあるスクリプト コードを実行させることを意味します。 、こうして攻撃の目的を達成します。 XSS 攻撃を防ぐために、PHP の組み込み関数 htmlspecialchars を使用して、ユーザーが入力したデータをエスケープできます。

サンプル コードは次のとおりです。

$userInput = $_GET['user_input'];
$escapedInput = htmlspecialchars($userInput);
echo $escapedInput;
  1. CSRF (クロスサイト リクエスト フォージェリ) の防止

CSRF 攻撃とは、ハッカーがログを偽造することを指します。 - ユーザーの身元を偽り、ユーザーを騙して知らないうちに操作を実行させ、それによって攻撃の目的を達成します。 CSRF 攻撃を防ぐために、PHP の組み込み関数 session_start() と csrf_token を使用してトークンを生成し、重要な操作が開始されるたびにトークンを検証できます。

サンプル コードは次のとおりです。

session_start();
if (empty($_SESSION['csrf_token'])) {
    $_SESSION['csrf_token'] = md5(uniqid(mt_rand(), true));
}
$csrfToken = $_SESSION['csrf_token'];

// 显示表单
echo '<form action="submit.php" method="post">';
echo '<input type="hidden" name="csrf_token" value="' . $csrfToken . '">';
echo '<input type="submit" value="提交">';
echo '</form>';

// 提交表单时验证令牌
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
    if ($_POST['csrf_token'] !== $csrfToken) {
        die('CSRF攻击');
    }
    // 其他处理逻辑
}
  1. SQL インジェクションの防止

SQL インジェクションとは、ハッカーが悪意のある SQL コードをユーザー入力に挿入することを意味します。 、データベース内のデータを変更したり、削除したりすることもできます。 SQL インジェクションを防ぐために、PHP の組み込み関数 mysqli_real_escape_string を使用して、ユーザーが入力したデータをエスケープできます。

サンプル コードは次のとおりです。

$db = mysqli_connect('localhost', 'user', 'password', 'database');
if (mysqli_connect_errno()) {
    die('数据库连接失败');
}

$userInput = $_GET['user_input'];
$escapedInput = mysqli_real_escape_string($db, $userInput);

$query = "SELECT * FROM users WHERE username='$escapedInput'";
$result = mysqli_query($db, $query);
while ($row = mysqli_fetch_assoc($result)) {
    // 处理查询结果
}
mysqli_close($db);

要約すると、小規模なプログラムの開発では、PHP のセキュリティ保護と攻撃防止が非常に重要です。この記事では、XSS、CSRF、SQL インジェクションの 3 つの側面からセキュリティを防止するためのサンプル コードをいくつか紹介します。ただし、セキュリティ保護は継続的なプロセスであり、開発者も現在のセキュリティ脅威に細心の注意を払い、状況に応じてタイムリーに適切な予防措置を講じる必要があります。この記事の内容が小規模なプログラム開発者にとって何らかの助けになれば幸いです。

以上がミニプログラム開発における PHP のセキュリティ保護と攻撃の防止の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。