m4c*_*ine 8 asp.net iis file-upload
我有一个内部网应用程序,需要上传(.iso)超过2GB的文件.看来2GB文件大小有很多限制因素.
看来你可以设置另一个文件大小限制,其中maxAllowedContentLength大约为4GB,因为它的类型是uint,但是当我们仍然受到maxRequestLength的2GB限制时会有什么好处呢?
<system.webServer>
<security>
<requestFiltering>
<requestLimits maxAllowedContentLength="4294967295" />
</requestFiltering>
</security>
<system.webServer>
Run Code Online (Sandbox Code Playgroud)
有没有人有任何上传超过2GB限制的文件的解决方案?
您是否愿意接受 JavaScript 解决方案??如果是这种情况,请尝试这个jQuery 插件,它允许您上传大量数据(很多 GB)。如果浏览器不支持提供基于 TCP/IP 发送和接收带有相应 ACK 的包的机制,它会使用 HTML5 FileReader API 功能和 Silverlight 回退来上传文件。文件按配置大小的块上传(默认为 4 MB)。
另外:它还带有文件队列模式。
以下是如何在 Razor 视图中使用它的示例:
$(function () {
var file = $("#file").createUploaderHtml5({
postDataUrl: "@Url.Action("Upload", "Home")",
packetSize: 4 * 1024 * 1024,
onPreparingUpload: function (plugin, ufname, umime, usize) {
plugin.settings.logger("ufname = [" + ufname + "] umime = [" + umime + "] usize = [" + usize + "]");
return true;
},
onInitPacketArrived: function (plugin, guid) {
plugin.settings.logger("guid = [" + guid + "]");
},
onDataPacketArrived: function (plugin, ack, total) {
//plugin.settings.logger("ACK [" + ack.Guid + "] packet = [" + ack.Packet + "] total = [" + total + "]");
var percent = Math.round(ack.Packet / total * 100);
$("#progressbar").attr("value", percent);
$("#percent").html(percent + " %");
},
onFileUploaded: function (pl) {
pl.settings.logger("File finished!!!");
},
logger: function(msg) {
var lg = $("#logger");
lg.html(lg.html() + msg + "<br />");
}
});
$("#start").click(function () {
file.startUpload();
});
$("#stop").click(function () {
file.cancelUpload();
});
});
Run Code Online (Sandbox Code Playgroud)
这是上传操作的代码:
[HttpPost]
public ActionResult Upload(FormCollection collection)
{
var packetSize = 4 * 1024 * 1024; // default to 4 MB
var filePath = Server.MapPath("~/_temp_upload/");
var result = UploadHelper.ProcessRequest(Request, filePath, packetSize);
if (result != null)
{
var metadata = UploadHelper.GetMetadataInfo(filePath, result.Guid);
// do anything with the metadata
}
if (result != null)
return Json(result);
return Content("");
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
8677 次 |
| 最近记录: |