Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/apache/9.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Apache 从https重写为http_Apache_Http_Drupal_Https_Rewrite - Fatal编程技术网

Apache 从https重写为http

Apache 从https重写为http,apache,http,drupal,https,rewrite,Apache,Http,Drupal,Https,Rewrite,我在一台apache服务器上有5个站点。其中一个站点使用SSL。因此,当使用https访问其他站点时,它们会被重定向到SSL站点,这是不正确的 例如 https://x.com (使用SSL) http://y.com (正常站点无SSL) 如果我访问https://y.com然后我从x.com获取内容。我如何修复sohttps://y.com刚刚被重写为http://y.com 您可以在apache配置文件中定义它。您必须向从https端口传入的连接添加规则 如果您使用的是linux,则可能在

我在一台apache服务器上有5个站点。其中一个站点使用SSL。因此,当使用https访问其他站点时,它们会被重定向到SSL站点,这是不正确的

例如

https://x.com (使用SSL)

http://y.com (正常站点无SSL)

如果我访问
https://y.com
然后我从x.com获取内容。我如何修复so
https://y.com
刚刚被重写为
http://y.com


您可以在apache配置文件中定义它。您必须向从https端口传入的连接添加规则

如果您使用的是linux,则可能在
/etc/apache2/sites available/default ssl
中有此配置

如果没有此文件,则必须搜索https virtualhost:

<IfModule mod_ssl.c>
<VirtualHost _default_:443>

您可以在apache配置文件中定义它。您必须向从https端口传入的连接添加规则

如果您使用的是linux,则可能在
/etc/apache2/sites available/default ssl
中有此配置

如果没有此文件,则必须搜索https virtualhost:

<IfModule mod_ssl.c>
<VirtualHost _default_:443>

在.htaccess put中:

RewriteCond %{HTTPS} on [NC]
RewriteRule ^(.*)$ http://y.com/$1 [R=301,L]

在您的.htaccess put中:

RewriteCond %{HTTPS} on [NC]
RewriteRule ^(.*)$ http://y.com/$1 [R=301,L]

这应该可以做到,但是,最终用户很可能会遇到与证书相关的错误,因为从https重定向仍然意味着使用https连接到主机,这需要使用主机名的证书。问题是在同一网络接口和端口组合上不能有多个证书(因为证书是在确定请求的主机名之前发送的)。现在我又看了一遍,我不确定这种重写条件是否可以。您更可能需要一个与https虚拟主机中请求的主机名匹配的条件,而不是在常规域中。htaccess。如果您试图通过在文件之间移动语句来避免证书错误,则不会这样做:)在触发任何重写规则之前请求证书,因此,将其移动到虚拟主机也无济于事。至于这是否会起作用-它可以起作用,但我用另一种方法在需要时让用户使用https。这应该可以做到,但是,对于最终用户,您很可能会遇到与证书相关的错误,因为从https重定向仍然意味着使用https连接到主机,这需要使用主机名的证书。问题是在同一网络接口和端口组合上不能有多个证书(因为证书是在确定请求的主机名之前发送的)。现在我又看了一遍,我不确定这种重写条件是否可以。您更可能需要一个与https虚拟主机中请求的主机名匹配的条件,而不是在常规域中。htaccess。如果您试图通过在文件之间移动语句来避免证书错误,则不会这样做:)在触发任何重写规则之前请求证书,因此,将其移动到虚拟主机也无济于事。至于这是否可行,它是可行的,但我用另一种方式让用户在需要时使用https。