前言
basic编码是标准的base64编码,用于处理常规的需求:输出的内容不添加换行符,而且输出的内容由字母加数字组成。
最近做了个web模版,其中想用base64背景图。虽然网络上有现成的编码器,但总想自己实现一个。可能很多人不知道,jdk 8新提供的base64类可以非常方便地处理此项任务:。
一、先选一张图片
mm.png
二、建立html演示文件模版
test.html
<!doctype html> <html> <head lang="zh-cn"> <meta charset="utf-8"> <meta http-equiv="x-ua-compatible" content="ie=edge"> <meta name="viewport" content="width=device-width"> <title>测试base64编码 - 2gua</title> <style type="text/css"> #thisimage { margin: 20px auto; -webkit-border-radius: 50%; border-radius: 50%; background: url() no-repeat center center; background-size: contain; border: 8px solid #ededed; width: 128px; height: 128px; } </style> </head> <body> <div id="thisimage"></div> </body> </html>
注意url()
为空,稍后我们要把生成的base64编码字符串植入其中。
三、编写java程序
这里将实现base64编解码的双向实现,尽管本例中只需要用到base64解码。java程序的注释很清楚了,直接上代码:
`base64trans.java` package com.gua; /** * created by 2gua on 2014/10/5. */ import java.io.ioexception; import java.nio.file.*; import java.util.base64; import static java.lang.system.out; public class base64trans { /** * 从图片文件中读取内容。 * @param path 图片文件的路径。 * @return 二进制图片内容的byte数组。 * */ private byte[] readfile(path path) { byte[] imagecontents = null; try { imagecontents = files.readallbytes(path); } catch (ioexception e) { out.println("读取文件出错了...~zz"); } return imagecontents; } /** * 编码图片文件,编码内容输出为{@code string}格式。 * @param imagecontents 二进制图片内容的byte数组。 * @return {@code string}格式的编码内容。 */ private string base64encoding(byte[] imagecontents) { if(imagecontents != null) return base64.getencoder().encodetostring(imagecontents); else return null; } /** * 解码图片文件。 * @param imagecontents 待解码的图片文件的字符串格式。 * @return 解码后图片文件的二进制内容。 */ private byte[] base64decoding(string imagecontents) { if(imagecontents != null) return base64.getdecoder().decode(imagecontents); else return null; } /** * 将解码后的二进制内容写入文件中。 * @param path 写入的路径。 * @param imagecontents 解码后的二进制内容。 */ private void writefile(path path, byte[] imagecontents) { if(imagecontents != null) try { files.write(path, imagecontents, standardopenoption.create); } catch (ioexception e) { out.println("写入文件出错了...~zz"); } } public static void main(string[] args) { base64trans bt = new base64trans(); string encodingstring = bt.base64encoding(bt.readfile(paths.get("d:/temp/mm.png"))); out.println("二进制图片文件base64码:" + encodingstring); bt.writefile(paths.get("d:/temp/mm2.png"), bt.base64decoding(encodingstring)); out.println("任务结束..."); } }
程序结果如下:
二进制图片文件base64码:ivborw0kggoaaaansuheugaaaiaaaacacayaaaddpmhlaaaabgdbtueaalgpc/xhbqaaacb ...(此处省略n多字符) 8xntiwl2vhc3lpy29ulmnul2vhc3lpy29ulmnul2nkbi1pbwcuzwfzewljb24uy24vcg5nlzewodcwlzewodcwodyucg5nplffdwaaaabjru5erkjggg== 任务结束...
四、最后设置
要在html文件模版test.html中引用base64编码内容,还有一步工作要做:将以下内容加到base64编码内容的开头处:data:image/png;base64,
最终结果也就是类似这样:
data:image/png;base64,ivborw0kggoaaaansuheugaaaiaaaacacayaaaddpmhlaaaabgdbtueaalgpc/xhbqaaacb ...(此处省略n多字符) 8xntiwl2vhc3lpy29ulmnul2vhc3lpy29ulmnul2nkbi1pbwcuzwfzewljb24uy24vcg5nlzewodcwlzewodcwodyucg5nplffdwaaaabjru5erkjggg==
之后,将这一长串字符串植入以下代码行的url()
括号中:
background: url() no-repeat center center;
如果图片是jpg格式,请将上面data:image/png;base64
中的png改为jpeg,如果是gif格式就改为gif。好了,刷新页面,看看结果:
有圆圈圈是因为我们设置了一些css3特效。
我们还实现了base64解码,并生成一个新的mm2.png图片,在图片浏览器中打开mm2.png,效果应该跟mm.png是一模一样的。
其实,每次jdk新版发布,都蕴藏着许多大大小小的更新,只是你是否有意去发掘它而已。java总是那么健壮和让人放心。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
如对本文有疑问, 点击进行留言回复!!
android sdk源码 andoid-21 下的TextUtils.java文本工具类 源码赏析
地理坐标(WGS84),投影坐标下(Mercator)切片系统的计算Java类
荐 JavaWeb~简单认识以太网、MAC地址、MTU机制、ARP协议、DNS协议
HUAWEI MH5000-31 LGA Module Hardware Guide draft
网友评论