あるネチズンから、最近 Laravel 開発プロジェクトがあり、テストのためにそれを CentOS サーバーに移動する必要があると聞きました。ちなみに移転の経緯については彼に聞いて皆さんに共有しましたので、ご興味があれば詳細をご覧ください。
まずプロジェクトの構成について話しましょう:
Laravel バージョン 5.5 - php7.0 以降であることが確認されており、
CentOS 7.0 以降です。
lnmp バージョン 1.5
次は再配置プロセスです:
1. lnmp1.5 をサーバーにインストールします:
lnmp インストール パッケージは怠け者にとって最も便利なインストール Web サーバーを展開するためのツール。さらに心配な場合は、自分でコンパイルしてインストールすることもできます。
インストール手順は公式 Web サイトに明確に記載されているため、無人自動インストールの使用を検討してください: https://lnmp.org/faq/v1-5-auto-install.html。インストールプロセス中に ssh が自動的に切断されないように、インストール前に screen を使用することをお勧めします。
Apache の代わりに nginx を使用して lnmp をインストールしました。
2. 仮想ホストを追加します:
追加方法については、公式 Web サイトに説明があります: https://lnmp.org/faq/lnmp-vhost-add-howto.html
追加時に記述するパラメータ:
(1) ドメイン名: 指定されたドメイン名 (または偽のドメイン名をカスタマイズ)
(2) Web サイトのディレクトリ: Enter キーを押します。入力しない場合、デフォルトは /home/wwwroot/ドメイン名
(3) 書き換えルール: y、必須。次に「laravel」と入力してEnterを押します。
#(4)アクセスログを開きます:Y、Enter Enter
#アクセスログ名:Enterを直接Enterを押します、デフォルト;いいえ、自分で構築します。
(7) SSL 機能: n、必須ではありません。
3. プロジェクト ファイルを Web サイトのディレクトリに移動します:
sftp メソッドを使用することも、lnmp 経由で ftp サーバーをインストールし、ftp 経由でアップロードすることもできます。アップロード後、http://serverip/phpmyadmin を通じてデータベースとユーザー アカウントを作成します。完了したら、プロジェクトの .env ファイルでデータベース構成を変更します。
4. 次の Web サイト ディレクトリを変更します:
Laravel プロジェクトの Web サイト ディレクトリはプロジェクトの下のパブリック ディレクトリである必要があるため、vhost ファイルを変更する必要があります: /usr/local/ nginx/conf/vhost/ドメイン名 .conf
root が指すディレクトリをプロジェクト下の public ディレクトリに指定します。次にnginxをリロードします。
5. Web サイトのディレクトリ権限設定:
(1) Web サイトのディレクトリ全体を www:www: chown www:www -R /home/wwwroot/Website directory
# # に変更します。 # (2) プロジェクト直下のストレージディレクトリを書き込み可能に設定します: chmod -R 775 /home/wwwroot/website directory/storage/ (3) Laravel プロジェクトの実際のアップロードディレクトリは storage/ であるためapp/ public なので、このディレクトリへのパブリック ディレクトリへのソフト リンクを作成する必要があります。ここでは、プロジェクト ディレクトリに入って、phpArtisan storage:link を実行します。 このコマンドの実行時にエラーが発生しました。php.ini が特定の php 関数をブロックしていることが原因です。php.ini ファイルの disable_functions 構成を変更し、使用する必要がある関数を削除し、変更して保存してください。それから php-fpm をリロードします。上記のコマンドを再実行するだけです。 6. キャッシュのクリア: php 職人キャッシュ:クリア 7. redis のインストール: lnmp を使用してインストールできます。公式 Web サイトに手順が記載されているので、ここでは省略します。 8. Composer によるサードパーティ ベンダー コンポーネントの更新: プロジェクト ディレクトリで Composer 更新を実行すると、fileinfo の PHP 拡張子が見つからないというメッセージが表示されます。現時点では、fileinfo 拡張子を手動でコンパイルしてインストールする必要があります。 最初のステップでは、wget を使用して lnmp インストール パッケージを自動的にダウンロードしました。コマンド ラインは、php のソース コードを含むこのインストール パッケージを解凍します。ソース コードを通じて fileinfo 拡張機能をコンパイルしてインストールできます。 関連チュートリアル:PHP ビデオ チュートリアル
以上がLaravelプロジェクトをサーバーに移動する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

データベースストレージセッションを使用することの主な利点には、持続性、スケーラビリティ、セキュリティが含まれます。 1。永続性:サーバーが再起動しても、セッションデータは変更されないままになります。 2。スケーラビリティ:分散システムに適用され、セッションデータが複数のサーバー間で同期されるようにします。 3。セキュリティ:データベースは、機密情報を保護するための暗号化されたストレージを提供します。

PHPでのカスタムセッション処理の実装は、SessionHandlerInterfaceインターフェイスを実装することで実行できます。具体的な手順には、次のものが含まれます。1)CussentsessionHandlerなどのSessionHandlerInterfaceを実装するクラスの作成。 2)セッションデータのライフサイクルとストレージ方法を定義するためのインターフェイス(オープン、クローズ、読み取り、書き込み、破壊、GCなど)の書き換え方法。 3)PHPスクリプトでカスタムセッションプロセッサを登録し、セッションを開始します。これにより、データをMySQLやRedisなどのメディアに保存して、パフォーマンス、セキュリティ、スケーラビリティを改善できます。

SessionIDは、ユーザーセッションのステータスを追跡するためにWebアプリケーションで使用されるメカニズムです。 1.ユーザーとサーバー間の複数のインタラクション中にユーザーのID情報を維持するために使用されるランダムに生成された文字列です。 2。サーバーは、ユーザーの複数のリクエストでこれらの要求を識別および関連付けるのに役立つCookieまたはURLパラメーターを介してクライアントに生成および送信します。 3.生成は通常、ランダムアルゴリズムを使用して、一意性と予測不可能性を確保します。 4.実際の開発では、Redisなどのメモリ内データベースを使用してセッションデータを保存してパフォーマンスとセキュリティを改善できます。

APIなどのステートレス環境でのセッションの管理は、JWTまたはCookieを使用して達成できます。 1。JWTは、無国籍とスケーラビリティに適していますが、ビッグデータに関してはサイズが大きいです。 2.cookiesはより伝統的で実装が簡単ですが、セキュリティを確保するために慎重に構成する必要があります。

セッション関連の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()を呼び出してセッションを開始します。セッション名の構成は、複数のアプリケーション間のセッションデータの競合を回避し、セキュリティを強化することができますが、セッション名の一意性、セキュリティ、長さ、設定タイミングに注意してください。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

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

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

ホットトピック









