获取一个临时文件和对中文文件名字进行编码的工具类
Posted qlqwjy
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了获取一个临时文件和对中文文件名字进行编码的工具类相关的知识,希望对你有一定的参考价值。
首先我们明白,一个文件可以命名为任何名称,比如一个excel,我们可以命名为不带后缀,然后向里面写入对应的内容,只是在导出的时候将文件命名为正确的名字即可。
一个在当前用户的默认临时文件夹中生成一个当前日期的文件夹,然后再里面写入一个用UUID生成名字的文件,常用于JavaEE中文件下载的时候先生成一个临时文件,然后向此文件中写入数据之后打开输入流提供下载。
获取一个临时文件,用于输入内容后打开inputstream提供下载
依赖Slf4j日志和commons-io包
public static File getTmpFile() { // 获取到当前系统的临时工作目录 String tempDirectoryPath = FileUtils.getTempDirectoryPath(); String date = DateFormatUtils.format(new Date(), "yyyy-MM-dd"); String tmpFileDir = tempDirectoryPath + date; FileUtils.deleteQuietly(new File(tmpFileDir)); // 创建目录(以日期格式命名) File file2 = new File(tmpFileDir); file2.mkdir(); // 创建临时文件,UUID产生名称 String fileName = UUIDUtil.getUUID2(); String tmpFileName = (tmpFileDir + "/" + fileName).replace("\\", "/"); File file = new File(tmpFileName); try { file.createNewFile(); } catch (IOException e) { log.error("getTmpFile error", e); } log.info("gene tempFile -> {}", file.getAbsolutePath()); return file; }
结果:
在文件下载的时候对中文文件名进行编码:
public String getFileName() { String name = "安全帽台账" + DateFormatUtils.format(new Date(), "yyyy-MM-dd") + ".xls"; try { name = new String(name.getBytes("UTF-8"), "ISO8859-1"); } catch (UnsupportedEncodingException e) { log.error("getFileName error", e); return DateFormatUtils.format(new Date(), "yyyy-MM-dd") + ".xls"; } return name; }
以上是关于获取一个临时文件和对中文文件名字进行编码的工具类的主要内容,如果未能解决你的问题,请参考以下文章