加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

base圖片保存到sqlserver,讀取出來不一樣的問題

发布时间:2020-12-12 13:36:24 所属栏目:MsSql教程 来源:网络整理
导读:把 data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABAMAAAJBCAYAAAAz/nxzAAAgAElEQVR4nOy9WYwkS3ffd+/9vvt9JE2KiyhaAk3ZkGmKsGXTkgzBEC1YBi0DJgRKEAwK9ItAiA8G........QAQRAEQRAEQRAEQegz/j/448aEK/0qmQAAAABJRU5ErkJggg== 這樣的base64String圖片 使用byte


把 data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABAMAAAJBCAYAAAAz/nxzAAAgAElEQVR4nOy9WYwkS3ffd+/9vvt9JE2KiyhaAk3ZkGmKsGXTkgzBEC1YBi0DJgRKEAwK9ItAiA8G........QAQRAEQRAEQRAEQegz/j/448aEK/0qmQAAAABJRU5ErkJggg== 這樣的base64String圖片


使用byte[] b = org.ajax4jsf.util.base64.Base64.decodeBase64((signedBase64CustomerDisk).getBytes("UTF-8"));存儲到sqlserver的image type的欄位,


讀取的時候?byte[] b = org.apache.commons.codec.binary.Base64.encodeBase64(imageBinary);

打印 : System.out.println("get form db :"+new String(org.ajax4jsf.util.base64.Base64.encodeBase64(imageBinary),"UTF-8"));

發現這段字串末尾部分變成了 data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABAMAAAJBCAYAAAAz/nxzAAAgAElEQVR4nOy9WYwkS3ffd+/9vvt9JE2KiyhaAk3ZkGmKsGXTkgzBEC1YBi0DJgRKEAwK9ItAiA8G........QAQRAEQRAEQRAEQegz/j/448aEK/0qmQAAAABJRU5ErkJgAAA=?


百思不得其解

后在存儲的時候

public byte[] imageDataToByte(String imageData) throws IOException {
		
	? ? byte[] imgByteArray = org.ajax4jsf.util.base64.Base64.decodeBase64(imageData.getBytes());
	? ? InputStream in = new ByteArrayInputStream(imgByteArray);
		
	    ByteArrayOutputStream bytestream = new ByteArrayOutputStream();
	    int ch;
	    while ((ch = in.read()) != -1)
	    {
	       bytestream.write(ch);
	    }
	    byte imgdata[]=bytestream.toByteArray();
	    bytestream.close();
	    return imgdata;
}

使用改方法把base64的String進行轉換為byte后問題解決~~

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读