nginx 是一个灵活且高效的网络服务器,如果想要在nginx服务器中重定,你可以从下面挑选一个适合的方式。
简单且快速的 return
这是一个非常简单的设置方式,只需要个return
语句就可以了
return 301 https://example.com$request_uri;
你需要把这段代码放到nginx配置文件的server
代码块中,301
是永久重定向,你也可以设置成302
做一个临时重定向(不建议)。
一个完整的例子:
return 301 https://example.com$request_uri;
正则表达式 rewrite
如果return
不能满足你的复杂业务需求,你可以考虑下正则匹配重定向:
rewrite ^/foo/(bar)/(.*)$ https://$server_name/$1/$2 permanent;
同样这也是需要在server
代码块中,其中permanent
为301
永久跳转,若需要302
可修改为redirect
一个完整的例子:
server { listen 80; listen [::]:80; hostname example.com www.example.com; root /var/www/example.com/public; rewrite ^/foo/(bar)/(.*)$ $scheme://$server_name/$1/$2 permanent; }
又如:
server { listen 80; server_name www.fangyongle.com fangyongle.cn; if ($host != 'www.fangyongle.com' ) { rewrite ^/(.*)$ https://www.fangyongle.com/$1 permanent; } }
再如:
# 根据文件类型设置过期时间 location ~* \.(js|css|jpg|jpeg|gif|png|swf)$ { if (-f $request_filename) { expires 1h; break; } }
使用Maps
如果你有一堆需要重定向的连接映射,你可以考虑在一个地方定义它,然后再通过if
来手动判断重定向。
首先定义重定向链接映射redirect-map.conf
map $request_uri $redirect_uri { /about.html /about-us; /customers.html /our-customers; /products.html /our-products; }
然后在server
代码块使用:
include redirect-map.conf; server { […] if ( $redirect_uri ) { return 301 $redirect_uri; } }
映射也可以有一些语法:
map $request_uri $redirect_uri { /about.html /about-us; /customers.html /our-customers; /products.html /our-products; # Match any url that ends in products.html or producs.htm ~products\.html?$ /our-products; # case-insensitive version of the above ~*products\.html?$ /our-products; # A named capture that maps # e.g. product-1234.html into /products/item-1234/overview ~product-(?<sku>\d+)\.html /products/item-$sku/overview; }
一些实用的重定向例子
http 重定向为 https
return 301 https://$host$request_uri;
统一规范域名
server_name example.com www.example.com example.net www.example.net _; if ( $host != $server_name ) { return 301 $scheme://$server_name$request_uri; }
含 www 和 不含 www 之间的重定向
# non-www to www if ( $host !~ ^www\. ) { return 301 $scheme://www.$host$request_uri; }
# www to non-www if ( $host ~ ^www\.(?<domain>.+)$ ) { return 301 $scheme://$domain$request_uri; }
附录
重定向中常用全局变量
$scheme // HTTP方法(如http,https),如:http $host // 请求主机头字段,否则为服务器名称,如:blog.fangyongle.com $server_name // 服务器名称,如:blog.fangyongle.com $request_uri // 包含请求参数的原始URI,不包含主机名,如:/2018/81.html?a=1&b=2 $request_filename // 当前请求的文件的路径名,由root或alias和URI request组合而成,如:/2013/81.htmlnginx 部分常用全局变量
nginx 部分常用全局变量
$remote_addr//获取客户端ip $binary_remote_addr//客户端ip(二进制) $remote_port//客户端port,如:50472 $remote_user//已经经过Auth Basic Module验证的用户名 $host//请求主机头字段,否则为服务器名称,如:blog.fangyongle.com $request//用户请求信息,如:GET ?a=1&b=2 HTTP/1.1 $request_filename//当前请求的文件的路径名,由root或alias和URI request组合而成,如:/2013/81.html $status//请求的响应状态码,如:200 $body_bytes_sent // 响应时送出的body字节数数量。即使连接中断,这个数据也是精确的,如:40 $content_length // 等于请求行的“Content_Length”的值 $content_type // 等于请求行的“Content_Type”的值 $http_referer // 引用地址 $http_user_agent // 客户端agent信息,如:Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/29.0.1547.76 Safari/537.36 $args //与$query_string相同 等于当中URL的参数(GET),如a=1&b=2 $document_uri //与$uri相同 这个变量指当前的请求URI,不包括任何参数(见$args) 如:/2018/81.html $document_root //针对当前请求的根路径设置值 $hostname //如:centos53.localdomain $http_cookie //客户端cookie信息 $cookie_COOKIE //cookie COOKIE变量的值 $is_args//如果有$args参数,这个变量等于”?”,否则等于”",空值,如? $limit_rate//这个变量可以限制连接速率,0表示不限速 $query_string // 与$args相同 等于当中URL的参数(GET),如a=1&b=2 $request_body // 记录POST过来的数据信息 $request_body_file//客户端请求主体信息的临时文件名 $request_method //客户端请求的动作,通常为GET或POST,如:GET $request_uri //包含请求参数的原始URI,不包含主机名,如:/2018/81.html?a=1&b=2 $scheme //HTTP方法(如http,https),如:http $uri//这个变量指当前的请求URI,不包括任何参数(见$args) 如:/2018/81.html $request_completion//如果请求结束,设置为OK. 当请求未结束或如果该请求不是请求链串的最后一个时,为空(Empty),如:OK $server_protocol//请求使用的协议,通常是HTTP/1.0或HTTP/1.1,如:HTTP/1.1 $server_addr//服务器IP地址,在完成一次系统调用后可以确定这个值 $server_name//服务器名称,如:blog.fangyongle.com $server_port//请求到达服务器的端口号,如:80
Rewrite正则相关指令详解
nginx的rewrite
相当于apache的rewriterule
(大多数情况下可以把原有apache的rewrite
规则加上引号就可以直接使用),它可以用在server
,location
和IF
条件判断块中,命令格式如下:
rewrite <regex> <replacement> <flag>
正则表达式匹配
~
は大文字と小文字を区別する一致です-
~*
は大文字と小文字を区別しない一致です ##!~
と
!~*は、それぞれ大文字と小文字を区別する不一致と大文字と小文字を区別しない不一致です
- #-f
と
#!-f
を使用してファイルが存在するかどうかを判定します #-d - および
!-d
は、ディレクトリ
-e - および
が存在するかどうかを判断するために使用されます。 ! -e
は、ファイルまたはディレクトリが存在するかどうかを判断するために使用されます。
-x - および #!-x
は、ファイルまたはディレクトリが存在するかどうかを判断するために使用されます。 is executable
flag tag
- - 基本的にこのFlagが使用されます。
-
break - - rewrite
を中止し、マッチングを続行しません
リダイレクト - 一時リダイレクトの HTTP ステータスを返します 302 -
permanent - 永続リダイレクトの HTTP ステータスを返します 301 -
と##last
break
URI の書き換えを実装すると、ブラウザのアドレス バーは変更されません。そして、この 2 つには微妙な違いがあります。
alias
- last
-
breakでマークする必要があります。
##proxy_pass
コマンドを使用する場合は、この記事でマークされている マーク -
ルールが実行されると、そのリクエストが配置されている##last
を使用する必要があります
rewrite server{...} - タグに対してリクエストが再開始され、
break
タグがこのルールのマッチングが完了したらマッチングを終了します。
Nginx 関連の技術記事の詳細については、Nginx チュートリアル 列にアクセスして学習してください。
以上がnginx が情報をリダイレクトする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Nginxは、イベント駆動型のアーキテクチャと非同期処理機能を通じてパフォーマンスを向上させ、モジュラー設計と柔軟な構成を通じてスケーラビリティを向上させ、SSL/TLSの暗号化と要求レートの制限を介してセキュリティを改善します。

Nginxは、高い並行性と低リソース消費シナリオに適していますが、Apacheは複雑な構成と機能的拡張を必要とするシナリオに適しています。 1.Nginxは、高性能と多数の同時接続を処理することで知られています。 2。Apacheは、その安定性とリッチモジュールのサポートで知られています。選択するときは、特定のニーズに基づいて決定する必要があります。

nginxisentialformodernwebapplicationsdueToitsRolesasareverseproxy、loadbalancer、andwebserver、weberporformanceandscalability.1)itactsasaReverseproxy、拡張、およびパフォーマンスを強化し、パフォーマンスを強化し、積極的に積極的なものを増やします

NGINXを通じてWebサイトのセキュリティを確保するには、次の手順が必要です。1。基本的な構成を作成し、SSL証明書と秘密鍵を指定します。 2。構成を最適化し、HTTP/2を有効にし、OCSPSTAPLING。 3.証明書パスや暗号化スイートの問題などの一般的なエラーをデバッグします。 4。let'sencryptの使用やセッションの多重化など、アプリケーションのパフォーマンス最適化の提案。

Nginxは、高性能のHTTPおよびリバースプロキシサーバーであり、高い並行接続の取り扱いに優れています。 1)基本的な構成:ポートを聞いて静的ファイルサービスを提供します。 2)高度な構成:逆プロキシとロードバランシングを実装します。 3)デバッグスキル:エラーログを確認し、構成ファイルをテストします。 4)パフォーマンスの最適化:GZIP圧縮を有効にし、キャッシュポリシーを調整します。

Nginxキャッシュは、次の手順を通じてWebサイトのパフォーマンスを大幅に改善できます。1)キャッシュ領域を定義し、キャッシュパスを設定します。 2)キャッシュ有効期間を構成します。 3)異なるコンテンツに従って異なるキャッシュポリシーを設定します。 4)キャッシュストレージと負荷分散を最適化します。 5)キャッシュ効果を監視およびデバッグします。これらの方法により、Nginxキャッシュはバックエンドサーバーの圧力を軽減し、応答速度とユーザーエクスペリエンスを向上させることができます。

DockerComposeを使用すると、Nginxの展開と管理が簡素化され、DockerswarmまたはKubernetesをスケーリングすることは一般的な慣行です。 1)DockerComposeを使用してNginxコンテナを定義および実行する、2)DockerswarmまたはKubernetesを介してクラスター管理と自動スケーリングを実装します。

nginxの高度な構成は、サーバーブロックとリバースプロキシを介して実装できます。1。サーバーブロックにより、複数のWebサイトを1つの場合に実行することができます。各ブロックは個別に構成されます。 2.逆プロキシは、リクエストをバックエンドサーバーに転送して、負荷分散とキャッシュアクセラレーションを実現します。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

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

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

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

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