SSLRequire 文件表达式

Posted

技术标签:

【中文标题】SSLRequire 文件表达式【英文标题】:SSLRequire file expression 【发布时间】:2017-11-30 22:02:07 【问题描述】:

我在 Apache 2.4 中遇到 的问题,因为它似乎无法找到或无法访问相关文件。

以下是代码摘录:

<Location />    
                SSLOptions +StrictRequire
                SSLRequireSSL
                SSLRequire (%SSL_CLIENT_CERT eq file("<full_path_to_PEM_file>"))
</Location>

当我尝试访问该站点时,我在日志中收到此错误:

[Tue Jun 27 13:20:02.358478 2017] [ssl:error] [pid 18661:tid 47040594310912] [client 82.69.3.205:58275] Evaluation of expression from 20-mod_ssl.conf:240 failed: Cannot open file <full_path_to_PEM_file>, referer: https://example.com/

权限正确,文件肯定存在,所以这里不知道还能做什么。

PEM 文件是一个有效的公共证书,在开始和结束处都有“BEGIN CERTIFICATE”和“END CERTIFICATE”行...

有什么想法吗?

【问题讨论】:

【参考方案1】:

您的虚拟主机应如下所示:

<VirtualHost *:443>
    ServerAdmin webmaster@example.com
    DocumentRoot /var/www/html/example

    ServerName example.com

    SSLEngine on

    SSLCertificateFile /etc/ssl/CA/example_com.crt
    SSLCertificateKeyFile /etc/ssl/CA/example.key

    # https://support.comodo.com/index.php?_m=knowledgebase&_a=viewarticle&kbarticleid=1203&nav=0,96,1,95
    SSLCertificateChainFile /etc/ssl/CA/chain_example_with_Positive.pem

    SSLHonorCipherOrder On
    SSLProtocol -all +TLSv1 +SSLv3
    SSLCipherSuite RC4-SHA:HIGH:!MD5:!aNULL:!EDH:!ADH
    SSLInsecureRenegotiation off

    <Directory /example/>
            Options Indexes SymLinksIfOwnerMatch
            AllowOverride All
            Require all granted
    </Directory>
    <Directory /var/www/html/example/>
            Options Indexes SymLinksIfOwnerMatch
            AllowOverride All
            Order allow,deny
            allow from all
    </Directory>

    ErrorLog $APACHE_LOG_DIR/error.log
    SetEnvIf User-Agent ".*MSIE.*" nokeepalive ssl-unclean-shutdown    
</VirtualHost>

【讨论】:

谢谢,但这不是我要问的。根据您的回答,我已经安装了公钥和私钥 - 这不是问题。我正在尝试为客户端添加额外的身份验证层,以便在他们可以连接之前提供他们的证书。这是通过 SSLRequire 选项加上 SSLOptions +StrictRequire 来完成的。我的问题是关于文件表达式,它似乎不适用于 SSLRequire... 好的...您是否注意到错误为 Cannot open file &lt;full_path_to_PEM_file&gt; ?这意味着根本没有名为 Cannot open file &lt;full_path_to_PEM_file&gt; 的文件 是的,就像我在原帖中所说的那样......“权限正确,文件肯定存在” 先生...如果您想为您的特定问题提供解决方案,您不需要提供确切的输出...不要显示密码...但其余的... 但同样,输出在原始问题中 - 没有其他可显示的......

以上是关于SSLRequire 文件表达式的主要内容,如果未能解决你的问题,请参考以下文章

正则表达式匹配文件名

正则表达式如何匹配excel文件

dos命令能不能结合正则表达式来批量修改文件名?

正则表达式 判断文件名后缀是不是为 csv xls xlsx

shell 的条件表达式及逻辑操作符简单介绍

正则表达式:除了特殊文件类型(如.lnk)之外的所有文件