htacess重定向未重定向

问题描述 投票:-1回答:1

我正在将create-react-appreact-router一起使用。我该如何进行以下任何一种更改(我想我不会错过任何一种):

重定向到:

[https://example.com(请注意,https受保护,没有www。)]

我使用以下代码创建了一个.htaccess文件:

<ifModule mod_rewrite.c>
  Options +FollowSymLinks
  IndexIgnore */*
  RewriteEngine On

  RewriteCond %{HTTPS} off

  RewriteRule ^(.*) https://%{HTTP_HOST}/$1 [R,L]

  RewriteCond %{REQUEST_FILENAME} !-f
  RewriteCond %{REQUEST_FILENAME} !-d
  RewriteCond %{REQUEST_FILENAME} !\/$
  RewriteRule ^(.*) /

</ifModule>

<IfModule mod_headers.c>
  <FilesMatch "sw\.js$">
    Header set Cache-Control "private, no-cache, no-store, proxy-revalidate, no-transform"
    Header set Pragma "no-cache"
  </FilesMatch>
</IfModule>

[添加时,路由将定向到安全的https,但是当我在网址中键入www时,www在那里。如何让浏览器始终重定向到没有www。?

reactjs .htaccess redirect
1个回答
0
投票

重定向到另一台主机应该像这样更好地工作,请注意硬接线目标主机名:

RewriteEngone on

RewriteCond %{HTTPS} off
RewriteRule ^/?(.*)$ https://example.com/$1 [R=301]

RewriteCond %{HTTP_HOST} !^example\.com$
RewriteRule ^/?(.*)$ https://example.com/$1 [R=301]

最好先从302临时重定向开始,然后在确定一切设置正确后,再将其更改为301永久重定向。这样可以防止在尝试时缓存问题...

将这些规则放在任何内部重写规则之前(您的示例显示了对?/的一般重写)。

此实现将在http服务器主机配置或动态配置文件(“ .htaccess”文件)中同样起作用。显然,重写模块需要加载到http服务器内部并在http主机中启用。如果使用动态配置文件,则需要注意在主机配置中完全启用了它的解释,并且该解释位于主机的DOCUMENT_ROOT文件夹中。

和一般说明:您应该始终喜欢将此类规则放置在http服务器主机配置中,而不要使用动态配置文件(“ .htaccess”)。这些动态配置文件增加了复杂性,通常是导致意外行为,难以调试的原因,并且确实降低了http服务器的速度。仅当您无法访问真正的http服务器主机配置(阅读:真正便宜的服务提供商)或坚持编写自己的规则的应用程序(这显然是安全的噩梦)时,才提供它们作为最后的选择。

© www.soinside.com 2019 - 2024. All rights reserved.