ASP.NET图片上传方法总结

本文介绍了两种ASP.NET中的图片上传实现方式:一是使用标准HTML进行图片上传,二是使用ASP.NET内置的FileUpload控件实现单文件上传。文章提供了前后端代码示例,包括如何获取上传文件、设置文件名及保存路径。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1 使用标准HTML来进行图片上传

前台代码:

复制代码
<body> 
    <form id="form1" runat="server"> 
    <div> 
        <table> 
            <tr> 
                <td colspan="2" style="height: 21px" > 
                    使用标准HTML来进行图片上传</td> 
            </tr> 
            <tr> 
                <td style="width: 400px"> 
                    <input id="InputFile" style="width: 399px" type="file" runat="server" /></td> 
                <td style="width: 80px"> 
                    <asp:Button ID="UploadButton" runat="server" Text="上传图片" OnClick="UploadButton_Click" /></td> 
            </tr> 
            <tr> 
                <td colspan="2" > 
                    <asp:Label ID="Lb_Info" runat="server" ForeColor="Red"></asp:Label></td>                 
            </tr> 
        </table>     
    </div> 
    </form> 
</body>
复制代码


后台代码:

 

复制代码
using System; 
using System.Data; 
using System.Configuration; 
using System.Web; 
using System.Web.Security; 
using System.Web.UI; 
using System.Web.UI.WebControls; 
using System.Web.UI.WebControls.WebParts; 
using System.Web.UI.HtmlControls; 

public partial class _Default : System.Web.UI.Page  

    protected void Page_Load(object sender, EventArgs e) 
    { 

    } 
    protected void UploadButton_Click(object sender, EventArgs e) 
    { 
        string uploadName = InputFile.Value;//获取待上传图片的完整路径,包含文件名称 
        //string uploadName = InputFile.PostedFile.FileName; 
        string pictureName = "";//上传后的图片名,以当前时间为文件名称,确保文件名称没有反复 
        if (InputFile.Value != "") 
        { 
            int idx = uploadName.LastIndexOf("."); 
            string suffix = uploadName.Substring(idx);//获得上传的图片的后缀名 
            pictureName = DateTime.Now.Ticks.ToString() + suffix; 
        } 
        try 
        { 
            if (uploadName != "") 
            { 
                string path = Server.MapPath("~/images/"); 
                InputFile.PostedFile.SaveAs(path + pictureName); 
            } 
        } 
        catch (Exception ex) 
        { 
            Response.Write(ex); 
        } 
    } 
}

复制代码


2 单文件上传

        这是最主要的文件上传,在asp.net1.x中没有这个FileUpload控件,唯独html的上传控件,那时候要把html控件转化为server控件,非常不好用。事实上全部文件上传的漂亮效果都是从这个FileUpload控件衍生,第一个样例尽管简单却是根本。

前台代码:

复制代码
<body> 
    <form id="form1" runat="server"> 
    <div> 
        <table style="width: 90%"> 
            <tr> 
                <td style="width: 159px" colspan=2> 
                    <strong><span style="font-size: 10pt">最简单的单文件上传</span></strong></td> 
            </tr> 
            <tr> 
                <td style="width: 600px"> 
                    <asp:FileUpload ID="FileUpload1" runat="server" Width="600px" /></td> 
                <td align=left> 
                    <asp:Button ID="FileUpload_Button" runat="server" Text="上传图片" OnClick="FileUpload_Button_Click" /></td> 
            </tr> 
            <tr> 
                <td colspan=2> 
                    <asp:Label ID="Upload_info" runat="server" ForeColor="Red" Width="767px"></asp:Label></td> 
            </tr> 
        </table>     
    </div> 
    </form> 
</body>
复制代码

后台代码:

复制代码
using System; 
using System.Data; 
using System.Configuration; 
using System.Web; 
using System.Web.Security; 
using System.Web.UI; 
using System.Web.UI.WebControls; 
using System.Web.UI.WebControls.WebParts; 
using System.Web.UI.HtmlControls; 

public partial class _Default : System.Web.UI.Page  

    protected void Page_Load(object sender, EventArgs e) 
    { 

    } 
    protected void FileUpload_Button_Click(object sender, EventArgs e) 
    { 
        try 
        { 
            if (FileUpload1.PostedFile.FileName == "") 
            //if (FileUpload1.FileName == "") 
            //if (!FileUpload1.HasFile)     //获取一个值,该值指示 System.Web.UI.WebControls.FileUpload 控件是否包含文件。包含文件,则为 true;否则为 false。 
            { 
                this.Upload_info.Text = "请选择上传文件!"; 
            } 
            else 
            { 
                string filepath = FileUpload1.PostedFile.FileName;  //得到的是文件的完整路径,包含文件名称,如:C:\Documents and Settings\Administrator\My Documents\My Pictures\20022775_m.jpg 
                //string filepath = FileUpload1.FileName;               //得到上传的文件名称20022775_m.jpg 
                string filename = filepath.Substring(filepath.LastIndexOf("\\") + 1);//20022775_m.jpg 
                string serverpath = Server.MapPath("~/images/") + filename;//取得文件在server上保存的位置C:\Inetpub\wwwroot\WebSite1\images\20022775_m.jpg 
                FileUpload1.PostedFile.SaveAs(serverpath);//将上传的文件另存为 
                this.Upload_info.Text = "上传成功!"; 
            } 
        } 
        catch (Exception ex) 
        { 
            this.Upload_info.Text = "上传发生错误!原因是:" + ex.ToString(); 
        } 
    } 
}

复制代码

转载于:https://www.cnblogs.com/mfryf/archive/2013/06/12/3133113.html

逐个模块给出以下说明: 一个用户只能在同一时间登陆一次,需要经过电脑ip验证,用户名和密码验证,全部通过才可以进入首页。 用户登录:首先进入首页,显示该用户今天上传图片。 1.查看图片:显示该用 户上传的所有图片,显示内容:图像描述,图像大小,是否验证,上传时间,查看,删除 2.上传图片:用户可以上传图片,在上传时有预览的功能,如果数据库中已存在上传过的照片,则提醒用户已上传,否则进入等待验证页面,等待后台验证,若验证成功则显示上传的图像,如果失败则提醒用户是否继续等待验证 3.修改口令:用户可以修改自己的密码 4.退出系统:用户退出当前系统,注销 5.团队简介和客户服务主要是显示团队介绍和联系方式 管理员登陆:进入首页,显示今天上传的所有图片,显示内容:编号,id,图像描述,图像大小,是否验证,上传用户,ip,上传时间,查看,删除 1.查看用户:显示用户名,密码,增加时间,上传几张图片,删除 2.增加用户:包括用户名,密码 3.查找用户:根据输入的用户名进行模糊查询,显示内容:用户名,密码,添加时间,上传几张图片,删除 4.查看所有图片:显示编号,id,图像描述,图像大小,是否验证,上传用户,ip,上传时间,查看,操作,其中id,图像描述,图像大小,是否验证,上传用户,ip,上传时间字段具有排序功能 5.查找图片:可以根据用户名和上传日期进行查询 6.查看节点:显示IP地址,删除 7.增加节点:输入客户端的ip地址进行添加 8.退出系统:进行注销 9.团队简介和客户服务:主要是显示团队介绍和联系方式
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值