在JDBC的注册驱动与连接数据库方面,通常将driver,url,user,password来放入配置文件中,并使用资源绑定器ResourceBundle来更快捷灵活地进行编程。
而资源绑定器的实例方法getString(key),如果传入的key对应的value包含汉语,则会返回一个拥有乱码的字符串。
如下的键值对中出现中文数据库名:
url=jdbc:mysql://127.0.0.1:3306/618网购
会导致乱码 ,如图
此时的解决办法为使用String的一个有参构造方法将getString获取的乱码转换为utf-8
String url = null;
try {
//如果数据库名是中文,则需要转换编码格式
url = new String(resourceBundle.getString("url").getBytes("ISO-8859-1"),"utf-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
System.out.println(url);
经过转换编码之后便可以正常连接数据库了。
为了更加方便,我们可以将 ISO-8859-1 配置进配置文件
codeFormat=ISO-8859-1
并将代码改写为:
ResourceBundle resourceBundle = ResourceBundle.getBundle("JDBC");
//获取getString的编码格式
String codeFormat = resourceBundle.getString("codeFormat");
String driver = resourceBundle.getString("driver");
String url = null;
try {
url = new String(resourceBundle.getString("url").getBytes(codeFormat),StandardCharsets.UTF_8);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
第二种方法,直接修改IDEA中properties文件的默认编码格式,这样getString就可以直接使用了。