您的位置:首页 > 编程语言 > ASP

asp.net input上传文件的几种方式

2010-02-01 02:35 656 查看
当客户端向服务器上传文件的时候,我们有时候是希望点击一个 button 或是 a 标签的时候,选择文件的对话框将自动弹出,

<input type="file" id="file" style="display:none"><br />
<input type="button" value="click" onClick="ok()"><br />

javascript ok方法:

function ok()
{
var s = document.getElementById("file");
s.style.display = "block";
s.click = true;
var str = s.value;
alert(str);
}

上面 str 便是客户端选择上传文件的路径,

但是,在asp.net的中使用

<input type='file' />

控件上传文件对文件的大小有限制,默认情况下大概在4m左右,如果上传再大的文件时就会出页面无法显示的错误.

修改web.config文件中的参数可以设置该控件上传文件的大小,web.config中配置如下:在<system.web>节点下增加

<httpRuntime maxRequestLength="409600"/>

可以来设置

<input type='file' />

控件上传文件的大小,maxRequestLength以字节位单位

第一种上传方式:(纯HTML上传或是异文件上传)

页面文件:
<form id="form1" method="post" enctype="multipart/form-data" action="Details.aspx">
<input id="testId" type="file" name="testName"/>
<input id="testSubmit" type="submit" value="上传" />
</form>

后台代码:
protected void Page_Load(object sender, EventArgs e)
{
/* Files will be upload when postback */
if (!IsPostBack)
{
if (this.Request.Files.Count > 0)
{
HttpPostedFile f = this.Request.Files[0];
string fname = f.FileName;
/* startIndex */
int index = fname.LastIndexOf("\\") + 1;
/* length */
int len = fname.Length - index;
fname = fname.Substring(index, len);
/* save to server */
f.SaveAs(this.Server.MapPath("~/Files/" + fname));
Response.Write("<script type='text/javascript'>alert('Success!');</script>");
}
}
}

第二种方式:(runat="server")

页面文件:
<input type="file" runat="server" id="testFile"/>
<input type="submit" id="testSubmit" value="上传" />
<br />

后台代码:
if (!IsPostBack)
{
/* input upload file */
if (Request.Files.Count > 0)
{
HttpPostedFile f = Request.Files[0];
string fname = f.FileName;
int index = fname.LastIndexOf("\\");
int len = fname.Length - index - 1;
fname = fname.Substring(index + 1, len);
f.SaveAs(this.Server.MapPath("~/Files/" + fname));
Response.Write("<script type='text/javascript'>alert('Success!');</script>");
}
}

两种方式中<from> 和 <input> 请注意有点不同。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: