欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java如何通過(guò)流讀取圖片做base64編碼

 更新時(shí)間:2023年11月18日 11:15:49   作者:luffy5459  
這篇文章主要介紹了java如何通過(guò)流讀取圖片做base64編碼問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

通過(guò)流讀取圖片做base64編碼

在web頁(yè)面上,顯示圖片,一般是給出圖片地址,然后以u(píng)rl的方式顯示,但是有一些特殊情況,如果我們的圖片保存在ftp服務(wù)器上,不能外部輕易訪問(wèn),但是可以通過(guò)用戶名密碼的方式登錄ftp服務(wù)器,然后下載圖片,但是這種方式需要將圖片另存一份,然后以路徑或者url的方式返回給前端頁(yè)面展示,有一種方式,讀取圖片流數(shù)據(jù),然后將二進(jìn)制數(shù)據(jù)做base64編碼,最后交給頁(yè)面顯示。

<img src="data:image/png;base64,xxxxxxxxxxxxxxxxxxxxxxx"/>

就可以顯示圖片了,目前很多地方都使用這種方式展示圖片。

案例

下面是一個(gè)java讀取圖片流數(shù)據(jù),并通過(guò)base64編碼工具編碼的代碼:

package com.xxx.test;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import sun.misc.BASE64Encoder;
public class ReadImageInputStreamDemo {
	public static void main(String[] args) {
		InputStream inputStream = null; 
		ByteArrayOutputStream outputStream = null;
		try {
			String fileName = "/Users/buejee/Downloads/電路.jpeg";
			String mediaType = fileName.substring(fileName.lastIndexOf(".")+1);
			File imageFile= new File(fileName);
			boolean exists = imageFile.exists();
			if(exists) {
				inputStream = new FileInputStream(fileName);
				outputStream = new ByteArrayOutputStream();
				int len;
				byte[] buf = new byte[1024];
				while((len = inputStream.read(buf))!=-1) {
					outputStream.write(buf, 0, len);
				}
				outputStream.flush();
				byte[] data = outputStream.toByteArray();
				BASE64Encoder encoder = new BASE64Encoder();
				String encodeStr = encoder.encode(data);
				encodeStr = "data:image/"+mediaType+";base64,"+encodeStr;
				System.out.println(encodeStr);
			}
		} catch (Exception e) {
			e.printStackTrace();
		}finally {
			try {
				if(inputStream!=null) {
					inputStream.close();
				}
				if(outputStream!=null) {
					outputStream.close();
				}
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
	}
}

運(yùn)行代碼,可以看到打印信息:

這個(gè)圖片原圖是這樣的:

 

生成的base64編碼經(jīng)過(guò)加工,添加data:image/jpeg;base64,然后就可以放到img標(biāo)簽上作為圖片顯示了。

做一個(gè)簡(jiǎn)單的html頁(yè)面,內(nèi)容如下:

最后,通過(guò)瀏覽器打開(kāi)這個(gè)網(wǎng)頁(yè):

這樣生成的圖片base64字符串會(huì)很長(zhǎng),在拷貝的時(shí)候可能會(huì)因?yàn)榭崭駟?wèn)題導(dǎo)致最終顯示失敗。 

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論