Java 如何獲取url地址文件流
獲取url地址文件流
/**
* 根據(jù)url下載文件流
* @param urlStr
* @return
*/
public static InputStream getInputStreamFromUrl(String urlStr) {
InputStream inputStream=null;
try {
//url解碼
URL url = new URL(java.net.URLDecoder.decode(urlStr, "UTF-8"));
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
//設(shè)置超時(shí)間為3秒
conn.setConnectTimeout(3 * 1000);
//防止屏蔽程序抓取而返回403錯(cuò)誤
conn.setRequestProperty("User-Agent", "Mozilla/4.0 (compatible; MSIE 5.0; Windows NT; DigExt)");
//得到輸入流
inputStream = conn.getInputStream();
} catch (IOException e) {
}
return inputStream;
}根據(jù)url獲取文件的二進(jìn)制
當(dāng)需要獲取url的文件,又不想下載文件的時(shí)候,可以用這個(gè)工具類。
方便快捷,使用HttpURLConnection,先根據(jù)URL獲取文件流,然后把獲取的二進(jìn)制流存儲(chǔ)進(jìn)去數(shù)據(jù)庫(kù)即可,到時(shí)候拿出來(lái)直接下載、打開(kāi)也是OK的。
上代碼
package jd_test;
import java.io.BufferedReader;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.Base64;
import java.util.Random;
import java.util.stream.Stream;
public class UrlResource {
private static Base64.Decoder decoder = Base64.getDecoder();
private static Base64.Encoder encoder = Base64.getEncoder();
public static void main(String[] args){
try {
//System.out.println(UrlResource.getUrlDetail("http://www.baidu.com",true));
//saveUrlFile("你的文檔的路徑.gif", "D:\\1.gif");
System.out.println(encoder.encode(getUrlFileData("http://www.你的文檔的路徑")));
// System.out.println(getUrlFileData("http://www.你的文檔的路徑"));
// saveUrlFile("http://www.你的文檔的路徑", "D:\\1.pdf");
// System.out.println(UrlResource.getUrlDetail("http://www.你的文檔的路徑",true));
//確定寫(xiě)出文件的位置
File file = new File("D:\\1.pdf");
//建立輸出字節(jié)流
FileOutputStream fos = new FileOutputStream(file);
//fos.write(decoder.decode(encoder.encode(getUrlFileData("http://www.你的文檔的路徑"))));
//fos.write(encoder.encode(getUrlFileData("http://www.你的文檔的路徑")));
fos.write(getUrlFileData("http://www.你的文檔的路徑"));
//用FileOutputStream 的write方法寫(xiě)入字節(jié)數(shù)組
//fos.write(getUrlFileData("http://www.你的文檔的路徑"));
System.out.println("寫(xiě)入成功");
//為了節(jié)省IO流的開(kāi)銷,需要關(guān)閉
fos.close();
} catch (Exception e) {
e.printStackTrace();
}
}
//獲取網(wǎng)絡(luò)文件,轉(zhuǎn)存到fileDes中,fileDes需要帶文件后綴名
public static void saveUrlFile(String fileUrl,String fileDes) throws Exception
{
File toFile = new File(fileDes);
if (toFile.exists())
{
// throw new Exception("file exist");
return;
}
toFile.createNewFile();
FileOutputStream outImgStream = new FileOutputStream(toFile);
System.out.println(getUrlFileData(fileUrl));
outImgStream.write(getUrlFileData(fileUrl));
outImgStream.close();
}
public static byte[] getBase64UrlFileData(String fileUrl)
{
try {
//發(fā)票PDF文件二進(jìn)制流base64,如果是get請(qǐng)求還需要進(jìn)行UrlEncode,使用sdk除外。
return encoder.encode(getUrlFileData(new String(decoder.decode(fileUrl))));
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
//獲取鏈接地址文件的byte數(shù)據(jù)
public static byte[] getUrlFileData(String fileUrl) throws Exception
{
URL url = new URL(fileUrl);
HttpURLConnection httpConn = (HttpURLConnection) url.openConnection();
httpConn.connect();
InputStream cin = httpConn.getInputStream();
ByteArrayOutputStream outStream = new ByteArrayOutputStream();
byte[] buffer = new byte[1024];
int len = 0;
while ((len = cin.read(buffer)) != -1) {
outStream.write(buffer, 0, len);
}
cin.close();
byte[] fileData = outStream.toByteArray();
outStream.close();
return fileData;
}
//獲取鏈接地址的字符數(shù)據(jù),wichSep是否換行標(biāo)記
public static String getUrlDetail(String urlStr,boolean withSep) throws Exception
{
URL url = new URL(urlStr);
HttpURLConnection httpConn = (HttpURLConnection)url.openConnection();
httpConn.connect();
InputStream cin = httpConn.getInputStream();
BufferedReader reader = new BufferedReader(new InputStreamReader(cin,"UTF-8"));
StringBuffer sb = new StringBuffer();
String rl = null;
while((rl = reader.readLine()) != null)
{
if (withSep)
{
sb.append(rl).append(System.getProperty("line.separator"));
}
//如果是要直接顯示到頁(yè)面中,可以講獲得的byte數(shù)據(jù)進(jìn)行base64加密,加上文件頭,直接設(shè)置到img的src里面就可以了
else
{
sb.append(rl);
}
}
return sb.toString();
}
}以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SPRING FRAMEWORK BEAN作用域和生命周期原理解析
這篇文章主要介紹了SPRING FRAMEWORK BEAN作用域和生命周期原理解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01
Java中BigDecimal除法使用不當(dāng)導(dǎo)致精度問(wèn)題
本文主要介紹了Java中BigDecimal除法使用不當(dāng)導(dǎo)致精度問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
利用java+mysql遞歸實(shí)現(xiàn)拼接樹(shù)形JSON列表的方法示例
這篇文章主要給大家介紹了關(guān)于利用java+mysql遞歸實(shí)現(xiàn)拼接樹(shù)形JSON列表的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來(lái)一起看看吧。2017-08-08
Kafka常用命令之kafka-console-consumer.sh解讀
這篇文章主要介紹了Kafka常用命令之kafka-console-consumer.sh解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
Java中if語(yǔ)句return用法和有無(wú)括號(hào)的區(qū)別
本文主要介紹了Java中if語(yǔ)句return用法和有無(wú)括號(hào)的區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-12-12
Spring bean對(duì)象實(shí)例化實(shí)現(xiàn)過(guò)程圖解
這篇文章主要介紹了Spring bean對(duì)象實(shí)例化實(shí)現(xiàn)過(guò)程圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07

