关于JDBC中properties默认编码格式为ISO-8859-1导致使用资源绑定器的getString方法出现乱码的解决办法

        在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就可以直接使用了。

 

  • 6
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值