问题背景:读取配置文件,但是读到的目录信息是中文乱码的。
第一步:
参考代码如上截图,方法即:读取jdbc配置,获取了配置文件(jdbc.properties)地址,然后加载这个文件读取配置信息,但是获取的文件目录的地址中文转译了。
第二步:
设置编码格式为utf-8,查看重新获取的地址是否可以加载:
ClassLoader classLoader = JdbcUtils.class.getclassLoader();
Url res = classloader.getResource(“jdbc.properties”);
String path = res.getPath();
Path = java.net.URLDecoder.decode(path,”utf-8”);
修改代码设置文件的编码方式如上后,发现这样加载过后虽然不乱码了,但是有两个其他问题,第一:项目中含有“+”可能被空格替换了,第二:多了/out/production/的目录结构。
第三步:解决有‘+’的问题
String path = res.getPath();path = java.net.URLDecoder.decode(res.getPath(),"utf-8"); //解决路径包含中文的情况String path2 = JDBCUtils.class.getResource("/").toURI().getPath();
这样可以原样保留‘+’号,但是还是未解决目录中多增加的/out/production/的目录结构。
第四步:
获取文件目录的所有方式
(这里的代码,可以去参考链接2里面复制)
当前,我采用了第二种获取项目路径的方式。
第五步:
修改后的代码为:
代码参考:
Properties pro = new Properties();//获取src路径下的文件的方式--->ClassLoader 类加载器ClassLoader classLoader = JDBCUtils.class.getClassLoader();File directory = new File("");String courseFile1 = directory.getCanonicalPath();String courseFile2 = courseFile1 + "\\src\\jdbc.properties";System.out.println(courseFile2);pro.load(new FileReader(courseFile2));
仅供初学者参考,因为项目中给的demo无法运行,所以修改了些。但是在实际项目中这么写,还是有待商榷的。配置服务器的时候乱码,等我我学到了再说。。。
2023.6.16补充:
我看使用InputStream也可以获取,方法更简单。
Properties pro = new Properties();InputStream is = JDBCUtils.class.getClassLoader().getResourceAsStream("jdbc.properties");pro.load(is);url = pro.getProperty("url");user = pro.getProperty("user");
。。。。
备注:我想和学后台和会后台的交个朋友,有想加我的初学者私聊我哈。
参考阅读;