java中更新文件时,指定原文件的编码格式,防止编码格式不对,造成乱码

1.pom中添加引入cpdetector(一个可以自动检测文本编码格式的项目)
   
 //pom中添加引入cpdetector(一个可以自动检测文本编码格式的项目)

  <dependency>
            <groupId>net.sourceforge.cpdetector</groupId>
            <artifactId>cpdetector</artifactId>
            <version>1.0.7</version>
        </dependency>
2.获取文件的编码格式 charset
    public static Charset detectCodepage(String filePath) throws IOException {
        CodepageDetectorProxy detector = CodepageDetectorProxy.getInstance();
        detector.add(UnicodeDetector.getInstance());
        detector.add(ASCIIDetector.getInstance());
        detector.add(JChardetFacade.getInstance());
        File file = new File(filePath);
        Charset charset = detector.detectCodepage(file.toURL());
        logger.info("the {} charset is {}",filePath,charset.displayName());
    }
3.指定更新文件的编码格式
//FileOutputStream中一个参数是文件路径,一个是指是否在文件尾进行追加
BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(filePath,true), charset);
posted @ 2019-05-13 18:33  纵码万水千山  阅读(626)  评论(0编辑  收藏  举报