栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

PHP到MySQL SSL连接

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

PHP到MySQL SSL连接

在这里,PHP(和

mysqli_real_connect
)是客户端而不是服务器。您正在使用
mysqli_ssl_set
客户端证书身份验证(以及服务器密钥和证书)对其进行配置。

我不确定您是如何配置MySQL服务器的,但是在配置的(MySQL)服务器部分中应该有类似的内容:

ssl-key=/mysql-ssl-certs/server-key.pemssl-cert=/mysql-ssl-certs/server-cert.pemssl-ca=/mysql-ssl-certs/ca-cert.pem

无论如何,它们都不属于客户端(只有CA证书才属于,但绝对不是服务器的私钥)。

完成此操作后,您可以尝试使用命令行客户端查看服务器是否配置正确:

mysql --ssl-verify-server-cert --ssl-ca=/mysql-ssl-certs/ca-cert.pem --ssl -h hostname ...

或这样做(尽管应该确实启用验证服务器证书以使SSL / TLS有用)

mysql --ssl-ca=/mysql-ssl-certs/ca-cert.pem --ssl -h hostname ...

这至少应该在命令行上起作用。

然后,从PHP获得两种选择:

  • 使用
    mysqli_ssl_set
    像你这样做,但离开
    $key
    $cert
    无效的,除非你想使用一个客户端证书这确实应该是从你的服务器证书不同。(我不记得那是否有效。)
  • 可能更容易,将其
    mysqli_ssl_set
    完全省略,并在全局MySQL客户端配置文件中进行配置(PHP应该可以在其中拾取它
    /etc/mysql/my.cnf
    ,但可能会有所不同,但这取决于您的发行版):
    [client]

    ssl-ca=/mysql-ssl-certs/ca-cert.pem

(这类似于服务器配置,但在客户端/客户端部分。)

对于授权部分(

GRANT
):

  • REQUIRE SSL
    只需要使用SSL / TLS
  • REQUIRE ISSUER
    REQUIRE SUBJECT
    REQUIRE X509
    要求客户出示客户端证书来比较所需的值(这就是你需要的情况下使用
    ssl-key
    ,并
    ssl-cert
    在客户端(配置或内
    mysqli_ssl_set
    )。


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/408275.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号