最近在做项目的时候为了对付NLB,把原来附件保存到Web服务器的方式改成了保存到数据库的方式。
这样改动后,一般的附件上传没有问题,但是有一个做了Hash校验的附件上传页面却很奇怪的在数据库中只保存了大量的0,也就是说附件的内容全是0.查看其代码如下:
if
(IsAllowFile(name))
//
判断文件类型是否允许
![](https://i-blog.csdnimg.cn/blog_migrate/34031c708bfe702fe82d01ff5c6593aa.gif)
{
if (MD5File.Check(files[i].InputStream, key))
![](https://i-blog.csdnimg.cn/blog_migrate/3112b7b6526db5bc83e275260ae60525.gif)
{
string fileName;
int len = files[i].ContentLength;
byte[] content = new byte[len];
files[i].InputStream.Read(content, 0, len);
string guid = AttachmentFile.AddFile(name, files[i].ContentType, content);//保存到数据库
fileName = "../File.aspx?guid=" + guid;
}
else
![](https://i-blog.csdnimg.cn/blog_migrate/3112b7b6526db5bc83e275260ae60525.gif)
{
denyFiles += name + "\\r";
}
}
这个地方就是将一个Stream转换为byte[],然后将byte[]存入数据库中。那么为什么byte[] content会全是0拉?原来是在执行Read()函数之前调用了MD5File.Check函数,而这个函数也是将上传的文件流作为参数传入,在内也执行了Read()函数实现将Stream转换为byte[]。
原因是Stream内部有一个指针Position表示当前操作的位置,当执行了一次Read函数后Position移动到了一定长度的位置,在第二次执行Read函数时候,Stream会根据新的Position继续读取数据,由于第一次读取的时候已经把Position设置到了Stream的终点,所以第二次读取的时候并没有把Stream中的内容读取到byte[]中。
解决办法也比较简单,在Read方法调用之前,加入files[i].InputStream.Position = 0;就可以将Stream中的内容读取到byte[]中了。
这样改动后,一般的附件上传没有问题,但是有一个做了Hash校验的附件上传页面却很奇怪的在数据库中只保存了大量的0,也就是说附件的内容全是0.查看其代码如下:
![](https://i-blog.csdnimg.cn/blog_migrate/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/34031c708bfe702fe82d01ff5c6593aa.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/0be121fa5b8988fbabbbc526af3b0fc0.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/b854634c0904529d4018c4c3336be836.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/3112b7b6526db5bc83e275260ae60525.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/b854634c0904529d4018c4c3336be836.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/eec4c0236afc26744c9c4e910bc34958.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/3112b7b6526db5bc83e275260ae60525.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/b854634c0904529d4018c4c3336be836.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/eec4c0236afc26744c9c4e910bc34958.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/4fd96b3cf02f4c7b5c8964ac8167f7af.gif)
原因是Stream内部有一个指针Position表示当前操作的位置,当执行了一次Read函数后Position移动到了一定长度的位置,在第二次执行Read函数时候,Stream会根据新的Position继续读取数据,由于第一次读取的时候已经把Position设置到了Stream的终点,所以第二次读取的时候并没有把Stream中的内容读取到byte[]中。
解决办法也比较简单,在Read方法调用之前,加入files[i].InputStream.Position = 0;就可以将Stream中的内容读取到byte[]中了。