在日常开发中,偶尔遇到需要将现在外网或是使用域名地址访问的文件,重新进行保存,这时就会使用该方法,将外部文件、通过地址访问的文件,转为文件流再进行保存,本文只提供转文件流,至于文件流转化为具体的文件,需要各位开发同仁自行查找相关代码。附上代码:
var fileurl = "http://www.image.com/12456.pdf" ; //需要进行转文件流的文件路径
Stream stream = null; //最后得到的文件流
try
{
System.Net.WebRequest req11 = System.Net.WebRequest.Create(fileurl);
req11.Method = "GET";
byte[] fileBytes;
using (WebResponse webRes = req11.GetResponse())
{
int length = (int)webRes.ContentLength;
HttpWebResponse response1 = webRes as HttpWebResponse;
Stream resstream = response1.GetResponseStream(); //这里得到的文件留是只读不可编辑的,可能会对后续操作有影响,所以下方重新转换了一下
//读取到内存
MemoryStream stmMemory = new MemoryStream();
byte[] buffer = new byte[length];
int i;
//将字节逐个放入到Byte中
while ((i = resstream.Read(buffer, 0, buffer.Length)) > 0)
{
stmMemory.Write(buffer, 0, i);
}
fileBytes = stmMemory.ToArray();//文件流Byte,需要文件流可直接return,不需要下面的保存代码
}
stream = new MemoryStream(fileBytes);
}
catch (Exception e)
{
//转换错误日志
}
以上就是具体的操作方式,希望对大家有用。