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

当客户端向服务器上传文件的时候,我们有时候是希望点击一个 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> 请注意有点不同。

posted @ 2010-02-01 02:35  XueM  Views(7216)  Comments(1Edit  收藏  举报