当前位置: 首页 > 编程笔记 >

C#导出pdf的实现方法(浏览器不预览直接下载)

麹高远
2023-03-14
本文向大家介绍C#导出pdf的实现方法(浏览器不预览直接下载),包括了C#导出pdf的实现方法(浏览器不预览直接下载)的使用技巧和注意事项,需要的朋友参考一下

前言

这篇文章主要给大家介绍了关于C#导出pdf的实现方法,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧

方法如下:

一.接口部分的代码

[HttpGet]
    public HttpResponseMessage ExportPdf(string id)
    {
      string pdfName = "";
       //id 查询条件,根据实际情况修改即可
       //pdfName 例如download.pdf
      byte[] pdfData= _policyGapManagerService.ExportPdf(id, out pdfName);//获得pdf字节
      var result = new HttpResponseMessage(HttpStatusCode.OK)
      {
        Content = new ByteArrayContent(pdfData)
      };
      result.Content.Headers.ContentDisposition =
        new ContentDispositionHeaderValue("attachment")
        {
          FileName = pdfName
        };
      result.Content.Headers.ContentType =new MediaTypeHeaderValue("application/pdf");
      return result;
    }

二.返回pdfbyte数组

1.下载http模式的pdf文件(以ASP.NET为例,将PDF存在项目的目录下,可以通过http直接打开项目下的pdf文件)

#region 调用本地文件使用返回pdfbyte数组

    /// <summary>
    /// 调用本地文件使用返回pdfbyte数组
    /// </summary>
    /// <param name="srcPdfFile">‘D:\in2434341555551.pdf'</param>
    /// <returns></returns>

    public static byte[] GetSignaturePDFByte(string srcPdfFile)
    {
      using (FileStream fsRead = new FileStream(srcPdfFile, FileMode.Open, FileAccess.Read, FileShare.Read))
      {
        int fsLen = (int)fsRead.Length;
        byte[] hebyte = new byte[fsLen];
        fsRead.Read(hebyte, 0, hebyte.Length);
        return hebyte;
      }
    }

    #endregion 调用本地文件使用返回pdfbyte数组

    #region 从网站上下载pdf,转化为字节流


    /// <summary>
    /// 从网站上下载pdf,转化为字节流
    /// </summary>
    /// <param name="srcPdfFile">文件地址:'https://******/group2/M00/00/04/wKj-mlpcoZ2IUbK5AACrpaV6k98AAAB6gAAAAAAAKu9562.pdf'</param>

    /// <returns></returns>
    public static Byte[] GetByteByRemoteURL(string srcPdfFile)
    {
      byte[] arraryByte;
      HttpWebRequest req = (HttpWebRequest)HttpWebRequest.Create(srcPdfFile);
      req.Method = "GET";
      using (WebResponse wr = req.GetResponse())
      {
        StreamReader responseStream = new StreamReader(wr.GetResponseStream(), Encoding.UTF8);
        int length = (int)wr.ContentLength;
        byte[] bs = new byte[length];

        HttpWebResponse response = wr as HttpWebResponse;
        Stream stream = response.GetResponseStream();

        //读取到内存
        MemoryStream stmMemory = new MemoryStream();
        byte[] buffer1 = new byte[length];
        int i;
        //将字节逐个放入到Byte 中
        while ((i = stream.Read(buffer1, 0, buffer1.Length)) > 0)
        {
          stmMemory.Write(buffer1, 0, i);
        }
        arraryByte = stmMemory.ToArray();
        stmMemory.Close();
      }
      return arraryByte;
    }

    #endregion 从网站上下载pdf,转化为字节流

    #region 从网站上下载文件,保存到其他路径

    /// <summary>
    /// 从网站上下载文件,保存到其他路径
    /// </summary>
    /// <param name="pdfFile">文件地址</param>
    /// <param name="saveLoadFile">保存文件路径:D:\12221.pdf</param>
    /// <returns></returns>
    public string SaveRemoteFile( string saveLoadFile , string pdfFile)
    {
      //bool flag = false;
      var f = saveLoadFile + Guid.NewGuid().ToString("D") + ".pdf";
      Uri downUri = new Uri(pdfFile);
      //建立一个WEB请求,返回HttpWebRequest对象
      HttpWebRequest hwr = (HttpWebRequest)WebRequest.Create(downUri);
      //流对象使用完后自动关闭
      using (Stream stream = hwr.GetResponse().GetResponseStream())
      {
        //文件流,流信息读到文件流中,读完关闭
        using (FileStream fs = File.Create(f))
        {
          //建立字节组,并设置它的大小是多少字节
          byte[] bytes = new byte[102400];
          int n = 1;
          while (n > 0)
          {
            //一次从流中读多少字节,并把值赋给N,当读完后,N为0,并退出循环
            n = stream.Read(bytes, 0, 10240);
            fs.Write(bytes, 0, n); //将指定字节的流信息写入文件流中
          }
        }
      }

      //return flag;
      //return _outPath + saveLoadFile;
      return f;
    }

    #endregion 从网站上下载文件,保存到其他路径

2.ftp模式的pdf文件

/// <summary>
    /// 下载FTP文件。
    /// </summary>
    /// <param name="offsetPath">相对路径</param>
    /// <param name="fileName">文件名称</param>
    /// <returns>下载结果,本地文件路径</returns>
    public string DownLoad(string offsetPath,string fileName)
    {
      try
      {
        FtpWebRequest ftpWeb = (FtpWebRequest)WebRequest.Create(_ftpRootPath + offsetPath + fileName);
        ftpWeb.Method = WebRequestMethods.Ftp.DownloadFile;
        ftpWeb.UseBinary = true;
        var resp = ftpWeb.GetResponse();
        using (FileStream fs = new FileStream(_outPath + fileName, FileMode.Create))
        {
          using (var s = resp.GetResponseStream())
          {
            if (s == null) { return "文件不存在!"; }

            int readCout = 0;
            byte[] bytes = new byte[1024];
            readCout = s.Read(bytes, 0, 1024);
            while (readCout > 0)
            {
              fs.Write(bytes, 0, readCout);
              readCout = s.Read(bytes, 0, 1024);
            }
          }
        }
        resp.Close();
        return _outPath + fileName;
      }
      catch (Exception e)
      {
        return e.Message;
      }
      
    }

    /// <summary>
    /// 判断文件是否存在
    /// </summary>
    /// <param name="offsetPath"></param>
    /// <param name="fileName"></param>
    /// <returns></returns>
    public bool FileExists(string offsetPath, string fileName)
    {
      try
      {
        FtpWebRequest ftpWeb = (FtpWebRequest)WebRequest.Create(_ftpRootPath + offsetPath + fileName);
        ftpWeb.Method = WebRequestMethods.Ftp.DownloadFile;
        ftpWeb.UseBinary = true;
        var resp = (FtpWebResponse)ftpWeb.GetResponse();
        resp.Close();
        return true;
      }
      catch (Exception)
      {
        return false;
      }
    }

    /// <summary>
    /// 获取目录下所有文件
    /// </summary>
    /// <returns></returns>
    public string[] Files(string offsetPath)
    {
      try
      {
        FtpWebRequest ftpWeb = (FtpWebRequest)WebRequest.Create(_ftpRootPath + offsetPath);
        ftpWeb.Method = WebRequestMethods.Ftp.ListDirectory;
        Stream stream = ftpWeb.GetResponse().GetResponseStream();
        if (stream == null)
        {
          return null;
        }
        List<string> fileList = new List<string>();
        using (StreamReader sr = new StreamReader(stream))
        {
          StringBuilder sb = new StringBuilder();
          do
          {
            sb.Append(sr.ReadLine());
            if (sb.Length > 0)
            {
              fileList.Add(sb.ToString());
              sb.Clear();
            }
            else
            {
              break;
            }
          } while (true);
        }
        return fileList.ToArray();
      }
      catch (Exception)
      {
         return null;
      }
    }

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对小牛知识库的支持。

 类似资料:
  • 本文向大家介绍Asp.net实现直接在浏览器预览Word、Excel、PDF、Txt文件(附源码),包括了Asp.net实现直接在浏览器预览Word、Excel、PDF、Txt文件(附源码)的使用技巧和注意事项,需要的朋友参考一下 1.功能说明 输入文件路径,在浏览器输出文件预览信息,经测试360极速(Chrome)、IE9/10、Firefox通过 2.分类文件及代码说明 DemoFiles 存

  • 本文向大家介绍Android实现pdf在线预览或本地预览的方法,包括了Android实现pdf在线预览或本地预览的方法的使用技巧和注意事项,需要的朋友参考一下 最近项目中需要使用在线预览pdf,并要能实现自动播放,我想这样的需求无论如何来说都是很操蛋的 由于本人水平有限,最后讨论将项目需求改成将pdf下载到本地再实现自动播放。 接下来总结下目前能够实现pdf阅读的方案,开发当中需要根据实际需求去选

  • 预览 在编辑器工具栏上选择 浏览器 后,点击旁边的按钮,会在用户的默认桌面浏览器中直接运行游戏的网页版本。推荐使用谷歌浏览器(Chrome)作为开发过程中预览调试用的浏览器,因为谷歌浏览器(Chrome)的开发者工具是最为全面强大的。 浏览器预览界面的最上边有一系列控制按钮可以对预览效果进行控制: 最左边选择预览窗口的比例大小,来模拟在不同移动设备上的显示效果 Rotate 按钮决定显示横屏还是竖

  • 本文向大家介绍JavaScript实现的浏览器下载文件的方法,包括了JavaScript实现的浏览器下载文件的方法的使用技巧和注意事项,需要的朋友参考一下 废话不多说了,直接给大家贴代码了,具体代码如下所示:   该方法从网上找来的,直接调用,使用直接传路径,就可使用 总结 以上所述是小编给大家介绍的JavaScript实现的浏览器下载文件的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,

  • 本文向大家介绍drag-and-drop实现图片浏览器预览,包括了drag-and-drop实现图片浏览器预览的使用技巧和注意事项,需要的朋友参考一下 今天刚试过chrome的drag and drop API,它能非常简单的将本地的图片放到浏览器中进行预览。试想一下当我们把一个文图片拖拽到浏览器里会发生什么事情,你的浏览器试图打开一个新的页面并加载这个图片。现在我不想浏览器这样帮我处理图片,我希

  • 本文向大家介绍JAVA读取文件流,设置浏览器下载或直接预览操作,包括了JAVA读取文件流,设置浏览器下载或直接预览操作的使用技巧和注意事项,需要的朋友参考一下 最近项目需要在浏览器中通过URL预览图片。但发现浏览器始终默认下载,而不是预览。研究了一下,发现了问题: // 设置response的Header,注意这句,如果开启,默认浏览器会进行下载操作,如果注释掉,浏览器会默认预览。 respons