java圖片轉base64和真實的結果不一樣
問題描述
先上代碼
String imgURL = 'http://www.g3zj.net:8082/util.action?method=appauthimg&d_=99';byte[] data = null;try { // 創建URL URL url = new URL(imgURL); // 創建鏈接 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();}// 對字節數組Base64編碼BASE64Encoder encoder = new BASE64Encoder();str=encoder.encode(data);
就是從一個網絡讀取圖片并轉成base64.發現轉出來的結果無法用于img標簽顯示(已加了data:image/jpeg;base64,前綴)。后來直接百度找了一個在線生成base64的網站,把這個圖片url放上去轉換,結果發現別人在線轉換出來的base64比我java代碼轉換的base64還長了很多。
為什么會這樣呢?
問題解答
回答1:InputStream 的 available() 返回的值是該InputStream 在不被阻塞的情況下,一次可以讀取到的數據長度。但網絡情況總是不定的,經常阻塞。所以建議使用循環讀取 InputStream 中的數據。
回答2:讀取整個InputStream時,用Streams.copy()比穩妥,例如題主這個例子中,可以是:
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 { // 創建URL URL url = new URL(imgURL); byte[] by = new byte[1024]; // 創建鏈接 HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setRequestMethod('GET'); conn.setConnectTimeout(5 * 1000); InputStream is = conn.getInputStream(); // 將內容讀取內存中 int len = -1; while ((len = is.read(by)) != -1) {data.write(by, 0, len); } // 關閉流 is.close();} catch (IOException e) { e.printStackTrace();}// 對字節數組Base64編碼BASE64Encoder encoder = new BASE64Encoder();System.out.println('data:image/jpg;base64,'+encoder.encode(data.toByteArray()));
然而樓主的代碼是可以用的,在我這里,只要加上data:image/jpg;base64,就好了
相關文章:
1. 哭遼 求大佬解答 控制器的join方法怎么轉模型方法2. sql語句 - 如何在mysql中批量添加用戶?3. mysql - 數據庫表中,兩個表互為外鍵參考如何解決4. mysql - 表名稱前綴到底有啥用?5. 編輯成功不顯示彈窗6. 怎么php怎么通過數組顯示sql查詢結果呢,查詢結果有多條,如圖。7. mysql - 怎么生成這個sql表?8. mysql儲存json錯誤9. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?10. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?
