Java Web连接MySql数据库,修改数据库连接类中的用户名和密码没有效果?

现在在做一个项目,其中编写了数据库连接及操作的类。
1、ConnDB类。

package com.wgh.tools;

import java.io.InputStream; //导入java.io.InputStream类
import java.sql.*; //导入java.sql包中的所有类
import java.util.Properties; //导入java.util.Properties类

public class ConnDB {
public Connection conn = null; // 声明Connection对象的实例
public Statement stmt = null; // 声明Statement对象的实例
public ResultSet rs = null; // 声明ResultSet对象的实例
//private static String propFileName = "connDB.properties"; // 指定资源文件保存的位置
//private static Properties prop = new Properties(); // 创建并实例化Properties对象的实例
private static String dbClassName = "com.mysql.jdbc.Driver"; // 定义保存数据库驱动的变量
private static String dbUrl = "jdbc:mysql://127.0.0.1:3306/db_9griddiary?user=root&password=&useUnicode=true&characterEncoding=utf8";

// public ConnDB() { // 构造方法
// try { // 捕捉异常
// // 将Properties文件读取到InputStream对象中
// InputStream in = getClass().getResourceAsStream(propFileName);
// prop.load(in); // 通过输入流对象加载Properties文件
// dbClassName = prop.getProperty("DB_CLASS_NAME"); // 获取数据库驱动
// // 获取连接的URL
// dbUrl = prop.getProperty("DB_URL", dbUrl);
// } catch (Exception e) {
// e.printStackTrace(); // 输出异常信息
// }
// }

/**
 * 功能:获取连接的语句
 * 
 * @return
 */
public static Connection getConnection() {
    Connection conn = null;
    try { // 连接数据库时可能发生异常因此需要捕捉该异常
        Class.forName(dbClassName).newInstance(); // 装载数据库驱动
        conn = DriverManager.getConnection(dbUrl); // 建立与数据库URL中定义的数据库的连接
    } catch (Exception ee) {
        ee.printStackTrace(); // 输出异常信息
    }
    if (conn == null) {
        System.err
                .println("警告: DbConnectionManager.getConnection() 获得数据库链接失败.\r\n\r\n链接类型:"
                        + dbClassName + "\r\n链接位置:" + dbUrl); // 在控制台上输出提示信息
    }
    return conn; // 返回数据库连接对象
}

/*
 * 功能:执行查询语句
 */
public ResultSet executeQuery(String sql) {
    try { // 捕捉异常
        conn = getConnection(); // 调用getConnection()方法构造Connection对象的一个实例conn

        stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,
                ResultSet.CONCUR_READ_ONLY);
        rs = stmt.executeQuery(sql);

    } catch (SQLException ex) {
        System.err.println(ex.getMessage()); // 输出异常信息
    }
    return rs; // 返回结果集对象
}

/*
 * 功能:执行更新操作
 */
public int executeUpdate(String sql) {
    int result = 0; // 定义保存返回值的变量
    try { // 捕捉异常
        conn = getConnection(); // 调用getConnection()方法构造Connection对象的一个实例conn
        stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,
                ResultSet.CONCUR_READ_ONLY);
        result = stmt.executeUpdate(sql); // 执行更新操作
    } catch (SQLException ex) {
        result = 0; // 将保存返回值的变量赋值为0
    }
    return result; // 返回保存返回值的变量
}

/*
 * 功能:关闭数据库的连接
 */
public void close() {
    try { // 捕捉异常
        if (rs != null) { // 当ResultSet对象的实例rs不为空时
            rs.close(); // 关闭ResultSet对象
        }
        if (stmt != null) { // 当Statement对象的实例stmt不为空时
            stmt.close(); // 关闭Statement对象
        }
        if (conn != null) { // 当Connection对象的实例conn不为空时
            conn.close(); // 关闭Connection对象
        }
    } catch (Exception e) {
        e.printStackTrace(System.err); // 输出异常信息
    }
}

}

第一次连接成功。
第二次为什么无论把这个类中的用户名和密码修改成什么都能连接上MySql了?
请问这个类中的用户名和密码有用吗?
那在哪儿修改用户名和密码后就连接不上Mysql了?

6个回答

如果遇到这种情况,可以考虑clean project;然后在试试,如果还不行再看代码;需要用到数据库帐号密码只有在链接的时候用到。

tyBaoErGe
kevin-go 回复hoho_12: 你用的如果是eclipse myeclipse的话, 在菜单栏-->Project-->clean试试
大约 4 年之前 回复
hoho_12
hoho_12 怎么clean project?
大约 4 年之前 回复

为了方便程序移植,这里将数据库连接所需信息保存到properties文件中,并将该文件保存在com.wgh.tools包中。connDB。propertites文件的内容如下:
DB_CLASS_NAME=com.mysql.jdbc.Driver
DB_URL=jdbc:mysql://127.0.0.1:3306/db_9griddiary?user=root&password=111&useUnicode=true&characterEncoding=utf8
在这里修改用户名和密码也没用。

你所说的"效果"是指什么?
1.正确的用户名密码能连接,但修改为错误的用户名密码也能连接进去?
2.无论修改不修改用户名密码都连接不进去?
问问题请准确描述

hoho_12
hoho_12 正确的用户名密码能够连接,错误的也能连接。
大约 4 年之前 回复

如果我把Mysql的用户名和密码修改了再登录,这里的用户名和密码改成什么都没用,这个传进去的用户名和密码好像已经固定了(就是第一次运行时上面类中设置的用户名和密码。)。

修改MySql密码后就有这个错误。
警告: DbConnectionManager.getConnection() 获得数据库链接失败.
链接类型:com.mysql.jdbc.Driver
链接位置:jdbc:mysql://127.0.0.1:3306/db_9griddiary?user=root&password=111&useUnicode=true

为什么它一直获取的是这个连接位置,这里的用户名和密码一直没有改过来?是什么原因?

private static String dbUrl = "jdbc:mysql://127.0.0.1:3306/db_9griddiary?user=root&password=&useUnicode=true&characterEncoding=utf8";
你这一句不是已经就把连接的用户名密码写死了吗?

sinat_34662125
sinat_34662125 回复hoho_12: 请问你解决这个问题了吗
大约 2 年之前 回复
tyBaoErGe
kevin-go 回复hoho_12: 你试试不通过Url传递用户名密码 ,通过DriverManager.getConnection(String url, String user, String password)来传递用户名密码
大约 4 年之前 回复
hoho_12
hoho_12 这句是定义,赋初值啊,而且改这句里面的用户名和密码都没用,mysql总能连上。这里的用户名和密码值传不进去。
大约 4 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问