java圖片轉base64和真實的結果不一樣
問題描述
先上代碼
String imgURL = 'http://www.g3zj.net:8082/util.action?method=appauthimg&d_=99';byte[] data = null;try { // 創(chuàng)建URL URL url = new URL(imgURL); // 創(chuàng)建鏈接 HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setRequestMethod('GET'); conn.setConnectTimeout(5 * 1000); InputStream inStream = conn.getInputStream(); data = new byte[inStream.available()]; inStream.read(data); inStream.close();} catch (IOException e) { e.printStackTrace();}// 對字節(jié)數(shù)組Base64編碼BASE64Encoder encoder = new BASE64Encoder();str=encoder.encode(data);
就是從一個網(wǎng)絡讀取圖片并轉成base64.發(fā)現(xiàn)轉出來的結果無法用于img標簽顯示(已加了data:image/jpeg;base64,前綴)。后來直接百度找了一個在線生成base64的網(wǎng)站,把這個圖片url放上去轉換,結果發(fā)現(xiàn)別人在線轉換出來的base64比我java代碼轉換的base64還長了很多。
為什么會這樣呢?
問題解答
回答1:InputStream 的 available() 返回的值是該InputStream 在不被阻塞的情況下,一次可以讀取到的數(shù)據(jù)長度。但網(wǎng)絡情況總是不定的,經(jīng)常阻塞。所以建議使用循環(huán)讀取 InputStream 中的數(shù)據(jù)。
回答2:讀取整個InputStream時,用Streams.copy()比穩(wěn)妥,例如題主這個例子中,可以是:
ByteArrayOutputStream baos = new ByteArrayOutputStream();Streams.copy(conn.getInputStream(), baos);String str = new BASE64Encoder(baos.toByteArray());回答3:
String imgURL = 'http://www.g3zj.net:8082/util.action?method=appauthimg&d_=99';ByteArrayOutputStream data = new ByteArrayOutputStream();try { // 創(chuàng)建URL URL url = new URL(imgURL); byte[] by = new byte[1024]; // 創(chuàng)建鏈接 HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setRequestMethod('GET'); conn.setConnectTimeout(5 * 1000); InputStream is = conn.getInputStream(); // 將內(nèi)容讀取內(nèi)存中 int len = -1; while ((len = is.read(by)) != -1) {data.write(by, 0, len); } // 關閉流 is.close();} catch (IOException e) { e.printStackTrace();}// 對字節(jié)數(shù)組Base64編碼BASE64Encoder encoder = new BASE64Encoder();System.out.println('data:image/jpg;base64,'+encoder.encode(data.toByteArray()));
然而樓主的代碼是可以用的,在我這里,只要加上data:image/jpg;base64,就好了
相關文章:
1. 點擊頁面就自動輸入到mysql.求解2. javascript - 在云服務器上啟動個node服務,在本機通過公網(wǎng)ip卻不能訪問3. javascript - angular-ui-bootstrap model 模態(tài)框出現(xiàn)的位置怎么調(diào)整4. javascript - vue 數(shù)據(jù)更新了。但是dom沒有更新,,,,,如圖5. javascript - iframe 為什么加載網(wǎng)頁的時候滾動條這樣顯示?6. css - PC端不同分辨率下字體大小呈現(xiàn)7. css - 百分比min-height的一個問題8. javascript - weex 怎么監(jiān)聽滾動到某處,然后添加fixed固定效果9. valign=top 是啥意思10. javascript - 判斷用戶網(wǎng)絡環(huán)境
