php連線MySQL時產生錯誤:mysqlnd cannot connect to MySQL 4.1+ using old authentication
阿新 • • 發佈:2019-02-17
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
連線失敗:
我的程式碼如下:
問題原因:使用高版本mysql資料庫匯入了低版本資料引起的,其中高版本資料庫的password hashes 是41位的hashes,而低版本資料庫的資料儲存的root 的password是16位的hashes,需要修改user表的password欄位資料為41為的hashes。<?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); ?>
解決辦法:
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