微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

从 http 重定向到 https 时从 url 中删除斜杠

如何解决从 http 重定向到 https 时从 url 中删除斜杠

出于某种原因,当我在其任何页面上以非 https 格式访问这些 url 之一时,它会将您重定向一个断开的链接,其中斜杠已被删除(从而更改 url 中的实际域并吸引用户场外)。

http://www.example.com/fr-FR 执行 302 重定向https://www.example.comfr-fr

在顶层,一切正常,http://www.example.com 重定向https://www.example.com

我尝试编辑 .htaccess 文件以捕获所有 http 并重定向到 https,但没有成功。我曾尝试将特定 url 重定向到其对应的 https,但在我的重定向被命中之前,我们仍然命中了相同的 302 重定向

我也在 vhost 文件中尝试了许多不同的重定向,但由于某种原因,似乎没有任何影响这个问题。我还尝试删除 .htaccess 并删除 vhost 文件删除任何有罪的代码,但这也无济于事。 有没有人知道是什么导致了这个问题?

这是 .conf 文件

    <VirtualHost *:80>
    ServerName example.com/
    ServerAlias www.example.com/
    DocumentRoot /var/www/2lbgfz7l.example.com
    DirectoryIndex index.html
    ErrorLog /var/log/apache2/2lbgfz7l.example.com.error.log
    CustomLog /var/log/apache2/2lbgfz7l.example.com.access.log combined
    Redirect 301 / https://www.example.com/$1

    <Location / >
        RewriteEngine on
        RewriteCond %{REQUEST_FILENAME} -s [OR]
        RewriteCond %{REQUEST_FILENAME} -l [OR]
        RewriteCond %{REQUEST_FILENAME} -d
        RewriteRule ^.*$ - [NC,L]
        RewriteRule ^(.*) /index.html/ [NC,L]
    </Location>

    <Directory "/var/www/2lbgfz7l.example.com">
            Options -Indexes +FollowSymLinks -MultiViews
            AllowOverride All
    </Directory>
</VirtualHost>

<IfModule mod_ssl.c>
  <VirtualHost *:443>
        ServerName example.com/
        ServerAlias www.example.com/
        DocumentRoot /var/www/2lbgfz7l.example.com
        DirectoryIndex index.html

        ErrorLog /var/log/apache2/example.com.error.log
        CustomLog /var/log/apache2/example.com.access.log combined

        <Directory "/var/www/2lbgfz7l.example.com">
                Options -Indexes +FollowSymLinks -MultiViews
                AllowOverride All
        </Directory>

        # Possible values include: debug,info,notice,warn,error,crit,# alert,emerg.
        LogLevel warn

        SSLEngine on

        <FilesMatch "\.(cgi|shtml|phtml|PHP)$">
            SSLOptions +StdEnvVars
        </FilesMatch>
        <Directory /usr/lib/cgi-bin>
            SSLOptions +StdEnvVars
        </Directory>

        browserMatch   "MSIE [2-6]" nokeepalive ssl-unclean-shutdown downgrade-1.0 force-response-1.0
        browserMatch "MSIE [17-9]" ssl-unclean-shutdown
        SSLCertificateChainFile /etc/apache2/ssl.crt/example.com.chain-2.pem
        SSLCertificateFile /etc/apache2/ssl.crt/example.com.chain-2.pem
        SSLCertificateKeyFile /etc/apache2/ssl.crt/example.com.key
    </VirtualHost>
</IfModule>

这是 .htaccess 文件

<IfModule mod_expires.c>
    ExpiresActive On
    ExpiresByType image/jpg "access 1 year"
    ExpiresByType image/jpeg "access 1 year"
    ExpiresByType image/gif "access 1 year"
    ExpiresByType image/png "access 1 year"
    ExpiresByType text/css "access 1 month"
    ExpiresByType text/html "access 1 month"
    ExpiresByType application/pdf "access 1 month"
    ExpiresByType text/x-javascript "access 1 month"
    ExpiresByType text/css "access plus 1 year"
    ExpiresByType application/x-shockwave-flash "access 1 month"
    ExpiresByType image/x-icon "access 1 year"
    ExpiresDefault "access 1 month"
</IfModule>

<IfModule mod_headers.c>
  <FilesMatch "\.(js|css|xml|gz)$">
    Header append vary: Accept-Encoding
  </FilesMatch>
</IfModule>

<ifModule mod_gzip.c>
    mod_gzip_on Yes
    mod_gzip_dechunk Yes
    mod_gzip_item_include file .(html?|txt|css|js|PHP|pl)$
    mod_gzip_item_include handler ^cgi-script$
    mod_gzip_item_include mime ^text/.*
    mod_gzip_item_include mime ^application/x-javascript.*
    mod_gzip_item_exclude mime ^image/.*
    mod_gzip_item_exclude rspheader ^content-encoding:.*gzip.*
</ifModule>

<IfModule mod_deflate.c>
    SetoutputFilter DEFLATE
    AddOutputFilterByType DEFLATE text/html text/css text/plain text/xml text/x-js text/js
</IfModule>

<IfModule mod_rewrite.c>
    RewriteEngine On
    RewriteCond %{HTTP_HOST} ^example\.com [NC]
    RewriteCond %{SERVER_PORT} 80
    RewriteRule ^(.*)$ https://www.example.com/$1 [R=301,L]

    RewriteEngine On
    RewriteCond %{HTTP_HOST} !^www\.
    RewriteRule ^(.*)$ https://www.%{HTTP_HOST}/$1 [R=301,L]
</IfModule>

解决方法

看起来问题是我在 /etc/apache2/sites-available 中处理的 .conf 文件没有被服务器读取,因为在 /etc/apache2/sites-enabled 中而不是我正在处理的 .conf 文件的符号链接在 /sites-available 中有一个 .conf 文件的副本,该文件正在被服务器读取。这个 conf 文件保存了不正确的重定向 - 一旦我删除了这个重复的文件并通过运行添加了一个符号链接

sudo ln -s /etc/apache2/sites-available/example.com.conf 来自 etc/apache2/sites-enabled 目录,我更新的 .conf 文件被读取。

在我更新的文件中,我删除了指令:

   <Location / >
        RewriteEngine on
        RewriteCond %{REQUEST_FILENAME} -s [OR]
        RewriteCond %{REQUEST_FILENAME} -l [OR]
        RewriteCond %{REQUEST_FILENAME} -d
        RewriteRule ^.*$ - [NC,L]
        RewriteRule ^(.*) /index.html/ [NC,L]
    </Location>

删除此问题后,问题解决了。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。