OWASP (Open Web Application Security Project) は、Web アプリケーションに対する現在の脅威を記録するプロジェクトです。私は彼らのサイトをフォローしていますが、2010 年、2013 年、2017 年のレポートにはいくつかの類似点があり、SQL またはその他の種類のインジェクション脅威がリストの最上位にあります。
これは深刻な問題です。
これは倒産の原因となるため、この問題は生死に関わる問題であり、組織はこの種の問題の発生を避けるためにこの種の問題への対処に重点を置く必要があります。
注射とは何ですか?
いわゆるインジェクションとは、データがフィルタリングされず、信頼できないコンテンツがシステム インタープリタに直接書き込まれることを意味します。この動作は、サイトへの SQL インジェクションにつながります。さらに悪いことに、攻撃者は、システムに対する完全な権限を取得します。
例:
次の悪意のあるクエリ ステートメントを見てください。これは、悪意のある動作を含む SQL ステートメントを $name 変数に配置し、ユーザーがpass POST メソッドは、受信した悪意のあるコードを使用して攻撃を実行するという最終的な目的を達成するために、PHP スクリプトに渡されます。
// 将恶意代码,DROP TABLE 写入 $name 变量 $name = "Mark';DROP TABLE users; -- ";\ $query = "SELECT * FROM users WHERE name='$name'";
PHP スクリプトによる解析後、最終的に次のような SQL ステートメントが生成されます。
SELECT * FROM users WHERE name='Mark';DROP TABLE users; -- '
ご想像のとおり、上記のステートメントはデータベースからユーザー データ テーブル全体を削除します。
ヨーダが言ったように:
これは危険すぎる、そう、危険すぎる。
PHP アプリケーションへの悪意のあるインジェクションを防ぐにはどうすればよいですか?
まず第一に、実際にはデータベースには何も挿入されません。このエラーは単にクエリ ステートメントの形式が間違っていることが原因です。 SQL ステートメントを正しくフォーマットするか、クエリ ステートメントとデータを別々に直接処理する限り、解決策は簡単です。 ######どうやってするの?パラメーター化されたクエリを使用してデータをフォーマットし、クエリ ステートメントをデータから分離します。
パラメータ化されたクエリを使用すると、プログラムがインジェクションのリスクを確実に回避できます。
例は次のとおりです:
$statement = $db->prepare('SELECT * FROM table WHERE id = ? and name = ? ');\ $statement->execute([1, "Mark"]);
さらに、プロジェクトで ORM (オブジェクト リレーショナル マッピング) またはクエリ ビルダーを使用する安全な方法があります。
私がおすすめしたいのは、有名なPHPフレームワークLaravelでも使われているEloquentです。次に、注射の危険を効果的に回避するためにデータをフォーマットするのに役立つ、そのインストール方法と使用方法を説明します。
Eloquent のインストール準備
PHP と
Composer正式な開始プロジェクトの開始時に ORM をインストールするのが最善です。
posts テーブルと users テーブルを含むブログ アプリケーションを構築するとします。
初期化構成最初に行うことは、プログラム用のcomposer.jsonファイルを作成することです。ターミナルでcomposer initを実行し、ターミナルのプロンプトに従うことができます。
#依存関係を定義するように求められたら、「luminate/database」と書きます。最終的な出力は上の画像のようになります。これで、composer install を実行して、プロジェクトに対応する依存関係をインストールできるようになります。
または、composer.json ファイルがすでにある場合は、ターミナルに直接「composer require inspired/database」と入力して、対応する依存関係をインストールできます。
次に、アプリケーションのルート ディレクトリに start.php ファイルを作成し、そのファイルに次のコードを貼り付ける必要があります。それらの役割については以下で説明します。
require "vendor/autoload.php"; //If you want the errors to be shown *是否显示错误 error_reporting(E_ALL); ini_set('display_errors', '1'); use Illuminate\Database\Capsule\Manager as Capsule; $capsule = new Capsule; $capsule->addConnection([ "driver" => "mysql", "host" =>"127.0.0.1", "database" => "test", "username" => "root", "password" => "root" ]); //Make this Capsule instance available globally. *要让 capsule 能在全局使用 $capsule->setAsGlobal(); // Setup the Eloquent ORM. $capsule->bootEloquent();
最初の行では、vendor/autoload.php ファイルを導入する必要があります。この方法で、ベンダー ディレクトリ内のすべてのパッケージをロードできます。
次に、Illuminate\Database\Capsule\Manager を Capsule として使用し、eloquent を使用できるようにエイリアスを付けます。
次に、上記の bootEloquent() と同様に、Capsule オブジェクトを作成し、データベース接続を初期化します。
さて、明らかに最初に行う必要があるのは、test という名前のデータベースを作成することです。ローカルで正しいユーザー名とパスワードを入力していることを確認してください。
移行 / データ移行Eloquent を使用する最大の利点の 1 つは、移行を使用できることです。
移行とは何かわからない場合は、以下の説明を読んでください:
移行は、PHP コードを通じてデータ テーブルを作成する方法です。
migrations.php ファイルに移行を作成します:
require "start.php"; use Illuminate\Database\Capsule\Manager as Capsule; Capsule::schema()->create('users', function ($table) { $table->increments('id'); $table->string('name'); $table->string('email')->unique(); $table->string('password'); $table->timestamps(); }); Capsule::schema()->create('posts', function ($table) { $table->increments('id'); $table->string('title'); $table->text('body'); $table->integer('created_by')->unsigned(); $table->timestamps(); });
上記のコードは、Capsule クラスを通じて 2 つのデータ テーブルを作成します。1 つは users テーブル、もう 1 つは post テーブルで、それぞれフィールドです。それらには名前が定義されています。
このファイルを実行します。白い画面が表示された場合は、移行が正常に実行されたことを意味します。これで、データベースを開いて、これら 2 つのテーブルが生成されたかどうかを確認できます。
あとは、データ テーブルに対応する Model クラスを作成するだけです。
用了 Eloquent,你就可以在 Model 类里操作相应的数据表,执行查询语句了。
创建一个 Models 文件夹,然后在其中分别创建 User.php 和 Post.php 文件:
namespace Models; use Illuminate\Database\Eloquent\Model; class User extends Model { /** * 对应的数据表 * * @var string */ protected $table = "users"; /** * 允许插入的字段 * * @var array */ protected $fillable = [ 'name', 'email', 'password' ]; /** * 需要被隐藏的字段 * * @var array */ protected $hidden = [ 'password', 'remember_token', ]; /* * 给 User 类添加方法 * */ public function posts() { return $this->hasMany(Post::class, 'created_by'); } } And namespace Models; use Illuminate\Database\Eloquent\Model; class Post extends Model { /** * 对应的数据表 * * @var string */ protected $table = "posts"; /** * 允许插入的字段 * * @var array */ protected $fillable = [ 'title', 'body', 'created_by' ]; } 在 composer.json 文件中加入如下代码,以确保上面创建的类文件能够被自动加载。 "autoload": { "classmap": [ "Models" // Folder where all your models are ] }
然后执行 composer dump-autoload。
通过 Eloquent 操作数据库
基本大功告成了。 测一下吧,在根目录创建 index.php 文件,添加如下代码:
require "start.php"; use Models\User; use Models\Post; User::create( [ 'name' => 'Mark Mike', 'email' => 'temp-email-1@mark.com', 'password' => '1234' ] ); Post::create( [ 'title' => 'New Blog Post', 'body' => 'New Blog Content', 'created_by' => 1 ] ); print_r(User::all()); print_r(Post::all()); print_r(User::find(1)->posts);
如你所见,用 Eloquent 操作数据库就是这么简单。除此之外,Eloquent 还提供了很多方法供你使用,而且很安全。
结语:
Eloquent 就像是给你的 SQL 查询加了一道安全层,它可以过滤掉我们在执行 SQL 查询时所犯的错误。如果你想用它,但是又不想安装 Laravel 框架,那么我想你已经从这篇文章中学到了该如何去做。这个优雅的 SQL 助手,将帮助你写出更干净且更安全的代码。
更多PHP相关知识,请访问PHP中文网!
以上がSQL インジェクションを回避するには、PHP プロジェクトで Laravel Eloquent クエリを単独で使用します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

開発環境とエコシステムにおけるLaravelとPythonの比較は次のとおりです。1。Laravelの開発環境は簡単で、PHPと作曲家のみが必要です。 Laravelforgeなどの豊富な範囲の拡張パッケージを提供しますが、拡張パッケージのメンテナンスはタイムリーではない場合があります。 2。Pythonの開発環境もシンプルで、PythonとPIPのみが必要です。エコシステムは巨大で複数のフィールドをカバーしていますが、バージョンと依存関係の管理は複雑な場合があります。

Laravelはバックエンドロジックでどのように役割を果たしますか?ルーティングシステム、Eloquentorm、認証と承認、イベントとリスナー、パフォーマンスの最適化を通じてバックエンド開発を簡素化および強化します。 1.ルーティングシステムにより、URL構造の定義とリクエスト処理ロジックが可能になります。 2.Eloquentormは、データベースの相互作用を簡素化します。 3.認証および承認システムは、ユーザー管理に便利です。 4.イベントとリスナーは、ゆるく結合したコード構造を実装します。 5.パフォーマンスの最適化により、キャッシュとキューイングを通じてアプリケーションの効率が向上します。

Laravelの人気には、単純化された開発プロセスが含まれ、快適な開発環境を提供し、豊富な機能が提供されます。 1)Rubyonrailsの設計哲学を吸収し、PHPの柔軟性を組み合わせています。 2)Eloquentorm、Bladeテンプレートエンジンなどのツールを提供して、開発効率を向上させます。 3)そのMVCアーキテクチャと依存関係噴射メカニズムにより、コードがよりモジュール化され、テスト可能になります。 4)キャッシュシステムやベストプラクティスなどの強力なデバッグツールとパフォーマンス最適化方法を提供します。

DjangoとLaravelはどちらもフルスタックのフレームワークです。 DjangoはPython開発者や複雑なビジネスロジックに適していますが、LaravelはPHP開発者とエレガントな構文に適しています。 1.DjangoはPythonに基づいており、迅速な発展と高い並行性に適した「バッテリーコンプリート」哲学に従います。 2. LaravelはPHPに基づいており、開発者エクスペリエンスを強調しており、小規模から中規模のプロジェクトに適しています。

LaravelはPHPベースのフレームワークであるため、PHPとLaravelは直接匹敵するものではありません。 1.PHPは、シンプルで直接的であるため、小規模プロジェクトや迅速なプロトタイピングに適しています。 2。LARAVELは、豊富な機能とツールを提供するため、大規模なプロジェクトや効率的な開発に適していますが、急な学習曲線があり、純粋なPHPほど良くない場合があります。

laravelisabackendframeworkbuiltonphp、designforwebapplicationdevelopment.itfocusonserver-sidelogic、databasemanagement、およびapplicationStructure、およびbueithedendtechnologiesvue.jsorreactforfull-stackdevelymentと統合されていること。

この記事では、Laravelでカスタムブレードディレクティブの作成と使用を行い、テンプレートを強化します。ディレクティブの定義、テンプレートでそれらを使用し、大規模なプロジェクトでそれらを管理することをカバーし、改善されたコードの再利用性やRなどの利点を強調しています

この記事では、コンポーネントを使用してLaravelで再利用可能なUI要素の作成とカスタマイズについて説明し、組織のベストプラクティスを提供し、パッケージを強化することを提案します。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

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

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境
