文件上传之--内存溢出(System.OutOfMemoryException)

本文介绍了在处理大文件上传时遇到的System.OutOfMemoryException异常,问题出现在将大文件流转换为byte数组。解决方案是通过循环读取文件流,每次读取固定长度并存入数组,避免一次性加载到内存中。示例代码包括后台和服务端的实现,旨在帮助遇到类似问题的开发者。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

两周前就想把这点经验记录下来了,由于拖延症上身,直到刚才突然想起这件未完成的任务,今天是1024,在这个特别的日子里,祝所有程序猿兄弟姐妹们节日快乐!

上传功能一直很正常,直到上传了个500多兆的文件,报错提示:

“System.OutOfMemoryException”类型的异常在 mscorlib.dll 中发生,但未在用户代码中进行处理

对于内部用途和新的托管对象,确保要有足够的内存可供分配。
如果要创建数组,请确保大小正确。

由于调用的webservice中的文件上传方法参数为二进制格式,需要把文件流转换为byte格式,所以直接写了byte[] byte = new byte[stream.Length],结果那个大文件就是在这句卡住了,一开始也很蒙圈,已经在配置文件中修改了最大请求的长度为何还会有问题,调试代码发现new byte[]的时候括号内要求参数是一个8位的整数,那个500多兆的文件转为字节后是个9位数,导致byte类型超出索引,于是想到每次实例化一个固定长度的byte,让文件循环写入,写满一个byte就放入数组,然后在服务端在解析这个数组即可,这样就不会存在内存溢出的问题了,下面是示例代码,仅供参考,若要带走,欢迎转发。

脚本部分在上一篇中有代码展示,这里只展示后台和服务端代码了。

1.一般处理程序部分:

public void FileUpload(HttpContext context)
    {
        WebService ws = new WebService();
        ws.Timeout = 3600000; //单位毫秒,1小时

        HttpFileCollection files = context.Request.Files;
        if (files.Count > 0)
        {
            /*获取真实文件名,files[0].FileName这种方法在IE浏览器中上传会带有F://路径*/
            string filename = System.IO.Path.GetFileName(files[0].FileName);
            HttpPostedFile file = files[0];
            Stream fs = file.InputStream;

            /*定义object数组,用来存放byte数据*/
            object[] obj = new object[] { };
            List<object> list = new List<object>();
            int offcount = 1048576; /*<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值