在Java中对字符串进行base64的编码和解码很简单,有自带的util;
//字符串编码
final java.util.Base64.Encoder encoder = java.util.Base64.getEncoder(); final String text = "字符串"; final String encodedText = encoder.encodeToString(text.getBytes());// System.out.println(encodedText);
//解码
final java.util.Base64.Decoder decoder = java.util.Base64.getDecoder(); System.out.println(new String(decoder.decode(encodedText)));
//HSSFWorkbook编码
//参数workbook是已经写好的excel文件
按照字符串的写法,依葫芦画瓢可以得出:
Base64.Encoder encoder = Base64.getEncoder(); encodedText = encoder.encodeToString(workbook.getBytes());//
而且这样写是没有报错的,尝试解码一下,生成的excel文件无法正常打开;
所以需要寻找一下另外的方法——把整个excel文件转成byte[];
Base64.Encoder encoder = Base64.getEncoder(); ByteArrayOutputStream baos = new ByteArrayOutputStream(); workbook.write(baos); byte[] bytes = baos.toByteArray(); encodedText = encoder.encodeToString(bytes);
//解码
String pathReal = request.getServletContext().getRealPath("/")+"base.xls"; Files.write(Paths.get(pathReal), Base64.getDecoder().decode(encodedText),StandardOpenOption.CREATE);
生成的excel文件能被正常打开。