.Net MVC4 使用心得(一)使用uploadify和wcf存储服务时的文件上传问题

2024-01-30 00:48

本文主要是介绍.Net MVC4 使用心得(一)使用uploadify和wcf存储服务时的文件上传问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        最近在研究MVC4,将一些研究心得写出来。文章不是教程,所以就不从理论开始描述了,重点针对开发中遇到的一些实际问题。

        之前遇到的问题,有空再补,先记录下今天遇到的问题。

        由于需要上传较大的文件,使用了uploadify上传组件3.2。3.2有多么坑爹暂时不说了,今天遇到的问题是,上传文件如果小于20M没有任何问题,大于20M就会报500错误(服务器程序错误)。使用本地调试,上传50M的文件,发现uploadify卡死,后台接收也没有代码也没有执行。

        经过分析,这个问题涉及两个问题,分区间展现出来,小于20M的文件上传,没有问题;大于20M小于30M的文件上传,可以执行到后台代码,但是后台调用了WCF的文件存储服务(WCF Client有多坑,暂时也不说了),在调用时出现未找到终结点错误(404错误,小于20M则正常);而对于大于30M的文件,本地调试也无法执行后台代码,但是,放到服务器上却没有30M以上不能传的现象。

        先解决本机不接收uploadify数据问题,考虑到是应该是请求长度限制。首先检查IIS Express配置,VS2012使用iis express作为默认的调试环境,配置文件翻看良久,未发现关于请求长度的设置。检查MVC的web.config,发现httpRuntime节已经设置了maxRequestLength:

<httpRuntime targetFramework="4.5" maxRequestLength="2097151"/>

       继续分析,可能是安全问题,查阅资料,发现<system.webServer>节下可以添加如下设置:

<requestFiltering><requestLimits maxAllowedContentLength="1073741824"></requestLimits>
</requestFiltering>
      调试,问题解决,可以上传大于50M的数据了。需要注意的是maxRequestLength单位是KB,而maxAllowedContentLength但是是字节。

      接下来解决WCF服务调用时的问题,该WCF服务是通过wsHttpBinding的,考虑也是设置问题,查看config文件,发现maxRequestLength合理设置过,尝试修改binding配置,将

maxBufferPoolSize,maxReceivedMessageSize等属性设置好,同时配置timeout,并且配置readerQuotas节的bytes限制。回来调试,好了,接收没有问题了,新的问题又来了,出现了IO错误,报未找到存储路径。返回错误信息含路径名,却没有文件名,分析可能是文件名没有传递成功。查看wcf消息传递参数,包含一个bool的是否自定义文件,和string的文件名字段。通过调试发现,client调用传递bool类型为true,但是在wcf服务端收到的确是false。纠结了一会儿,发现wcf的client会针对数据协定中的每个bool或者enum变量,生成一个名为 变量名+specified的bool型变量。查阅资料,发现这货是决定Soap中是否传递相应参数的,if为false,则无论怎样的设置都不会起作用,始终传递的都是默认值。OK,把他们统统设置成true。很好,问题解决了。

       测试发现,效率什么的实在不敢恭维,因为通过soap传递数据,消息过于庞大,而mvc应用和存储服务其实是在同一台服务器。if换成Pipe绑定会不会好点。时间有限,不能过多探究,本身开辟两块临时内存来存放数据就已经很疼了,更何况还要进行数据传递。考虑再三,还是改为mvc里controller直接写盘。

这篇关于.Net MVC4 使用心得(一)使用uploadify和wcf存储服务时的文件上传问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/658634

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

IDEA和GIT关于文件中LF和CRLF问题及解决

《IDEA和GIT关于文件中LF和CRLF问题及解决》文章总结:因IDEA默认使用CRLF换行符导致Shell脚本在Linux运行报错,需在编辑器和Git中统一为LF,通过调整Git的core.aut... 目录问题描述问题思考解决过程总结问题描述项目软件安装shell脚本上git仓库管理,但拉取后,上l

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三