Python连接到MySQL失败,错误“dh key too small”
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Python连接到MySQL失败,错误“dh key too small”,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1282字,纯文字阅读大概需要2分钟。
内容图文
![Python连接到MySQL失败,错误“dh key too small”](/upload/InfoBanner/zyjiaocheng/894/3e12d715827c4a7b9dbe5417b4d40d79.jpg)
我正在尝试连接到公司的MySQL数据库.策略是我只使用SSL连接.
我提供了用户名,CA证书,证书和私钥.
如果我使用HeidiSQL,我可以毫无问题地连接.
但是,我无法使用Python 2.7.11与mysql-connector-python-rf(v2.1.3)进行连接.
这是我的简单连接测试程序:
from __future__ import print_function, division, unicode_literals
import mysql.connector
from mysql.connector.constants import ClientFlag
cnx = mysql.connector.connect(
user='myusername',
host='myserver.example.com',
port=3306,
client_flags=[ClientFlag.SSL],
ssl_ca='/path/to/ca.crt',
ssl_cert='/path/to/user.crt',
ssl_key='/path/to/user.key'
)
cnx.close()
我总是得到这个例外:
mysql.connector.errors.InterfaceError: 2055: Lost connection to MySQL server at
'myserver.example.com:3306', system error: 1 [SSL: SSL_NEGATIVE_LENGTH] dh key too small
(_ssl.c:590)
我试过寻找答案,但除了更改服务器端的设置之外似乎没有解决方案,这简直就是禁止.
我该如何修复和/或解决此问题?
更多信息更新:我正在使用PyCharm 5.0.3在Windows 10上创建我的程序
解决方法:
这是一个安全问题,服务器端受到weak DH key的影响.当前版本的OpenSSL强制使用最小长度的DH密钥,以防止使用弱DH密钥的攻击.
如果你的公司真的对安全性感兴趣,而不仅仅是相信神奇地洒下一些(不安全的)SSL会做到这一点,那么他们应该在服务器端解决这个问题.要在客户端解决问题,您的Python需要与旧版本的OpenSSL链接,而OpenSSL尚未强制实施最小DH密钥长度.
内容总结
以上是互联网集市为您收集整理的Python连接到MySQL失败,错误“dh key too small”全部内容,希望文章能够帮你解决Python连接到MySQL失败,错误“dh key too small”所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。