文件上传:
界面:
前台代码:
<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. 深度学习-使用cuda加速卷积神经网络-手写数字识别准确率99.7%

    源码和运行结果 cuda:https://github.com/zhxfl/CUDA-CNN C语言版本参考自:http://eric-yuan.me/ 针对著名手写数字识别的库mnist,准确率是9 ...

  2. PetShop学习第四天

    ASP.NET缓存 1.页输出缓存分为整页缓存和部分页缓存.我们可以通过@OutputCache指令来完成对Web页面的输出缓存.

  3. Java集合的小抄 Java初学者必备

    在尽可能短的篇幅里,将所有集合与并发集合的特征,实现方式,性能捋一遍.适合所有”精通Java”其实还不那么自信的人阅读. 不断更新中,请尽量访问博客原文. List ArrayList 以数组实现.节 ...

  4. Hadoop MapReduce编程 API入门系列之mr编程快捷键活用技巧详解(四)

    1.Shift + Alt + S Hadoop没有使用jdk自带的默认序列化机制. 现在呢,hadoop-2.*里有两套序列化机制.一个是自己hadoop的序列化机制,一个是谷歌的. 所以,要改为. ...

  5. 转载 C#匿名函数 委托和Lambda表达式

    转载原出处: http://blog.csdn.net/honantic/article/details/46331875 匿名函数 匿名函数(Anonymous Function)是表示“内联”方法 ...

  6. 转载Sql 获取数据库所有表及其字段名称,类型,长度

    转载原地址 http://www.cnblogs.com/Fooo/archive/2009/08/27/1554769.html SELECT (case when a.colorder=1 the ...

  7. CentOS6.5安装telnet

    原文地址:http://www.cnblogs.com/zhongshengzhen/ 1.检查是否已经安装telnet [root@localhost ~]# rpm -qa | grep teln ...

  8. webservice 地址

    快递查询WEB服务 http://webservice.36wu.com/ExpressService.asmx 支持上百家快递/物流查询,准确高效,所有数据均来自快递服务商.此数据返回类型进行了封装 ...

  9. cocos2d-x 判断点击命中坐标的几种方法

    转自:http://www.cnblogs.com/jiackyan/archive/2013/04/14/3019893.html //重载 virtual bool ccTouchBegan(CC ...

  10. POJ 2778 DNA Sequence (AC自己主动机 + dp)

    DNA Sequence 题意:DNA的序列由ACTG四个字母组成,如今给定m个不可行的序列.问随机构成的长度为n的序列中.有多少种序列是可行的(仅仅要包括一个不可行序列便不可行).个数非常大.对10 ...