ThinkPHP6 セキュリティ保護ガイド: 一般的な攻撃の防止
インターネットの急速な発展に伴い、ネットワーク セキュリティの問題はますます顕著になり、さまざまな攻撃手法が際限なく出現しています。 。 ThinkPHP6 は、人気のある PHP オープンソース フレームワークとして、セキュリティの面でも注目を集めています。この記事では、開発者がシステムのセキュリティを向上できるように、いくつかの一般的な攻撃方法と、対応するセキュリティ保護を ThinkPHP6 に実装する方法を紹介します。
SQL インジェクションは、最も一般的な攻撃手法の 1 つであり、攻撃者は悪意のある SQL ステートメントを構築することによって、データベース内のデータを取得、変更、または削除します。 ThinkPHP6 では、SQL ステートメントを使用してパラメータをバインドするか、Query オブジェクトを使用することで SQL インジェクションを防ぐことができます。以下は、バインド パラメーター メソッドを使用したコード例です。
use thinkacadeDb; $id = input('id'); $sql = "SELECT * FROM users WHERE id=:id"; $result = Db::query($sql, ['id'=>$id]);
XSS (クロスサイト スクリプティング) 攻撃は、被害者のブラウザーで実行されるように設計されています。悪意のあるスクリプトは、Web ページのコンテンツを改ざんすることで攻撃目的を達成します。 XSS 攻撃を防ぐために、ThinkPHP6 は XSS フィルターとトランスコーディング方法を提供します。以下は、出力フィルターを使用したコード例です。
use thinkhelperStr; $content = input('content'); echo Str::removeXss($content);
CSRF (クロスサイト リクエスト フォージェリ) 攻撃は、攻撃者が実行リクエストを偽造すると発生します。不正な行為、ユーザーの同意を得た操作。 ThinkPHP6 には組み込みの CSRF 保護メカニズムが用意されており、構成ファイルで CSRF トークンを有効にするだけで保護を実現できます。以下は、CSRF トークンを有効にする構成例です:
//config/app.php 'csrf' => [ 'token_on' => true, ],
次に、フォームに CSRF トークン フィールドを追加します:
<form method="post"> <input type="hidden" name="token" value="{:token()}"> <!-- 其他表单字段 --> </form>
use thinkacadeFilesystem; $file = $request->file('image'); $savePath = 'uploads/'; $info = $file->validate(['size'=>102400,'ext'=>'jpg,png,gif'])->move($savePath); if($info){ $filePath = $savePath.$info->getSaveName(); //文件保存成功 } else { //文件上传失败 echo $file->getError(); }
//config/route.php Route::rule('user/:id', 'index/user/show'); //index/user.php namespace appindexcontroller; class User { public function show($id) { //处理用户信息展示 } }
以上がThinkPHP6 セキュリティ保護ガイド: 一般的な攻撃の防止の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。