[转]Display PDF within web browser using MVC3
本文转自:http://www.codeproject.com/Tips/697733/Display-PDF-within-web-browser-using-MVC
Introduction
I will demonstrate you different way to display PDF within browser using MVC3
.
Background
I have created MVC3
empty project. I have added Controller
name Home
and created action
name Index
. I have added Index
view
for index action. I have added Temp.pdf
in my solution.
Using the code
Method 1:- Display PDf by filePath. Let's create action name DispalyPDF
in Home controller
as fellow and add view
for action
.
public FileResult DisplayPDF()
{
return File("/Temp.pdf", "application/pdf");
}
That's it you can able to view PDF in browser.
I have use File function as my return type which return FileResult
having overload File(filePaht,contentType)
.
filePath
: Define the path of file. I have file in my root directory name Temp.pdf. I have define my file path as "/Temp.pdf".
contentType
: Define the type of file we are returning. If the content type is supported by browser browser will display that file.
I have specified link in the Index view that will navigate to the action DisplyaPDF()
.
<li>@Html.ActionLink("Viw Temp PDF Method1","DisplayPDF")</li>
Method 2:- Display PDF by fileContent.
Let's create action PDFDispaly()
as fellow and add view PDFDisplay
.
public FileResult PDFDisplay()
{
string filepath = Server.MapPath("/Temp.pdf");
byte[] pdfByte = Helper.GetBytesFromFile(filepath);
return File(pdfByte, "application/pdf");
}
I have use File function as return type having overload File(fileContent,fileContentType)
fileContent
: define file content as the byte array.
fileContentType
: define the type of file eg pdf, excel, text etc..
I have use server.MapPath
method to get actual path of file on server by specifying virtual path as argument. I have created Helper
method name GetByetsFromFile
that will return fileContent
as byte array by accepting actual file path as argument.
public static byte[] GetBytesFromFile(string fullFilePath)
{
// this method is limited to 2^32 byte files (4.2 GB) FileStream fs = null;
try
{
fs = File.OpenRead(fullFilePath);
byte[] bytes = new byte[fs.Length];
fs.Read(bytes, 0, Convert.ToInt32(fs.Length));
return bytes;
}
finally
{
if (fs != null)
{
fs.Close();
fs.Dispose();
}
} }
Method3:- Download PDF File Let's add another link that will provide to download Temp.pdf on ClientSide.
<li>@Html.ActionLink("Download Temp PDF","PDFDownload")</li>
Let's create action name PDFDownload
that will allow user to download PDF.
public FileResult PDFDownload()
{ string filepath =Server.MapPath("/Temp.pdf");
byte[] pdfByte = Helper.GetBytesFromFile(filepath);
return File(pdfByte, "application/pdf", "demoform1");
}
I have use File function as my return type where overload accept the fileContent
, contentType
and fileDownloadName
.
fileDownloadName
: we just need to specify the file download name where MVC3 engine will do all the magic for us and download the file on client side with the specified name.
Method4:- Display PDF File as PartialView. You can not specify the return type File as PartialViewResult
. Let's use the HTML 5 tag embed in partialview to display pdf within browser and render the partial view inside div using AJax.ActionLink helper.
Let's add another actionlink on Index View but this time we will add ajax.actionlink()
.
<li>@Ajax.ActionLink("Viw Temp PDF Method4", "PDFPartialView", new AjaxOptions { UpdateTargetId = "pdfContainer" })</li>
Let's create action method PDFPartialView
inside Home controller that return partialviewresult
as fellow.
public PartialViewResult PDFPartialView()
{
return PartialView();
}
Add view by checking create partial view check box. We have created partial view
. Create embed html 5 tag inside the partial view. Specify src to the relative path of the PDF file as fellow.PDFPartialView
<h4>Partial View That display PDF....</h4><br /><embed src="/Temp.pdf" type="application/pdf"></embed>
Click on the link "View Temp pdf method3". You will notice pdf loaded inside the div id pdfContainer.
Method5:- Display PDF as 64 bit string. This method only work with Chrome browser. We will follow following 3 step process.
Step 1 Convert PDF into the 64 bit array.
Step 2 Convert 64 bit array into 64 bit string.
Step3 Display 64 bit string as Src of the embed tag.
Note:- Do not forget to specify mime type as type.(e.g. "image/png")
Let's create action PDFInCrome in Home controller as follow.
//only work in the crome
public PartialViewResult PDFInCrome()
{ string filepath = Server.MapPath("/Temp.pdf");
byte[] pdfByte = Helper.GetBytesFromFile(filepath);
var strBase64=Convert.ToBase64String(pdfByte);
PDFCrome pdfCrome = new PDFCrome();
pdfCrome.Content = string.Format("data:application/pdf;base64,{0}", strBase64);
return PartialView(pdfCrome);
}
Let's add partial view PDFInCrome
as follow.
@model DisplayPDFDemo.Comman.PDFCrome <embed src="@Model.Content" ></embed>
We are done with our action and view. Let's call our partial view on click of Ajax.ActionLink in our Index view.
<li>@Ajax.ActionLink("Viw Temp PDF Method5", "PDFInCrome", new AjaxOptions { UpdateTargetId = "pdfContainer" })</li>
This is end our simple demo of display PDF within web browser hope you enjoy.
License
This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)
[转]Display PDF within web browser using MVC3的更多相关文章
- Display PDF in browser | Acrobat, Reader XI
点这个链接查看详细的解决办法 http://helpx.adobe.com/acrobat/using/display-pdf-browser-acrobat-xi.html When you cli ...
- Csharp:user WebControl Read Adobe PDF Files In Your Web Browser
namespace GeovinDu.PdfViewer { [DefaultProperty("FilePath")] [ToolboxData("<{0}:Sh ...
- 关于PB调用Microsoft Web Browser控件的一些问题
Microsoft Web Browser控件是WINDOWS系统自带的控件,一般不需要单独安装,由于工作的需要,把使用中遇到的问题记录一下,以便查阅. 插入控件: 环境为PB12.0,insert- ...
- Atitit.office word excel ppt pdf 的web在线预览方案与html转换方案 attilax 总结
Atitit.office word excel ppt pdf 的web在线预览方案与html转换方案 attilax 总结 1. office word excel pdf 的web预览要求 ...
- 对于一个网站,如何禁止直接从浏览器Web browser中访问js文件
比如有一个网站,https://testsystem.infotest.com 在这个网站的内容文件目录下面,有一个scripts文件夹,该文件夹中有一个js文件,比如lukeTest.js文件 这样 ...
- C#彻底解决Web Browser 跨域读取Iframes内容
C#彻底解决Web Browser 跨域读取Iframes内容 用C# winform的控件web browser 读取网页内容,分析一下数据,做一些采集工作. 如果是同一个域名下面还是好办的,基本上 ...
- 教你如何清除 MyEclipse/Eclipse 中 Web Browser 和 Switch Workspace 的历史记录
有些许强迫症的开发人员可能会因为 MyEclipse/Eclipse 中 Web Browser 和 Switch Workspace 冗余的历史记录而感到苦恼,下面的方法就可以有效的帮助解决你的痛点 ...
- How To Open An URL In Android’s Web Browser
How To Open An URL In Android’s Web Browser 以下核心代码片断,将展现使用“android.content.Intent” 打开一个指定的 URL. butt ...
- How to open a web site with the default web browser in a NEW window
http://delphi.about.com/cs/adptips2004/a/bltip0504_4.htm When using ShellExecute (as explained in th ...
随机推荐
- ActiveReports 报表控件官方中文入门教程 (3)-如何选择页面报表和区域报表
本篇文章将介绍区域报表和页面报表的常见使用场景.区别和选择报表类型的一些建议,两种报表的模板设计.数据源(设计时和运行时)设置.和浏览报表的区别. ActiveReports 报表控件官方中文入门教程 ...
- Android 手机卫士12--进程管理
1.本进程不能被选中,所以先将checkbox隐藏掉--手机卫士 不能自杀 if(getItem(position).packageName.equals(getPackageName())){ ho ...
- [翻译]:SQL死锁-阻塞
一般情况下死锁不是一步到位的,它必须满足特定的条件,然后形成资源的循环依赖才会产生死锁,死锁之前一定会出现阻塞,由阻塞升级才有可能出现死锁,所以我们有必要了解系统中都有哪些已经被阻塞的锁. 我在解决共 ...
- RHEL7文件管理
Linux系统目录结构 主要目录说明 目录 说明 / 通常称为根分区所有的文件和目录的起始点只有root用户对此目录拥有写权限 /home 普通用户的宿主目录 /root 超级用户的宿主目录 /dev ...
- 实验12:Problem I: 成绩排序
Home Web Board ProblemSet Standing Status Statistics Problem I: 成绩排序 Problem I: 成绩排序 Time Limit: 1 ...
- 换SSD硬盘,重装系统,一阵子忙乱
许久没重装过系统了,低声下气地问老板要了一块SSD硬盘,不马上安装上手痒得难受,但年底这个时候重装系统绝对忙乱,差点耽误了一份申请表和一份培训记录表. SSD安装:先从网上找相关贴子,最主要的一个 ...
- Android拍照保存在系统相册不显示的问题
Intent intent = new Intent(Intent.ACTION_MEDIA_SCANNER_SCAN_FILE); Uri uri = Uri.fromFile(new File(& ...
- UWP开发-HTTP详解
HTTP作为一个基础功能,有必要介绍下在UWP下的使用方法. 一.Get请求: 一般我们用到的是GetAsync方法 public static async Task Gets(Uri uri) { ...
- Android自定义控件之轮播图控件
背景 最近要做一个轮播图的效果,网上看了几篇文章,基本上都能找到实现,效果还挺不错,但是在写的时候感觉每次都要单独去重新在Activity里写一堆代码.于是自己封装了一下.本篇轮播图实现原理原文出处: ...
- 冒泡排序(java版)
public class BubbleSortTest { //冒泡排序 public static void bubbleSort(int[] source) { //外层循环控制控制遍历次数,n个 ...