パフォーマンス、スピード、セキュリティ、スケーラビリティの観点から
返信内容:
多くの技術的な質問には標準的な答えがありません。標準的な答えを得ようとせず、実際に PHP プログラマーの観点から考えてください。 Yii と Laravel は両方とも優れたフレームワークであるとは誰も言いません。優れた PHP プログラマーは、どのフレームワークを使用するかについてあまり気にする必要はありません。どのフレームワークでもすぐに習得して開発を開始できるからです。このフレームワークの設計アイデアと使用テクニックをすぐに学びます。フレームワークの 1 つまたは複数の側面を比較したい場合は、インターネット上に多くの情報があります。質問する必要はありません。検索してください:テクノロジースタックの選択に関する提案: Laravel 5 とYii 2
PHP Frameworks での Yii 2.0 対 Laravel に関する投稿
Yii2 対 Laravel 5
https:// www.quora.com/Yii-2-0-vs-Laravel-5-1-LTS-that-one-is-best-for-large-projects
Yii2 vs Laravel 5: PHP
ただし、比較の目的は次のとおりです。何かを一度に要約するのではなく、より深く理解するためです。もし誰かを打ち負かしてしまうと、それは偏ったものになるでしょうし、異なる考え方を学ぶ機会も失われます。
テクノロジーは好みの問題です。つまり、単にパフォーマンスやスケーラビリティについて肯定または否定するのではなく、最も重要なのは使用シナリオです。あるフレームワークはあるチーム プロジェクト環境には適していますが、上級技術担当者はこれについて同意するかもしれません。
自分で下調べをして、自分自身の答えを与える必要があります。それが自分にとって最も説得力のあるものになります。他の人の意見は、自分のプロジェクトやチームに対する具体的な理解に代わるものではありません。 Laravel5は使ってみて文句のつけようのないフレームワークです! パフォーマンス、速度、セキュリティ、スケーラビリティは Yii の強みであり、Laravel の強みは高度なコンセプトです。 Yii 自体も、ActiveRecord など、laravel から多くの概念を借用しています。もちろん、laravel 自体も Ruby on Rails から借用しています。
yii の唯一の欠点は、軽量ではなく、少し重いことです。それ自体で。 Yii2 はエレガントで拡張が簡単なので、エンタープライズ Web サイトを迅速に開発できるのが気に入っています。 カニの悪魔
この選択は実際には猿の糞に依存していると思いますが、それでも私はあなたの要求に従い、いくつかの材料を集めるのを手伝います。どちらが将来なのかは答えられないかもしれませんが、決断の参考になれば幸いです。実際、ダンスを習った後に踊っても大丈夫です。
パフォーマンス
一人の男性からのデータしか見つかりませんでした。 「hello world」ベンチマークのみの場合、yii2 は 1 秒あたり 153 リクエストですが、laravel4 は 1 秒あたり 69 リクエストです。かなり一方的なので参考程度に。数か月以内に、最新のネットワーク フレームワーク ベンチマークに Yii2 が含まれる可能性があります。現在、Laravel のスコアは、I7、Amazon EC2、および超大規模な Peak の 3 つがすべて失敗しています。 PHP で最も優れたパフォーマンスを発揮するのは Brother Bird の yaf です。しかし、正直に言うと、そのフレームワークはあまり使いやすいものではありません。
速度
パフォーマンスでは、運用効率は考慮されなくなりました。そのため、開発効率を考慮してください。全体として、Yii2 のセールスポイントは、すぐに使える機能、柔軟な拡張性、そして使いやすさです。このように、Laravel4の開発効率は決して遅いとは言えませんが、Yii2は中大規模プロジェクトの開発に向けた独自の配慮があり、スキャフォールディングから開発、デバッグまでをカバーする多くのツールを提供しています。単体テスト、機能テスト、受け入れテストからパフォーマンスのチューニングまで。 Laravel4 の利点も非常に人気があり、多くの人が Laravel に殺到しているため、中国語と英語の情報がたくさんあります。もう 1 つのポイントは、Laravel の学習曲線は非常に短いのに対し、Yii2 は始めるのは簡単ですが、習得するのは簡単ではなく、学習して大切にする必要があるということです。 Laravel についての私の唯一の意見は、アプリケーションコンポーネントに名前を付けるとき、この人は常に非常に詩的で、奇妙で使用できない名前を付けるため、英語を母国語としない開発者を非常に不快にさせるということです。 Yii2 の主な開発者は中国人、ドイツ人、Maozi 人ですが、英語を話すのが好きな人はいません。
セキュリティ
どのフレームワークも非常に安全であると主張していますが、正確に知っている人はいません...私はこの分野の専門家ではなく、それしか知りません。多くの大企業はオリジナルの Yii を使用することを好み、Yii2 は国際的に有名なセキュリティの第一人者 (コードレビューと新機能) によって承認されています。
スケーラビリティ
Laravel は Symfony2 の優れたデカップリング特性を継承しており、Yii は Yii2 の Composer や Service Locator を完全に採用しています。およびその他の機能的特徴。最近では、DI をサポートしていなくても、モダンなフレームワークであると言うのが恥ずかしいほど、誰もが柔軟です。それらの微妙な違いを説明するために、Symfony2 にはデフォルトで多くの選択肢があり、後の段階では可能な限り柔軟であるという利点があります。何をすればよいのか迷ってしまいますが、初心者にとっては選択肢が多すぎて、設定する必要がある場所が多すぎることがあります。Yii2 には、すぐに使える原則に基づいたデフォルトのオプションが多数用意されており、柔軟性がないと感じることがありますが、実際には後で調整できます。これらのフレームワークはこの点で非常に柔軟であり、違いは設計思想にのみ存在します。
まとめ
賢明に言えば、Laravel4 も Yii2 も未来ではないと思います。なぜなら、著者は Laravel5 と Yii 2.1 を作成する予定だからです。 。
興味関連、Yii2 中国文化プロジェクトの発起人。ソフト広告: Yii Framework 2.0 中国語ドキュメント はい、laravelはとても良いです。しかし、それは役に立たず、会社では役に立ちません。または YII を選択してください laravel が将来のものかどうかはわかりませんが、laravel のバージョンが頻繁に更新され、5.2.20 と 5.2.32 の間には多くの非互換性があることはわかっています。前者でも同じコードを実行できますが、さまざまなエラーが発生します。後者に基づいて報告されます。また、パフォーマンスは少し遅れています。
私は yii2 を使ったことがあるのですが、かなり良いです。ルールが多くて初心者には慣れないかもしれませんが、慣れると開発速度が非常に速いことがわかります。大規模なチーム開発に適しています。キャッシュは非常に詳細で強力であり、大規模なプロジェクトのために生まれます。
要約すると、laravel は非常に先進的であり、非常に先進的であるように見えますが、あと 2 年後の未来について議論しましょう。 とても愚かです、両方を学ぶことができます。 yii2 は laravel を完全に上回ります。
コードレビューに関しては、Yii と Laravel の両方を phpstorm に入れると、Laravel については個別の警告が依然として表示されますが、Yii についてはほとんど警告が表示されません。これは、IDE がシステム全体の内部と外部を認識できることを意味します。したがって、ユーザーは、使用されているクラスやメソッドがどこから来たのか、どこで何回使用されたのかを簡単に知ることができます。 これにより、後のリファクタリングのメンテナンスが大幅に容易になります。 開発速度の点では、laravlel5 と yii の間には大きな違いがあります。

セッション関連のXSS攻撃からアプリケーションを保護するには、次の測定が必要です。1。セッションCookieを保護するためにHTTPonlyとセキュアフラグを設定します。 2。すべてのユーザー入力のエクスポートコード。 3.コンテンツセキュリティポリシー(CSP)を実装して、スクリプトソースを制限します。これらのポリシーを通じて、セッション関連のXSS攻撃を効果的に保護し、ユーザーデータを確保できます。

PHPセッションのパフォーマンスを最適化する方法は次のとおりです。1。遅延セッション開始、2。データベースを使用してセッションを保存します。これらの戦略は、高い並行性環境でのアプリケーションの効率を大幅に改善できます。

thesession.gc_maxlifettinginttinginphpdethinesthelifsessessiondata、setinseconds.1)it'sconfiguredinphp.iniorviaini_set()。 2)AbalanceSneededToAvoidPerformanceIssues andunexpectedLogouts.3)php'sgarbagecollectionisisprobabilistic、影響を受けたBygc_probabi

PHPでは、session_name()関数を使用してセッション名を構成できます。特定の手順は次のとおりです。1。session_name()関数を使用して、session_name( "my_session")などのセッション名を設定します。 2。セッション名を設定した後、session_start()を呼び出してセッションを開始します。セッション名の構成は、複数のアプリケーション間のセッションデータの競合を回避し、セキュリティを強化することができますが、セッション名の一意性、セキュリティ、長さ、設定タイミングに注意してください。

セッションIDは、機密操作の前、30分ごとにログイン時に定期的に再生する必要があります。 1.セッション固定攻撃を防ぐためにログインするときにセッションIDを再生します。 2。安全性を向上させるために、敏感な操作の前に再生します。 3.定期的な再生は長期的な利用リスクを減らしますが、ユーザーエクスペリエンスの重量を量る必要があります。

PHPのセッションCookieパラメーターの設定は、session_set_cookie_params()関数を通じて達成できます。 1)この関数を使用して、有効期限、パス、ドメイン名、セキュリティフラグなどのパラメーターを設定します。 2)session_start()を呼び出して、パラメーターを有効にします。 3)ユーザーログインステータスなど、ニーズに応じてパラメーターを動的に調整します。 4)セキュリティを改善するために、セキュアとhttponlyフラグを設定することに注意してください。

PHPでセッションを使用する主な目的は、異なるページ間でユーザーのステータスを維持することです。 1)セッションはsession_start()関数を介して開始され、一意のセッションIDを作成し、ユーザーCookieに保存します。 2)セッションデータはサーバーに保存され、ログインステータスやショッピングカートのコンテンツなど、さまざまなリクエスト間でデータを渡すことができます。

サブドメイン間でセッションを共有する方法は?一般的なドメイン名にセッションCookieを設定することにより実装されます。 1.セッションCookieのドメインをサーバー側の.example.comに設定します。 2。メモリ、データベース、分散キャッシュなど、適切なセッションストレージ方法を選択します。 3. Cookieを介してセッションIDを渡すと、サーバーはIDに基づいてセッションデータを取得および更新します。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

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

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

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