php与mysql无法连接,提示错误如下:
warning: mysql_connect() [function.mysql-connect]: client does not support authentication protocol requested by server; consider upgrading mysql client
in d:\xxxx\xxxx\apache-tomcat-8.0.5\webapps\project\opendb.php on line 5
could not connect: client does not support authentication protocol requested by server; consider upgrading mysql client
php的版本是php-4.4.9
myslq的版本是5.6
tomcat的版本是8.0.5
想要在本地搭建一个php的开发环境(tomcat+mysql+php)。
现在
1、tomcat与php已经调通,在页面上可以看到phpinfo。
2、tomcat与mysql也调通,用jsp页面可以查询mysql中的表信息。
注:在网上查到的解决方法都不行。下面方法试过了,还是同样的错误提示。
----------------------------------------------------------------------------------------------------
主要是改变连接 mysql 帐户的加密方式,mysql 4.1/5.0 是通过 password 这种方式加密的。可以通过以下两种方法得到解决:
1) mysql->set password for 'some_user'@'some_host'=old_password('new_password');
mysql->flush privileges;
2)mysql->update mysql.user set password=old_password('new_password') where host='some_host' and user='some_user';
mysql->flush privileges;
----------------------------------------------------------------------------------------------------
回复讨论(解决方案) 你的 mysql 是自己安装吧?
tomcat、php、mysql都是自己安装的
你的 mysql 是自己安装吧?
tomcat、php、mysql都是自己安装的 背景
从 php 5.3 开始,php 的 mysql 操作只使用内置的 mysql 客户端
显然这个客户端的版本是要低于 5.6 的,但不影响使用
原因
你安装 mysql 时,安装程序会把 mysql 的安装路径追加到操作系统环境变量 path 中
这就是不能访问的根源
补救
所以你需要从 path 中去掉 mysql 的路径
不过这样一来,jdbc 可能就无法连接 mysql 了,可能需要重新配置一下
背景
从 php 5.3 开始,php 的 mysql 操作只使用内置的 mysql 客户端
显然这个客户端的版本是要低于 5.6 的,但不影响使用
原因
你安装 mysql 时,安装程序会把 mysql 的安装路径追加到操作系统环境变量 path 中
这就是不能访问的根源
补救
所以你需要从 path 中去掉 mysql 的路径
不过这样一来,jdbc 可能就无法连接 mysql 了,可能需要重新配置一下
非常感谢回复。
首先我使用的php是4.4.9,而不是5.3以上版本。
其次,在path中并没有mysql的路径。
背景
从 php 5.3 开始,php 的 mysql 操作只使用内置的 mysql 客户端
显然这个客户端的版本是要低于 5.6 的,但不影响使用
原因
你安装 mysql 时,安装程序会把 mysql 的安装路径追加到操作系统环境变量 path 中
这就是不能访问的根源
补救
所以你需要从 path 中去掉 mysql 的路径
不过这样一来,jdbc 可能就无法连接 mysql 了,可能需要重新配置一下
还有个问题,不知道是否有关系。
在我利用:mysql->set password for 'some_user'@'some_host'=old_password('new_password');
修改密码时会提示:error 1372 (hy000): password hash should be a 41-digit hexadecimal number
当改为mysql->set password for 'some_user'@'some_host'=old_password('');时会成功。
※及密码为空。
但是我通过mysqladmin -u root -p password 是可以修改密码的,jdbc在密码为空和不为空时都可以访问。
这个问题还是没有解决,但是我通过其他方法配置成功了。
把mysql5.6卸载后安装了mysql4.1。 就没有那个错误了。
但有出现了一个新问题,在php页面中我写的用户是a,但是错误提示说b@localhost (b是我本机的用户名)不能访问mysql。
后来在mysql的user表中新增了一个b的用户。
终于搞定了。
还是感谢版主及时回复。。