oldpassword mysql_mysql OLD_PASSWORD's problem | 2hei's site

In my mysql slave and master’s

i meet a problem:

[MysqlDb.connectDB]java.sql.SQLException: Client does not support authentication protocol requested by server; consider upgrading MySQL client

this is a problem of mysql update version 4.1 and more!

to sovle it , we can do this

1st:

mysql> SET PASSWORD FOR

-> ‘some_user’@’some_host’ = OLD_PASSWORD(‘newpwd’);

2nd:

mysql> UPDATE mysql.user SET Password = OLD_PASSWORD(‘newpwd’)

-> WHERE Host = ‘some_host’ AND User = ‘some_user’;

mysql> FLUSH PRIVILEGES;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个简单的基于B/S架构的信息管理系统的用户账户系统的Java代码实现,数据库使用MYSQL。 1. 设计数据库表结构 在MYSQL数据库中创建一个名为"users"的表,包含以下字段: - id(int,主键,自增) - username(varchar(50),用户名,唯一) - password(varchar(50),密码) - email(varchar(50),邮箱) 2. 编写Java代码实现用户账户系统 在Java中实现用户账户系统,具体代码如下: ``` import java.sql.*; public class UserAccountSystem { // 数据库连接信息 private static String DB_URL = "jdbc:mysql://localhost:3306/test"; private static String DB_USER = "root"; private static String DB_PASSWORD = "123456"; // 注册用户 public static boolean register(String username, String password, String email) { Connection conn = null; PreparedStatement ps = null; try { // 连接数据库 Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(DB_URL, DB_USER, DB_PASSWORD); // 执行SQL语句 String sql = "INSERT INTO users (username, password, email) VALUES (?, ?, ?)"; ps = conn.prepareStatement(sql); ps.setString(1, username); ps.setString(2, password); ps.setString(3, email); int result = ps.executeUpdate(); // 返回执行结果 return result > 0; } catch (Exception e) { e.printStackTrace(); } finally { // 关闭连接 try { if (ps != null) { ps.close(); } if (conn != null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); } } return false; } // 登录验证 public static boolean login(String username, String password) { Connection conn = null; PreparedStatement ps = null; ResultSet rs = null; try { // 连接数据库 Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(DB_URL, DB_USER, DB_PASSWORD); // 执行SQL语句 String sql = "SELECT * FROM users WHERE username=? AND password=?"; ps = conn.prepareStatement(sql); ps.setString(1, username); ps.setString(2, password); rs = ps.executeQuery(); // 验证结果 return rs.next(); } catch (Exception e) { e.printStackTrace(); } finally { // 关闭连接 try { if (rs != null) { rs.close(); } if (ps != null) { ps.close(); } if (conn != null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); } } return false; } // 修改密码 public static boolean changePassword(String username, String oldPassword, String newPassword) { Connection conn = null; PreparedStatement ps = null; try { // 连接数据库 Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(DB_URL, DB_USER, DB_PASSWORD); // 执行SQL语句 String sql = "UPDATE users SET password=? WHERE username=? AND password=?"; ps = conn.prepareStatement(sql); ps.setString(1, newPassword); ps.setString(2, username); ps.setString(3, oldPassword); int result = ps.executeUpdate(); // 返回执行结果 return result > 0; } catch (Exception e) { e.printStackTrace(); } finally { // 关闭连接 try { if (ps != null) { ps.close(); } if (conn != null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); } } return false; } // 退出登录 public static void logout() { // 清除用户登录信息 } } ``` 3. 进行测试和调试 编写完Java代码后,可以进行测试和调试,检查用户账户系统是否能够正常运行,并且与MYSQL数据库进行交互,实现用户数据的存储和管理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值