Nginx を使用してフロントエンドのクロスドメインの問題を解決するにはどうすればよいですか?
まえがき
静的ページや Vue に似たアプリケーションを開発する場合、多くの場合、いくつかのインターフェイスを呼び出します。これらのインターフェイスはクロスドメインである可能性が高く、ブラウザ クロスオリジンの問題は報告されますが、調整は行われません。
最も簡単な解決策は、セキュリティの問題を無視するようにブラウザを設定し、--disable-web-security を設定することです。ただし、この方法は PC ページを作成する場合には問題ありませんが、モバイル ページの場合は機能しません。
解決策
Nginx を使用してリクエストを転送します。クロスドメイン インターフェイスをローカル ドメインのインターフェイスとして書き込み、これらのインターフェイスを実際の要求アドレスに転送します。
例を挙げてください
たとえば、私たちは Vue アプリケーションを開発しています。
原文:
デバッグ ページ: http://192.168.1.100:8080/
要求されたインターフェイス: http:// ni .hao.sao/api/get/info
ステップ 1:
要求されたインターフェイスは次のとおりです: http://192.168.1.100:8080/api/get / info
PS: これにより、クロスドメインの問題が解決されました。
ステップ 2:
Nginx をインストールした後、/usr/local/etc/nginx/ ディレクトリ (これは Mac の場合) に移動し、nginx.conf を変更します。ファイル 。
ステップ 3:
デフォルトのサーバー構成をコメントアウトします。
以下を追加します:
server{ listen 8888; server_name 192.168.1.100; location /{ proxy_pass http://192.168.1.100:8080; } location /api{ proxy_pass http://ni.hao.sao/api; } }
保存後、Nginx を起動します。
PS: Nginx の構成について詳しく知る必要はありません。非常に簡単です。
ステップ 4:
アクセス: http://192.168.1.100:8888/
完了しました。
PS: アクセスされたポートは「8888」であることに注意してください。他のドメインにアドレスがある場合は、場所の追加を続けてください。
エラーデモ
最初はNginxの構成がよくわからなかったので、次のようにすればよいのではないかと考えました。
server{ listen 8080; server_name 192.168.1.100; location /api{ proxy_pass http://ni.hao.sao/api; } }
これを書いた理由は、Nginx を使用して 8080 リクエストを監視し、一致するリクエストのみを転送できるようになると思うからです。私が気づかなかったのは、これを書いた後、Nginx はポート 8080 を占有する必要があるということです。
ポートを占有する必要があるため、同じプロトコルを使用する他のプロセスがポートを占有することができなくなり、その結果、開発されたページをポート 8080 で有効にすることができなくなります。同僚に言われてこのことを思い出し、考え方を変えて一番上の方法を思いつきました。
概要
実際、これは開発中やデバッグ中だけでなく、運用環境でも行うことができます。 Nginx を使用してリクエストを転送した後、デプロイされる静的ページをリクエスト インターフェイスと同じドメインに配置する必要はありません。
付録
リクエストに問題があり、それが Nginx によって報告されたエラーであることがわかった場合は、Nginx の error.log を見つけるだけで済みます。理由を知っています。
前提条件は、nginx.conf で error.log を設定することです:
error_log logs/error.log;
Mac 上の error.log の場所:
/usr/local/Cellar/nginx/1.15.8/logs/error.log
Nginx 関連の知識の詳細については、次のサイトを参照してください。 Nginx の使い方チュートリアル コラム!
以上がnginx がクロスドメインの問題を解決する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

nginxunitは、多言語プロジェクトや動的な構成要件に適した、apachetomcat、gunicorn、node.jsビルトインHTTPサーバーよりも優れています。 1)複数のプログラミング言語をサポートします。2)動的な構成リロード、3)高いスケーラビリティと信頼性を必要とするプロジェクトに適した組み込みの負荷分散機能を提供します。

Nginxunitは、モジュラーアーキテクチャと動的な再構成機能により、アプリケーションのパフォーマンスと管理性を向上させます。 1)モジュラー設計には、マスタープロセス、ルーター、アプリケーションプロセスが含まれ、効率的な管理と拡張をサポートします。 2)動的再構成により、CI/CD環境に適した、実行時に構成をシームレスに更新できます。 3)多言語サポートは、言語ランタイムの動的なロードを通じて実装され、開発の柔軟性が向上します。 4)イベント駆動型モデルと非同期I/Oによって高性能が達成され、高い並行性の下でも効率的なままです。 5)申請プロセスを分離し、アプリケーション間の相互の影響を減らすことにより、セキュリティが改善されます。

nginxunitを使用して、アプリケーションを複数の言語で展開および管理できます。 1)nginxunitをインストールします。 2)PythonやPHPなどのさまざまなタイプのアプリケーションを実行するように構成します。 3)アプリケーション管理に動的構成関数を使用します。これらの手順を通じて、アプリケーションを効率的に展開および管理し、プロジェクトの効率を向上させることができます。

NGINXは、高い並行接続の処理に適していますが、Apacheは複雑な構成とモジュール拡張が必要なシナリオにより適しています。 1.Nginxは、高性能と低リソース消費で知られており、高い並行性に適しています。 2. Apacheは、その安定性とリッチモジュール拡張機能で知られています。これは、複雑な構成ニーズに適しています。

Nginxunitは、動的な構成と高性能アーキテクチャにより、アプリケーションの柔軟性とパフォーマンスを向上させます。 1.動的構成により、サーバーを再起動せずにアプリケーション構成を調整できます。 2.高性能は、イベント駆動型および非ブロッキングアーキテクチャおよびマルチプロセスモデルに反映され、同時接続を効率的に処理し、マルチコアCPUを利用できます。

NginxとApacheはどちらも強力なWebサーバーであり、それぞれがパフォーマンス、スケーラビリティ、効率の点で独自の利点と短所を備えています。 1)nginxは、静的なコンテンツを処理し、逆プロキシを逆にするときにうまく機能します。 2)Apacheは、動的コンテンツを処理するときにパフォーマンスが向上し、リッチモジュールサポートが必要なプロジェクトに適しています。サーバーの選択は、プロジェクトの要件とシナリオに基づいて決定する必要があります。

Nginxは、高い並行リクエストの処理に適していますが、Apacheは複雑な構成と機能的拡張が必要なシナリオに適しています。 1.Nginxは、イベント駆動型の非ブロッキングアーキテクチャを採用しており、高電流環境に適しています。 2。Apacheはプロセスまたはスレッドモデルを採用して、複雑な構成のニーズに適したリッチモジュールエコシステムを提供します。

Nginxは、Webサイトのパフォーマンス、セキュリティ、およびスケーラビリティを改善するために使用できます。 1)逆プロキシおよびロードバランサーとして、Nginxはバックエンドサービスを最適化し、トラフィックを共有できます。 2)イベント駆動型および非同期アーキテクチャを通じて、nginxは高い並行接続を効率的に処理します。 3)構成ファイルでは、静的ファイルサービスやロードバランシングなどのルールの柔軟な定義を可能にします。 4)最適化の提案には、GZIP圧縮の有効化、キャッシュの使用、およびワーカープロセスの調整が含まれます。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

WebStorm Mac版
便利なJavaScript開発ツール

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。
