php连接MySQL时产生错误:mysqlnd cannot connect to MySQL 4.1+ using old authentication

1 篇文章 0 订阅
1 篇文章 0 订阅

1.本人开发PHP使用的是appserv-win32-2.6.0.exe,其中PHP版本是6.0.0-dev,MySQL版本是 6.0.4-alpha-community-log。在使用PHP连接数据库是产生了如下错误:

Warning: mysql_connect() [function.mysql-connect]: OK packet 6 bytes shorter than expected. PID=248 in D:\Code\AppServ\InstallLocation\AppServ\www\mysqltest.php on line 3

Warning: mysql_connect() [function.mysql-connect]: mysqlnd cannot connect to MySQL 4.1+ using old authentication in D:\Code\AppServ\InstallLocation\AppServ\www\mysqltest.php on line 3

Warning: mysql_connect() [function.mysql-connect]: in D:\Code\AppServ\InstallLocation\AppServ\www\mysqltest.php on line 3
连接失败:

我的代码如下:

<?php
	header("content-type:text/html;charset=utf-8");
	$conn=mysql_connect("localhost","root","root");
	if(!$conn){
		die("连接失败:".mysql_error());
	}
	echo $conn;//连接成功,打印出取到的连接
	mysql_select_db("mysql");
	mysql_query("set names utf8");
	mysql_close($conn);
?>
问题原因: 使用高版本mysql数据库导入了低版本数据引起的,其中高版本数据库的password hashes 是41位的hashes,而低版本数据库的数据存储的root 的password是16位的hashes,需要修改user表的password字段数据为41为的hashes。

解决办法:

use mysql;    // 进入存储user表的数据库
set session old_passwords=0;   //修改session使用41位hashes(16为1,41的为0)
select password('root');   //查看你的password函数是否可以生成41位的hashes
set password for 'root' @'localhost' = password('root');   //使用password函数修改你的root密码为41的hashes







  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值