asp.net 网站写好后如何运行中信建设有限责任公司企业邮箱
- 作者: 多梦笔记
- 时间: 2026年02月16日 00:57
当前位置: 首页 > news >正文
asp.net 网站写好后如何运行,中信建设有限责任公司企业邮箱,asp网站开发平台,好用的wordpress博客模版1.背景
后台返回了一个在线的pdf地址#xff0c;需要我这边去做一个pdf的预览#xff08;需求1#xff09;#xff0c;并且支持配置是否可以下载#xff08;需求2#xff09;#xff0c;需要在当前页就能预览#xff08;需求3#xff09;。之前我写过一篇预览pdf的文…1.背景
后台返回了一个在线的pdf地址需要我这边去做一个pdf的预览需求1并且支持配置是否可以下载需求2需要在当前页就能预览需求3。之前我写过一篇预览pdf的文章但是当时后台返回的是blob流文件如果你们的pdf也是以流文件的形式返回的可以看这篇文章超链接点进去就行。
2.简单说下pdf预览的实现方式
a.借助 embed / iframe标签这个是真的很简单我直接贴在下面了缺点是 没办法阻止用户打印和下载pdf所以我pass了这个方案
embedtypeapplication/pdf:srcpdfUrlwidth800height600 /iframe:srcpdfUrlwidth800height600 /实现效果
b.使用vue插件vue-pdf来渲染(应该还有一些其他的插件也可以使用大家自己研究下实现的效果把) 这个方案我已经试了且用到项目上了但是感觉很丑跟浏览器打开pdf的效果差别很大原因是这个插件大概得原理是把pdf转成了图片然后使用canvas来渲染的然后很多东西都没有就被我pass了。你可以想象一下你的pdf然后你截图放进你网页上的感觉就差不多是这个效果了图片我忘记保存了大家脑补一下 我找了个图这个其实别人还做了一些其他的渲染比如下面的也是他自己写的。我感觉是没这么好看的所以就抛弃了这个 c.使用pdf.js预览 我觉得预览pdf这一块还是得用pdf.js真的很成熟样式也还是很给力的然后想要改成什么样就可以改成什么样因为源码在你手上。 缺点稍微麻烦点需要处理跨域的问题但是如果你的网站、pdf文件所在位置后台返回的pdf位置都在同一个域名下的话就不需要处理。且可能需要知道一点运维的知识不然很可能你在本地能运行成功但是到线上可能访问不到
3.使用pdf.js预览pdf
a.到官网去下载pdf.js 建议下第二个别问我为啥因为我下了第一个来写demo发现有报错又踩坑了
b.解压之后直接丢到项目中的public文件夹下面去
c.写一个pdf.vue文件内容如下注意我的路径这个路径跟public的路径是一样的前面加了一个/原因如下当我们使用npm run serve时我们的本地电脑也会开启一个服务将public项目中的资源开发出来此时跟服务器是一样的你去访问localhost:8080/pdf/web/viewer.html 是可以正常访问通的这里不理解的话就依葫芦画瓢吧没关系的
templateiframe :src/pdf/web/viewer.html?filepdfUrl/iframe
/template
scriptexport default {name: Pdf,props: {pdfUrl: {type: String,default: }}
}
/scriptstyle scoped
iframe {/* width: 960px; */width: 1100px;max-width: 100%;height: 800px;margin-left: 50%;transform: translateX(-50%);
}
/styled.在页面中导入使用
templatediv classhomediv这下面是我用来预览pdf文件的/divpdf :pdfUrlpdfUrl/pdf/div
/templatescript
import pdf from ./pdf.vue;export default {name: HomeView,components:{pdf},data() {return {pdfUrl:http://localhost:8080/怎么删除wps中最后的空白页.pdf}},created(){},
};
/scripte.预览效果是这样子的 f.到源码中修改一下把打印和下载都去掉这一步很简单大家自己去弄了也可以直接使用我的pdf文件我这里都已经改好了。最后的效果如下 4.难点处理
很大概率你在本地能跑通代码但是到线上会出问题可能会出现的问题我都罗列在下面了
a线上404
线上404的话说明你线上的这个pdf的资源没有上传到线上或者线上写的路径不对比如你的ip为192.168.1.182。如果正常的话你去访问192.168.1.182/pdf/web/viewer.html 是可以正常访问通的。如果都没有出现正常的这个页面如下 那么说明你pdf文件资源没上传或者你写的路径不对。 1.检查dist包里面是否有这个pdf文件一般放在public文件夹的都会原封不动的打到dist包中这里还是需要检查下 2.如果发现有的话说明没问题那么你需要到服务器上看下有没有这个pdf文件上传上去了没有。如果有的话那就是你写的路径不对或者是后台没有开发这个静态资源文件夹。此时如果你不懂的话你就跟后台说下你要去访问这个页面应该要用什么路径去访问才能访问的到。正常来说 192.168.1.182/pdf/web/viewer.html是可以的如果不可以可能是要加什么路径比如192.168.1.182/web/pdf/web/viewer.html这种。如果你是web/pdf/web/viewer.html才能访问的到那么你就要在你的pdf.vue里面改下路径以对应生产环境
b线上显示资源跨域
这里是很明显从浏览器面板能看到的。这个的处理需要你和后台一起处理首先你访问/pdf/web/viewer.html这个的地址和你访问的页面的地址是需要在一个域名下的如果不在的话需要后台处理开放个别域名第二点就是/pdf/web/viewer.htmlfilepdfUrl 这个pdfUrl的地址最好也是跟你的pdf的viewer.html在同一个域名下相当于三个都在同一域名下就不会有跨域问题了。如果后台说是静态资源都放到另一台主机上了那么麻烦他让他做个资源映射保证你的pdfUrl是跟你的pdf的viewer.html在同一个域名下的
5.demo地址
demo地址可下载自己看代码https://github.com/rui-rui-an/viewpdf 参考文章https://juejin.cn/post/7207078219215732794?searchId2024060423581130C1D707D73A6338E3BA#heading-14
6.更新
关于下载忘记写下载了 html: 我这里用的是一个div然后文件名作为用户下载的入口点击就能去下载
div classdownpdf href# v-ifis_download clickgoDownload{{ pdfname }}/div方法1直接下载:
downloadPdf(pdfurl) {let fileName this.pdfnamelet reg /^([hH][tT]{2}[pP]://|[hH][tT]{2}[pP][sS]://)(([A-Za-z0-9-]).)([A-Za-z0-9-/])$/if (!reg.test(pdfurl)) {throw new Error(传入参数不合法,不是标准的文件链接)} else {let xhr new XMLHttpRequest()xhr.open(get, pdfurl, true)xhr.setRequestHeader(Content-Type, application/pdf)xhr.responseType bloblet that thisxhr.onload function () {if (this.status 200) {//接受二进制文件流var blob this.responsethat.downloadExportFile(blob, fileName)}}xhr.send()}},downloadExportFile(blob, tagFileName) {let downloadElement document.createElement(a)let href blobif (typeof blob string) {downloadElement.target _blank} else {href window.URL.createObjectURL(blob) //创建下载的链接}downloadElement.href hrefdownloadElement.download tagFileName//下载后文件名document.body.appendChild(downloadElement)downloadElement.click() //点击下载document.body.removeChild(downloadElement) //下载完成移除元素if (typeof blob ! string) {window.URL.revokeObjectURL(href) //释放掉blob对象}},方法二通过调自己的后端的下载api来下载这里得问自己的后台我这里就不贴代码了
相关文章
-
asp.net 网站开发视频教程网上申请营业执照
asp.net 网站开发视频教程网上申请营业执照
- 站长
- 2026年02月16日
-
asp.net 网站截图韩国最牛的设计网站
asp.net 网站截图韩国最牛的设计网站
- 站长
- 2026年02月16日
-
asp.net 手机网站开发唐山网站建设维护
asp.net 手机网站开发唐山网站建设维护
- 站长
- 2026年02月16日
-
asp.net+mvc+网站开发wordpress doc附件前加图标
asp.net+mvc+网站开发wordpress doc附件前加图标
- 站长
- 2026年02月16日
-
asp.net4.5网站开发分析网站的外链
asp.net4.5网站开发分析网站的外链
- 站长
- 2026年02月16日
-
asp.net个人网站有一个网站专门做促销小游戏
asp.net个人网站有一个网站专门做促销小游戏
- 站长
- 2026年02月16日
