.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

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

HDFS—存储优化(纠删码)

纠删码原理 HDFS 默认情况下,一个文件有3个副本,这样提高了数据的可靠性,但也带来了2倍的冗余开销。 Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约50%左右的存储空间。 此种方式节约了空间,但是会增加 cpu 的计算。 纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。 默认只开启对 RS-6-3-1024k

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma