uniapp-微信公众号实现pdf的预览和下载

uniapp-微信公众号实现pdf的预览和下载

1.预览

预览最方便的方式就是借助pdf.js,直接官网下载导入到自己项目下即可。
注意:一定要放在根目录下面 /hybrid/html 否则可能会出现找不到的情况。
在这里插入图片描述

代码

<template>
    <view>
    <!-- 通过web-view渲染到页面上 -->
        <web-view :src="allUrl"></web-view>
    </view>
</template>

<script>
	import {getPdf} from '@/service/test.js';
    export default {
        data() {
            return {
                viewerUrl: '/hybrid/html/web/viewer.html',
                allUrl: ''  
            }
        },
        onLoad(options) {
           this.pdf()
        },
        methods: {
			//自己封装的请求的方法
			pdf(){
				getPdf().then((res)=>{
				     //这里拿到的结果是base64的流,需要转为二进制的流
				     //可以直接拿到二进制的流
					 let pdf = `data:application/pdf;base64,${res}`;
					 pdf = this.base64ToBlob(pdf)
					 this.allUrl = this.viewerUrl + '?file=' + URL.createObjectURL(pdf)
				})
				
			},
			
            // base64转blob
            base64ToBlob(base64Data) {
                let arr = base64Data.split(','),
                    fileType = arr[0].match(/:(.*?);/)[1],
                    bstr = atob(arr[1]),
                    l = bstr.length,
                    u8Arr = new Uint8Array(l);

                while (l--) {
                    u8Arr[l] = bstr.charCodeAt(l);
                }
                return new Blob([u8Arr], {
                    type: fileType
                });
            }
        }
    }
</script>

2.下载

微信公众号是不支持直接下载的,所以只能引导用户打开浏览器去进行下载。

<template>
	<view>	
	</view>
</template>

<script>
	export default {
		data() {
			return {
				
			}
		},
		onLoad(){
		 	this.downFile()
		},
		methods: {
			downFile() {
				let jweixin = require('jweixin-module') 
				uni.downloadFile({

					 url:  '',//下载地址
					header: {
						'X-Access-Token': uni.getStorageSync('token'),
						 "Access-Control-Expose-Headers":'Content-Disposition'
					},
					responseType:'arraybuffer',
					success: (data) => {
						this.resourceUrl = data.tempFilePath
						//这里拿到的也是二进制的流
						console.log(data.tempFilePath)
						if (data.statusCode === 200) {
							// window.location = URL
							//word同样适用
							const fileName = 'xxx.pdf'  // 文件名+后缀
							const listNode = document.createElement("a")
							listNode.download = fileName 
							listNode.style.display = "none"
							listNode.href = data.tempFilePath // 文件流生成的url
							document.body.appendChild(listNode)
							listNode.click()  // 模拟在按钮上实现一次鼠标点击
							window.URL.revokeObjectURL(listNode.href)  // 释放 URL 对象
							document.body.removeChild(listNode)  // 移除 a 标签
							
						}
			
					}
				});
			},
		}
	}
</script>

<style>

</style>

公众号h5pdf文件上传是指在公众号的自定义菜单或服务模块中,用户可以选择上传PDF文件进行阅读或下载。这种功能的实现主要依赖于公众号的开发能力和对文件上传的处理方式。 首先,公众号需要提供一个用户界面,用户可以在该界面中选择本地存储的PDF文件进行上传。用户可以通过手机相册、微信云存储或者其他文件管理应用选择文件。在选择文件后,公众号需要进行文件格式的判断,确保上传的文件符合PDF格式的要求。 其次,公众号需要通过H5技术将选择的PDF文件上传至服务器。H5技术可以使用一些前端框架如Vue.JS、React等,通过调用服务器端提供的API接口将PDF文件传输至服务器。这个过程中需要注意文件上传的速度和稳定性,以及对用户信息的保护。 最后,公众号需要对上传的PDF文件进行存储和管理。可以采用云存储技术,将文件存储在云端,这样可以节约服务器的存储空间。同时,公众号需要为用户提供浏览和下载PDF文件的功能,可以通过将PDF文件转换为图片或者使用第三方的PDF阅读器插件来实现。 公众号h5pdf文件上传功能的实现需要公众号开发人员具备一定的后端开发和前端开发的技术,同时需要与服务器端进行数据传输和信息安全的保护。通过对用户上传PDF文件的处理,公众号可以为用户提供更加丰富的服务体验。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值