开发者社区> 问答> 正文

java.sql.SQLException: Access denied

Access denied for user 'root'@'www.bugd.net' (using password: YES)
我买了一个阿里云服务器 在本地myeclipse上的项目连接阿里云服务器上的mysql是可以的,项目可以运行,但是当我把项目移植到阿里云服务器上的tomcat上时,在通过域名访问时我的项目时出现了java.sql.SQLException: Access denied for user 'root'@'www.bugd.net' (using password: YES)
我确定用户名和密码是正确的,因为在本地运行时可以的,我只是将程序部署到阿里云服务器上,我也把权限都授权了,还是不行。。。。。哎。。。。困扰两天了

展开
收起
a123456678 2016-03-10 14:17:53 4103 0
2 条回答
写回答
取消 提交回答
  • 推荐回答:

    这是因为虽然用户名和密码正确,但是却没有在其他ip地址上访问的权限。需要登录mysql然后修改权限。

    具体操作是首先本地登陆MySQL,然后执行这两句代码:GRANT ALL PRIVILEGES ON . TO root@‘%’ IDENTIFIED BY ’000000′;FLUSH PRIVILEGES;

    格式:grant 权限 on 数据库名.表名 用户@登录主机 identified by “用户密码”;

    参数说明: ALL PRIVILEGES表示赋给远程登录用户的权限,ALL PRIVILEGES表示所有的权限,你也可以单独或组合赋select,update,insert,delete权限;.:

    第一个表示要赋权的数据库名,当然表示全部数据库了,

    第二个表示数据库下的表名,同理,表示全部表,像我这样的懒人当然就直接用.了,反正都是自己开发用

    root表示要赋权的用户;%表示远程登录的IP(你用来登录的ip),如果要限制登录IP的话,这里就添你允许登录的IP,比如192.18.1.99等,%表示不限制IP,000000是用户远程登录的密码。就这么简单。这句运行以后再运行FLUSH PRIVILEGES,就可以了。

    官方帮助文档地址:阿里云帮助中心

    更多参考: 阿里云官方(新用户需官网注册查看)

    2021-04-19 00:13:26
    赞同 展开评论 打赏
  • 这是因为虽然用户名和密码正确,但是却没有在其他ip地址上访问的权限。需要登录mysql然后修改权限。
    具体操作是首先本地登陆MySQL,然后执行这两句代码:GRANT ALL PRIVILEGES ON . TO root@‘%’ IDENTIFIED BY ’000000′;FLUSH PRIVILEGES;
    格式:grant 权限 on 数据库名.表名 用户@登录主机 identified by “用户密码”;

    参数说明: ALL PRIVILEGES表示赋给远程登录用户的权限,ALL PRIVILEGES表示所有的权限,你也可以单独或组合赋select,update,insert,delete权限;.:第一个表示要赋权的数据库名,当然表示全部数据库了,第二个表示数据库下的表名,同理,表示全部表,像我这样的懒人当然就直接用.了,反正都是自己开发用

    root表示要赋权的用户;%表示远程登录的IP(你用来登录的ip),如果要限制登录IP的话,这里就添你允许登录的IP,比如192.18.1.99等,%表示不限制IP,000000是用户远程登录的密码。就这么简单。这句运行以后再运行FLUSH PRIVILEGES,就可以了。

    2019-07-17 18:57:35
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
SQL Server 2017 立即下载
低代码开发师(初级)实战教程 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载