ホームページ > バックエンド開発 > PHPチュートリアル > PHP アンチインジェクション フィルタリングの顧客提出 $_GET および $_POST パラメーター_PHP チュートリアル

PHP アンチインジェクション フィルタリングの顧客提出 $_GET および $_POST パラメーター_PHP チュートリアル

WBOY
リリース: 2016-07-13 17:10:42
オリジナル
966 人が閲覧しました

以下は、PHP ページが SQL を挿入するのを防ぐためのプログラム コードです。必要な方は参照してください。

次のコードは、php の $_GET パラメータと $_POST パラメータのフィルタリングを実装します

コードは次のとおりです コードをコピー

/**
*安全上の注意事項
*/
関数Add_S($array)
{
foreach($array as $key=>$value)
{
if(!is_array($value))
{
$value = get_magic_quotes_gpc()?$value:addslashes($value);
$array[$key]=filterHtml($value);
}
それ以外
{
Add_S($array[$key]);
}
}
$array を返します;
}
関数 glstr($var) {

if (is_array($var)) {
return Add_S($var);
}
elseif(strlen($var)){
$var = get_magic_quotes_gpc()?$var:addslashes($var);

$var = filterHtml($var);
}
$var を返します;
}
関数 filterHTML($html)
{
$farr = 配列(
"/[^>]*?)>/eis",
"/]*?)>/eis",
"/<(script|i?frame|style|title|form)(.*?)/eis",
"/(]*?s+)on[a-z]+s*?=("|')([^2]*)2([^>]*?>)/isU" ,//JavaScriptのonイベントをフィルタリング
"/s+/",//余分な空白をフィルタリングします
);
$tarr = 配列(
「」、
「」、
「」、
「14」、
「」、
);
$html = preg_replace( $farr,$tarr,$html);
$html を返します;
}
if (sizeof($_GET)) {
foreach($_GET as $key => $value) {
$_GET[$key] = glstr($value); //
}

}
if (sizeof($_POST)) {
foreach($_POST as $key => $value) {
$_POST[$key] = glstr($value); //
}
}

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/629648.html技術記事以下は、php ページが SQL を挿入するのを防ぐプログラム コードです。必要な方は参照してください。 次のコードは、php の $_GET パラメーターと $_POST パラメーターのフィルターを実装します。コードは次のとおりです。 /** * Security...
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート