文件上传:
界面:
前台代码:
<body style="text-align: center; background-image: url(Images/bg6.bmp);">
    <form id="form" method="post" runat="server" enctype="multipart/form-data">
        <p style="text-align: center">
             
        </p>
        <div>
            <div style="text-align: center">
                <br />
                <table border="0" cellpadding="0" cellspacing="0" style="background-image: url(Images/wjsc.bmp); width: 412px; height: 293px">
                    <tr>
                        <td style="width: 105px; text-align: center">
                            <div style="text-align: center">
                                <div style="text-align: center">
                                    <table cellpadding="0" cellspacing="0" style="width: 410px; height: 177px; text-align: center;">
                                        <tr>
                                            <td align="left" style="width: 100px; height: 42px; text-align: left"></td>
                                        </tr>
                                        <tr>
                                            <td align="left" style="width: 100px; height: 30px; text-align: center"></td>
                                        </tr>
                                        <tr>
                                            <td align="left" style="width: 100px; height: 37px; text-align: center"> 
                                                    <input type="file" name="file" style="width: 370px" id="File1" language="javascript" onclick="return File1_onclick()" runat="server" /></td>
                                        </tr>
                                        <tr>
                                            <td align="left" style="width: 100px; height: 30px; text-align: center"> 
                                        <asp:Label ID="lbltishi" runat="server" Font-Bold="False" Font-Size="9pt" ForeColor="Red"
                                            Height="20px" Width="355px" Text="提示:请您选择要上传的文件"></asp:Label></td>
                                        </tr>
                                        <tr>
                                            <td style="width: 100px; height: 30px; text-align: center;">
                                                <asp:Button runat="server" Text="上传文件" ID="BtnUp" OnClick="BtnUp_Click" Width="128px" SkinID="btnSkin"></asp:Button></td>
                                        </tr>
                                        <tr>
                                            <td style="width: 100px; height: 21px"> </td>
                                        </tr>
                                    </table>
                                </div>
                            </div>
                        </td>
                    </tr>
                </table>
                 
            </div>
        </div>
    </form>
 

</body>

后台代码:
    //上传方法
    public void Up(int id)
    {
        HttpFileCollection UpLoad = HttpContext.Current.Request.Files; //获取页面所有上传文件
        //实现多个文件上传,逐个获取
        for (int i = 0; i < UpLoad.Count; i++)
        {
            HttpPostedFile file = UpLoad[i];//HttpPostedFile 类提供用于获取关于单独的文件的信息和读取及保存文件的属性和方法。
            string fileName = Path.GetFileName(file.FileName);//获取页面上传文件的文件名
            if (fileName != null)
            {
                file.SaveAs(MapPath("mr/") + fileName);//保存上传内容
                directory.Insert(fileName, id, file.ContentLength, "mr/" + fileName, file.ContentType);//插入数据方法
 
            }
        }
        Response.Write("<script>alert('恭喜您!文件上传成功!');window.close();</script>");
    }
    //上传按钮
    protected void BtnUp_Click(object sender, EventArgs e)
    {
        if (this.File1.PostedFile.FileName == "")
        {
            Response.Write("<script>alert('很遗憾,上传文件不能为空!')</script>");
 
        }
        else
        {
            Up(ID1);
 
        }
    }
    //插入数据(directory.Insert)
    public int Insert(string mrming, int id, int nsize, string path, string s)
    {
        SqlConnection con = new SqlConnection(GetConStr());
        SqlCommand cmd = new SqlCommand("procInsert", con);
        cmd.CommandType = CommandType.StoredProcedure;
        ///添加存储过程的参数
        SqlParameter pmrming = new SqlParameter("@mrming", SqlDbType.VarChar, 200);
        pmrming.Value = mrming;
        cmd.Parameters.Add(pmrming);
        SqlParameter pmrid = new SqlParameter("@mrid", SqlDbType.Int, 4);
        pmrid.Value = id;
        cmd.Parameters.Add(pmrid);
        SqlParameter psize = new SqlParameter("@size", SqlDbType.Int, 4);
        psize.Value = nsize;
        cmd.Parameters.Add(psize);
        SqlParameter path1 = new SqlParameter("@path", SqlDbType.VarChar, 255);
        path1.Value = path;
        cmd.Parameters.Add(path1);
        SqlParameter leibie1 = new SqlParameter("@Leibie", SqlDbType.VarChar, 200);
        leibie1.Value = s;
        cmd.Parameters.Add(leibie1);
        int i = -1;
        con.Open();
        i = cmd.ExecuteNonQuery();
        con.Close();
        return i;
    }
 
下载模块:
    protected void rpZiYuan_ItemCommand(object source, RepeaterCommandEventArgs e)
    {
        if (e.CommandName == "downLoad")                      //下载
        {
            try
            {
                sql = "update T_ZiYuan set F_DownloadTimes =F_DownloadTimes+1 where F_Id=" + e.CommandArgument;
                cs.ExecuteUpdate(sql);  //更新下载次数
                
                sql = "select * from T_ZiYuan where F_Id=" + e.CommandArgument;
                DataRow row = cs.GetDataSet(sql).Tables[0].Rows[0];
                string filePath = row["F_ZiYuanPath"].ToString();
 
                filePath = Server.MapPath("~/ZiYuan/" + filePath);
 
                FileStream fs = new FileStream(filePath, FileMode.Open); //建立文件流
                long fileSize = fs.Length;
 
                Context.Response.ContentType = "application/octet-stream"; //设置输出流的 HTTP MIME 类型为application/octet-stream
                Context.Response.AddHeader("Content-Disposition", "attachment;fileName=\"" + HttpUtility.UrlEncode(Path.GetFileName(filePath), System.Text.Encoding.UTF8) + "\"");//将 HTTP 头添加到输出流
                Context.Response.AddHeader("Content-Length", fileSize.ToString());//增加报文头
 
                byte[] fileBuffer = new byte[fileSize];
                fs.Read(fileBuffer, 0, (int)fileSize);
                fs.Close();
                Context.Response.BinaryWrite(fileBuffer);
                Context.Response.End();
                //Response.Redirect("DownLoad.aspx");
 
               
 
            }
            catch
            {
                throw new Exception("对不起,文件下载错误!");
            }
        }

}

ASP.NET网络硬盘(文件上传,文件下载)的更多相关文章

  1. iOS开发之结合asp.net webservice实现文件上传下载

    iOS开发中会经常用到文件上传下载的功能,这篇文件将介绍一下使用asp.net webservice实现文件上传下载. 首先,让我们看下文件下载. 这里我们下载cnblogs上的一个zip文件.使用N ...

  2. ASP.NET中的文件上传大小限制的问题

    一.文件大小限制的问题 首先我们来说一下如何解决ASP.NET中的文件上传大小限制的问题,我们知道在默认情况下ASP.NET的文件上传大小限制为2M,一般情况下,我们可以采用更改WEB.Config文 ...

  3. Asp.net mvc 大文件上传 断点续传

    Asp.net mvc 大文件上传 断点续传 进度条   概述 项目中需要一个上传200M-500M的文件大小的功能,需要断点续传.上传性能稳定.突破asp.net上传限制.一开始看到51CTO上的这 ...

  4. MVC图片上传、浏览、删除 ASP.NET MVC之文件上传【一】(八) ASP.NET MVC 图片上传到服务器

    MVC图片上传.浏览.删除   1.存储配置信息 在web.config中,添加配置信息节点 <appSettings> <add key="UploadPath" ...

  5. ASP.NET知识总结(5.文件上传 文件下载)

    5.文件上传 ->说明:使用http协议只适合传输小文件,如果想传递大文件,则需要使用插件或者客户  端程序(使用ftp协议) ->客户端操作 <1>为表单添加属性:encty ...

  6. ASP.NET MVC之文件上传【一】(八)

    前言 这一节我们来讲讲在MVC中如何进行文件的上传,我们逐步深入,一起来看看. Upload File(一) 我们在默认创建的项目中的Home控制器下添加如下: public ActionResult ...

  7. 解决ASP.NET Core Mvc文件上传限制问题

    一.简介 在ASP.NET Core MVC中,文件上传的最大上传文件默认为20MB,如果我们想上传一些比较大的文件,就不知道怎么去设置了,没有了Web.Config我们应该如何下手呢? 二.设置上传 ...

  8. 文件上传&文件下载

    一.单个文件上传 文件上传需要两个jar包: 首先制作一个简单的页面,用于实现文件上传 <h1>单个文件上传</h1> <s:form action="uplo ...

  9. ASP.NET MVC之文件上传【一】

    前言 这一节我们来讲讲在MVC中如何进行文件的上传,我们逐步深入,一起来看看. Upload File(一) 我们在默认创建的项目中的Home控制器下添加如下: public ActionResult ...

随机推荐

  1. leetcode@ [22]Generate Parentheses (递归 + 卡特兰数)

    https://leetcode.com/problems/generate-parentheses/ Given n pairs of parentheses, write a function t ...

  2. [iOS基础控件 - 3.3] 图片浏览器

    需求: 1.显示当前图片序号/总图片数 2.显示图片 3.上一张图片.下一张图片转换 4.显示图片描述     A.数据的加载方式 1.逐个加载.处理 2.使用数组.字典分离数据和逻辑 3.延迟加载 ...

  3. Razor模板引擎(C#版)语法

    1.简介: Razor 是一种标记语法,可以让您将基于服务器的代码(Visual Basic 和 C#)嵌入到网页中. 基于服务器的代码可以在网页传送给浏览器时,创建动态 Web 内容.当一个网页被请 ...

  4. 【Stage3D学习笔记续】真正的3D世界(五):粒子特效

    先看效果,按下空格键添加粒子特效: 一般而言粒子特效的实现都是比较复杂的,且不说实现粒子特效的编码和设计,光是编写一个粒子编辑器就不是简单的一件事,但是作者使用了很取巧的方式来完成,我们接下来深入代码 ...

  5. MSSQLSERVER数据库- SP_EXECUTESQL的使用

    EXEC和SP_EXECUTESQL有什么区别呢? 1,它们之间最大的区别是嵌入式的参数,如下面一个语句 declare @sql nvarchar() declare @id varchar() ' ...

  6. Python比较函数__cmp__

    #!/usr/bin/python class my_type(object): def __init__(self, v): self.value = v def __cmp__(self, v2) ...

  7. iOS中的深复制与浅复制

    很多语言中都有深复制浅复制的概念,如C++,ObjC等.简单来说,浅复制就是两个变量指向了同一块内存区域,深复制就是两个变量指向了不同的内存区域,但是两个内存区域里面的内容是一样的. 浅复制示意图: ...

  8. sql存储过程exec执行字符串select 的区别

    USE [GuangHong]GO/****** Object: StoredProcedure [dbo].[st_MES_SelInspctDetail] Script Date: 11/23/2 ...

  9. centos6下安装部署hadoop2.2

    环境准备1.操作系统:centos6.0 64位2.hadoop版本:hahadoop-2.2.0 安装和配置步骤具体如下:1.主机和ip分配如下     ip地址                  ...

  10. iOS开发笔记系列-基础4(变量与数据类型)

    对象的初始化 对象的初始化方法一般都如下: -(id)init { self=[super init]; if(self){ ... } return self; } 这个方法首先会调用父类的初始化方 ...