byte[] bytes = new byte[uploader.UploadedFiles[0].InputStream.Length];
uploader.UploadedFiles[0].InputStream.Read(bytes, 0, bytes.Length);

var storedFile = new document();
string strFullPath = uploader.UploadedFiles[0].FileName;
string strFileName = Path.GetFileName(strFullPath);

storedFile.document_id = Guid.NewGuid();
storedFile.content_type = uploader.UploadedFiles[0].ContentType;
storedFile.original_name = strFileName;
storedFile.file_data = bytes;
storedFile.date_created = DateTime.Now;
db.documents.InsertOnSubmit(storedFile);
db.SubmitChanges();


如果:

一次调用Read从流中读取是非常危险的。您假设所有数据都将立即可用,但情况并非总是如此。您应该始终循环读取,直到没有更多数据为止。

我应该如何更改上面的代码以使其“不太危险”?

最佳答案

乔恩·斯基特(Jon Skeet)实际上有一篇非常不错的博客文章,介绍了人们尝试阅读Streams的所有不同方式,以及每个人为何被打破(以他认为是理想的解决方案结尾):

Reading binary data in C#

关于c# - 如何安全地从asp.net的流中读取?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/4155844/

10-09 00:53