asp.net(C#)客户端如何从服务器“直接”下载文件?

时间:2021-04-21 17:51:29
默认都是会弹出一个确认提示是打开、保存还是取消,我现在想直接下载,不知道该如何实现,求C#代码。
小弟先谢过了!!!

15 个解决方案

#1


到了客户端,就不受你的控制咯

自己封装个浏览器吧

#2


楼主做啥用呢?
病毒?

#3


直接这样就可以了啊
<a href="../Download/单机Setup.rar">
                  下载</a> 

你试一下 有问题回复

#4


这是客户端的问题,比如 firefox 非可直接打开的东东直接下载进指定目录

#5


引用 2 楼 dzpzds 的回复:
楼主做啥用呢?
 病毒?

二楼的把我眼晃花了。

支持4楼的。

#6


回答:无法实现

#7


应该是涉及到浏览器的吧

#8


不修改IE配置,就无法实现。这个受浏览器的限制太大。

#9


这个要修改客服端的机子,不然很难搞!

#10


没办法实现,这个事客户端的设置。

#11



asp.net下载文件的常用方法

//TransmitFile实现下载
    //TransmitFile实现下载
         protected void Button1_Click1(object sender, EventArgs e)
        {
            /*
             微软为Response对象提供了一个新的方法TransmitFile来解决使用Response.BinaryWrite
             下载超过400mb的文件时导致Aspnet_wp.exe进程回收而无法成功下载的问题。
             代码如下:
             */
            string strFileName = "三部闲置设备管理系统操作手册IEMS.ppt";
            Response.ContentType = "application/x-zip-compressed";
            //Response.ContentEncoding = System.Text.Encoding.GetEncoding("gb2312");
            string filename = BLL.Config.PART_EM_UPLOAD_DOC + strFileName; 

            //BLL.Config.PART_EM_UPLOAD_DOC 为路径   ("D:/EMUploadDoc/")
            Response.AddHeader("Content-Disposition", "attachment;filename=" +Server.UrlPathEncode(strFileName));

           //Server.UrlPathEncode()解决文件名的乱码问题.
            
            Response.TransmitFile(filename);
        }    //WriteFile实现下载
    protected void Button2_Click(object sender, EventArgs e)
    {
        /*
         using System.IO;
        
         */

        string fileName = "asd.txt";//客户端保存的文件名
        string filePath = Server.MapPath("DownLoad/aaa.txt");//路径

        FileInfo fileInfo = new FileInfo(filePath);
        Response.Clear();
        Response.ClearContent();
        Response.ClearHeaders();
        Response.AddHeader("Content-Disposition", "attachment;filename=" + fileName);
        Response.AddHeader("Content-Length", fileInfo.Length.ToString());
        Response.AddHeader("Content-Transfer-Encoding", "binary");
        Response.ContentType = "application/octet-stream";
        Response.ContentEncoding = System.Text.Encoding.GetEncoding("gb2312");
        Response.WriteFile(fileInfo.FullName);
        Response.Flush();
        Response.End();
    }

    //WriteFile分块下载
    protected void Button3_Click(object sender, EventArgs e)
    {

        string fileName = "aaa.txt";//客户端保存的文件名
        string filePath = Server.MapPath("DownLoad/aaa.txt");//路径

        System.IO.FileInfo fileInfo = new System.IO.FileInfo(filePath);

        if (fileInfo.Exists == true)
        {
            const long ChunkSize = 102400;//100K 每次读取文件,只读取100K,这样可以缓解服务器的压力
            byte[] buffer = new byte[ChunkSize];

            Response.Clear();
            System.IO.FileStream iStream = System.IO.File.OpenRead(filePath);
            long dataLengthToRead = iStream.Length;//获取下载的文件总大小
            Response.ContentType = "application/octet-stream";
            Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode(fileName));
            while (dataLengthToRead > 0 && Response.IsClientConnected)
            {
                int lengthRead = iStream.Read(buffer, 0, Convert.ToInt32(ChunkSize));//读取的大小
                Response.OutputStream.Write(buffer, 0, lengthRead);
                Response.Flush();
                dataLengthToRead = dataLengthToRead - lengthRead;
            }
            Response.Close();
        }
    }

    //流方式下载
    protected void Button4_Click(object sender, EventArgs e)
    {
        string fileName = "aaa.txt";//客户端保存的文件名
        string filePath = Server.MapPath("DownLoad/aaa.txt");//路径

        //以字符流的形式下载文件
        FileStream fs = new FileStream(filePath, FileMode.Open);
        byte[] bytes = new byte[(int)fs.Length];
        fs.Read(bytes, 0, bytes.Length);
        fs.Close();
        Response.ContentType = "application/octet-stream";
        //通知浏览器下载文件而不是打开
        Response.AddHeader("Content-Disposition", "attachment;  filename=" + HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8));
        Response.BinaryWrite(bytes);
        Response.Flush();
        Response.End();

    }

#12


我是想实现:客户端调用服务端的Excel模板文件,实现后台打印,但是下载有提示的话,整个过程就中断了。

#13


如果允許的話,你還敢上網不?

你的qq,網上銀行...........

Game Over

#14


除非你有本事弄个通过CA认证的ActiveX控件,不然客户端IE设置不改,怕是没有办法实现。如果你能要求客户做到用你的程序时,必须修改IE的安全性设置,那就好办了。

#15


引用 14 楼 hzzasdf 的回复:
除非你有本事弄个通过CA认证的ActiveX控件,不然客户端IE设置不改,怕是没有办法实现。如果你能要求客户做到用你的程序时,必须修改IE的安全性设置,那就好办了。

嗯。弹出一个确认提示是打开、保存还是取消。这个东东我也没解决。浏览器的安全性

#1


到了客户端,就不受你的控制咯

自己封装个浏览器吧

#2


楼主做啥用呢?
病毒?

#3


直接这样就可以了啊
<a href="../Download/单机Setup.rar">
                  下载</a> 

你试一下 有问题回复

#4


这是客户端的问题,比如 firefox 非可直接打开的东东直接下载进指定目录

#5


引用 2 楼 dzpzds 的回复:
楼主做啥用呢?
 病毒?

二楼的把我眼晃花了。

支持4楼的。

#6


回答:无法实现

#7


应该是涉及到浏览器的吧

#8


不修改IE配置,就无法实现。这个受浏览器的限制太大。

#9


这个要修改客服端的机子,不然很难搞!

#10


没办法实现,这个事客户端的设置。

#11



asp.net下载文件的常用方法

//TransmitFile实现下载
    //TransmitFile实现下载
         protected void Button1_Click1(object sender, EventArgs e)
        {
            /*
             微软为Response对象提供了一个新的方法TransmitFile来解决使用Response.BinaryWrite
             下载超过400mb的文件时导致Aspnet_wp.exe进程回收而无法成功下载的问题。
             代码如下:
             */
            string strFileName = "三部闲置设备管理系统操作手册IEMS.ppt";
            Response.ContentType = "application/x-zip-compressed";
            //Response.ContentEncoding = System.Text.Encoding.GetEncoding("gb2312");
            string filename = BLL.Config.PART_EM_UPLOAD_DOC + strFileName; 

            //BLL.Config.PART_EM_UPLOAD_DOC 为路径   ("D:/EMUploadDoc/")
            Response.AddHeader("Content-Disposition", "attachment;filename=" +Server.UrlPathEncode(strFileName));

           //Server.UrlPathEncode()解决文件名的乱码问题.
            
            Response.TransmitFile(filename);
        }    //WriteFile实现下载
    protected void Button2_Click(object sender, EventArgs e)
    {
        /*
         using System.IO;
        
         */

        string fileName = "asd.txt";//客户端保存的文件名
        string filePath = Server.MapPath("DownLoad/aaa.txt");//路径

        FileInfo fileInfo = new FileInfo(filePath);
        Response.Clear();
        Response.ClearContent();
        Response.ClearHeaders();
        Response.AddHeader("Content-Disposition", "attachment;filename=" + fileName);
        Response.AddHeader("Content-Length", fileInfo.Length.ToString());
        Response.AddHeader("Content-Transfer-Encoding", "binary");
        Response.ContentType = "application/octet-stream";
        Response.ContentEncoding = System.Text.Encoding.GetEncoding("gb2312");
        Response.WriteFile(fileInfo.FullName);
        Response.Flush();
        Response.End();
    }

    //WriteFile分块下载
    protected void Button3_Click(object sender, EventArgs e)
    {

        string fileName = "aaa.txt";//客户端保存的文件名
        string filePath = Server.MapPath("DownLoad/aaa.txt");//路径

        System.IO.FileInfo fileInfo = new System.IO.FileInfo(filePath);

        if (fileInfo.Exists == true)
        {
            const long ChunkSize = 102400;//100K 每次读取文件,只读取100K,这样可以缓解服务器的压力
            byte[] buffer = new byte[ChunkSize];

            Response.Clear();
            System.IO.FileStream iStream = System.IO.File.OpenRead(filePath);
            long dataLengthToRead = iStream.Length;//获取下载的文件总大小
            Response.ContentType = "application/octet-stream";
            Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode(fileName));
            while (dataLengthToRead > 0 && Response.IsClientConnected)
            {
                int lengthRead = iStream.Read(buffer, 0, Convert.ToInt32(ChunkSize));//读取的大小
                Response.OutputStream.Write(buffer, 0, lengthRead);
                Response.Flush();
                dataLengthToRead = dataLengthToRead - lengthRead;
            }
            Response.Close();
        }
    }

    //流方式下载
    protected void Button4_Click(object sender, EventArgs e)
    {
        string fileName = "aaa.txt";//客户端保存的文件名
        string filePath = Server.MapPath("DownLoad/aaa.txt");//路径

        //以字符流的形式下载文件
        FileStream fs = new FileStream(filePath, FileMode.Open);
        byte[] bytes = new byte[(int)fs.Length];
        fs.Read(bytes, 0, bytes.Length);
        fs.Close();
        Response.ContentType = "application/octet-stream";
        //通知浏览器下载文件而不是打开
        Response.AddHeader("Content-Disposition", "attachment;  filename=" + HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8));
        Response.BinaryWrite(bytes);
        Response.Flush();
        Response.End();

    }

#12


我是想实现:客户端调用服务端的Excel模板文件,实现后台打印,但是下载有提示的话,整个过程就中断了。

#13


如果允許的話,你還敢上網不?

你的qq,網上銀行...........

Game Over

#14


除非你有本事弄个通过CA认证的ActiveX控件,不然客户端IE设置不改,怕是没有办法实现。如果你能要求客户做到用你的程序时,必须修改IE的安全性设置,那就好办了。

#15


引用 14 楼 hzzasdf 的回复:
除非你有本事弄个通过CA认证的ActiveX控件,不然客户端IE设置不改,怕是没有办法实现。如果你能要求客户做到用你的程序时,必须修改IE的安全性设置,那就好办了。

嗯。弹出一个确认提示是打开、保存还是取消。这个东东我也没解决。浏览器的安全性