ホームページ バックエンド開発 PHPチュートリアル PHPのセキュリティ関連の問題

PHPのセキュリティ関連の問題

Jun 13, 2016 pm 01:10 PM
mysql php select

PHPのセキュリティ問題

Web 開発を行う場合、セットアップ時に「クライアント データを決して信頼しない」という基本的なセキュリティ知識を誰もが知っていると思います。そして、php は型付けが弱い言語です。多くの人は開発プロセス中に型変換を無視しており、パラメータのフィルタリングは計り知れない結果に直接つながります。

フィルター機能を使用しない場合、次のような状況が発生する可能性があります。

データベースに (SQL) が挿入されます。システムのクラッシュ、システム データの損失、ユーザー情報の損失を直接引き起こす可能性があります。 Web サイトがハッキングされた場合、ファイルが処理されると、Web サイトのファイルが削除される可能性があります。

多くの人が PHP セーフ モードをオンにしておけばすべてがうまくいくと考えていることにも言及しておく価値があります。実際にはそうではありません。多くのインジェクターは正面を迂回し、側面攻撃を実行します。

?0×7e、0×27 およびその他の (ASCII コード) 文字列を引用符として使用すると、PHP はそれらをフィルターできません。インジェクションの一般的な方法は、機密データ情報を取得するためにパラメータに多くの mysql?sql 構文を追加することです。

経験値:

and(select1from(select?count(*),concat((select(select(select?concat(0x7e,0x27,phpcms_member.username,0x27,0x7e)from?phpcms_member?limit0,1))from?information_schema.tableslimit0,1),floor(rand(0)*2))x?from?information_schema.tablesgroupby?x)a)and1=1
と(1から(選択? count(*),concat((select(select(select?concat(0x7e,0x27 ,phpcms_member.ユーザー名,0x27,0x7e)from?phpcms_member?制限0,1))from?information_schema .テーブル制限0,1)、 フロア(ランド(0)*2 ))x?from?information_schema.tablesgroupby ?x)a)および1=1

mysql information_schema.tables はすべてのユーザーに表示され、すべてのテーブル構造情報とデータベース情報を見つけることができます。

PHP オープン ソース システムは数多くあります。多くのオープン ソース システムには、誰もが知っているデータ構造と機密情報テーブルがあります。 (もちろん犯罪者も含まれます)

ここでいう機密情報とは、多くの場合、ユーザー情報や管理情報のことです。現在、md5 の徹底的な検索が常に行われています。 md5 で暗号化されたパスワードの多くは、依然として平文に復号化できます。

多くのシステムでは、対応するセキュリティの改善が行われています。

以下に一般的なメソッドを紹介します:

フィルター関数を使用して、php filter security filter function.md5(?md5(‘ユーザーパスワード’) . ‘秘密キー’) で暗号化結果を取得します。一般的に使用される PHP オープン ソース システムのバックグラウンドでは、ディレクトリ名を変更する必要があります。多くのシステム バックエンドは、admin をバックエンドの入り口として直接使用します。 phpmyadmin などのデータベース オペレーティング ソフトウェアを Web サイトの表示ディレクトリに配置しないでください。

待ってください。 。その理由は、現在、そのような管理端末をスキャンするためのスキャン ツールが多数存在しているためです。

以下は衝撃的な写真です

?

mysql 注入

mysql インジェクション

?

mysql インジェクション

出典:?Martin Blog[http://www.blags.org/]

この記事のリンクアドレス:?http://www.blags.org/php-security-issue/


?

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

session_start()関数の重要性は何ですか? session_start()関数の重要性は何ですか? May 03, 2025 am 12:18 AM

session_start()iscrucialinphpformangingusersions.1)itInitiateSanewsessionifnoneExists、2)resumesanexistingsession、および3)SetSessionCookieforcontinuityAcrossRequests、ApplicationslicationSliviseSlikeUserauthicationAnticatent。

フィールドをMySQLテーブルに追加および削除する手順 フィールドをMySQLテーブルに追加および削除する手順 Apr 29, 2025 pm 04:15 PM

MySQLでは、AlterTabletable_nameaddcolumnnew_columnvarchar(255)afterexisting_columnを使用してフィールドを追加し、andtabletable_namedopcolumncolumn_to_dropを使用してフィールドを削除します。フィールドを追加するときは、クエリのパフォーマンスとデータ構造を最適化する場所を指定する必要があります。フィールドを削除する前に、操作が不可逆的であることを確認する必要があります。オンラインDDL、バックアップデータ、テスト環境、および低負荷期間を使用したテーブル構造の変更は、パフォーマンスの最適化とベストプラクティスです。

データ処理と計算にMySQL関数を使用する方法 データ処理と計算にMySQL関数を使用する方法 Apr 29, 2025 pm 04:21 PM

MySQL関数は、データ処理と計算に使用できます。 1.基本的な使用には、文字列処理、日付計算、数学操作が含まれます。 2。高度な使用法には、複数の関数を組み合わせて複雑な操作を実装することが含まれます。 3.パフォーマンスの最適化では、Where句での機能の使用を回避し、GroupByおよび一時テーブルを使用する必要があります。

MySQLをアンインストールし、残留ファイルをクリーンする方法 MySQLをアンインストールし、残留ファイルをクリーンする方法 Apr 29, 2025 pm 04:03 PM

安全かつ徹底的にMySQLをアンインストールし、すべての残留ファイルをクリーンにするには、次の手順に従ってください。1。MySQLサービスを停止します。 2。MySQLパッケージをアンインストールします。 3.構成ファイルとデータディレクトリのクリーン。 4.アンインストールが徹底していることを確認します。

MySQLにデータを挿入する効率的な方法 MySQLにデータを挿入する効率的な方法 Apr 29, 2025 pm 04:18 PM

MySQLでデータを挿入するための効率的な方法には、次のものが含まれます。1。insertInto ...値構文、2。LoadDatainFileコマンドの使用、3。トランザクション処理の使用、4。バッチサイズの調整、5。Insurtignoreまたは挿入の使用...

作曲家:PHP開発者のパッケージマネージャー 作曲家:PHP開発者のパッケージマネージャー May 02, 2025 am 12:23 AM

Composerは、PHPの依存関係管理ツールであり、Composer.jsonファイルを介してプロジェクトの依存関係を管理しています。 1)依存関係情報を取得するためのComposer.jsonを解析する。 2)依存関係を解析して、依存性ツリーを形成します。 3)PackagistからVendorディレクトリへの依存関係をダウンロードしてインストールします。 4)Composer.Lockファイルを生成して、依存関係バージョンをロックして、チームの一貫性とプロジェクトの保守性を確保します。

他のリレーショナルデータベースでMySQLを使用することの利点は何ですか? 他のリレーショナルデータベースでMySQLを使用することの利点は何ですか? May 01, 2025 am 12:18 AM

MySQLがさまざまなプロジェクトで広く使用されている理由には、次のものがあります。1。複数のストレージエンジンをサポートする高性能とスケーラビリティ。 2。使いやすく、メンテナンス、シンプルな構成とリッチツール。 3。豊富なエコシステム、多数のコミュニティとサードパーティのツールサポートを魅了します。 4。複数のオペレーティングシステムに適したクロスプラットフォームサポート。

mysqlの文字セットと照合ルールを構成する方法 mysqlの文字セットと照合ルールを構成する方法 Apr 29, 2025 pm 04:06 PM

MySQLで文字セットと照合を構成する方法は次のとおりです。1。サーバーレベルでの文字セットとコレクションの設定:setNames'utf8 '; setCharacterSetutf8; setCollat​​ion_connection = 'utf8_general_ci'; 2。特定の文字セットと照合を使用するデータベースを作成します:createdatabaseexample_dbcharactersetutf8collat​​eutf8_general_ci; 3.テーブルを作成するときに文字セットとコレクションを指定:createTableExample_table(idint

See all articles