AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1066076
Accepted
poypoy
poypoy
Asked: 2021-06-09 07:27:23 +0800 CST2021-06-09 07:27:23 +0800 CST 2021-06-09 07:27:23 +0800 CST

apache如何配置多域https重定向?

  • 772

我有一个在 AWS Elastic beanstalk 下运行的 apache。我有几个不同的域,我希望它们都以 HTTPS 中的特定域名结尾。

从其他域(例如https://domain1.com到https://maindomain.com的重定向)返回 SSL 证书错误。

在 apache 中,我有两个虚拟主机配置,一个用于 *:80,一个用于 *:443。两者都是为 maindomain.com 设置的。它们是用 certbot 创建的。

让这个适用于所有其他领域的最佳实践应该是什么?我想我需要为每个域设置一个 VirtualHost,但是如何配置它才能让它与重定向一起工作?

显然,以下示例不起作用,因为它返回 SSL 错误:

<IfModule mod_ssl.c>
<VirtualHost domain1.com:443>
        ServerName domain1.com
        RedirectPermanent / https://maindomain.com/
</VirtualHost>
</IfModule>

这是默认的 Virtualhost *:80 配置

<VirtualHost *:80>
        #ServerName maindomain.com
        DocumentRoot /var/www/html
        <Directory /var/www/html>
                Options -Indexes +FollowSymLinks +MultiViews
                AllowOverride All
                Require all granted
        </Directory>
RewriteEngine on
RewriteCond %{SERVER_NAME} =maindomain.com
RewriteRule ^ https://%{SERVER_NAME}%{REQUEST_URI} [END,NE,R=permanent]
</VirtualHost>

这是默认的 Virtualhost *:443 配置

<IfModule mod_ssl.c>
<VirtualHost *:443>
        #ServerName maindomain.com
        DocumentRoot /var/www/html
        <Directory /var/www/html>
                Options -Indexes +FollowSymLinks +MultiViews
                AllowOverride All
                Require all granted
        </Directory>
ServerName maindomain.com

SSLCertificateFile /etc/letsencrypt/live/maindomain.com/fullchain.pem
SSLCertificateKeyFile /etc/letsencrypt/live/maindomain.com/privkey.pem
Include /etc/letsencrypt/options-ssl-apache.conf
</VirtualHost>
</IfModule>

您的帮助将不胜感激。D

ssl-certificate apache-2.4 apache2 elastic-beanstalk certbot
  • 1 1 个回答
  • 323 Views

1 个回答

  • Voted
  1. Best Answer
    ezra-s
    2021-06-15T22:59:31+08:002021-06-15T22:59:31+08:00

    要么您获得包含多个名称的证书以涵盖所有域,要么查看您提到的域方案,您将在某些时候收到证书错误。

    理论上,浏览器会查看 SAN/CN 以匹配其中找到的名称以及它们用于连接的 DNS 名称,如果不匹配,则会出现证书错误。

    如果您使用的其他域是子域,您至少可以有一个多名称证书或通配符。

    例如对于域:

    不管是什么.example.com ,您都可以使用像 * .example.com这样的通配符,甚至包括一个用于 example.com 的 SAN。

    另请注意,如果您有 1 个带有“example.com”的虚拟主机,对到达您服务器的其他名称的请求将由同一个虚拟主机处理,因此您要么拥有一个具有多个名称的证书,它与所有情况都匹配,要么您必须创建一个方案您可以在其中通过不同的虚拟主机和证书涵盖它们。这完全取决于您真正想要涵盖的内容。

    • 0

相关问题

  • RHEL/Apache ssl.conf 配置问题

  • IIS7 中的证书信任列表

  • SSL证书的区别?

  • 如何修复邮件服务器 SSL?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve