Uniapp——安卓PDF下载并预览

该博客介绍了如何在前端应用中实现PDF文件的下载和预览功能。通过下载并使用PDF.js库,将解压后的文件放入静态资源目录。用户可以输入PDF文件地址,点击下载按钮将文件保存到本地,然后通过获取本地文件列表展示预览选项。点击预览时,利用web-view组件加载PDF.js的viewer.html并传递文件路径实现预览。
摘要由CSDN通过智能技术生成

1. 下载pdfjs

https://download.csdn.net/download/qq812457115/86339338

2. pdfjs解压后放到static里
在这里插入图片描述

3. 实现

<template>
	<view style="padding: 20px;">
		地址:<input type="text" v-model="pdfUrl" style="margin: 20px 0;">
		<view style="display: flex;justify-content: space-between;">
			<button @click="handleDownloadFile">下载</button>
			<button @click="getList">获取列表</button>
		</view>
		<view>
			<view v-for="item in pdfList" @click="previewPDF(item.filePath)" style="background:#2C405A;color: white;margin-top:20px;">PDF:{{item.filePath}}
			</view>
		</view>
		<web-view v-if="allUrl" :src="allUrl"></web-view>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				allUrl: "",
				viewerUrl: '/static/pdfjs/web/viewer.html',
				pdfUrl: 'http://abcfile.vaiwan.com/profile/upload/2022/06/07/上会系统测试用_20220607200050A001/上会系统测试用/陈美娟同志考察材料.pdf',
				pdfList:[]
			}
		},
		methods: {
			/* 点击下载 */
			handleDownloadFile() {
				const downloadTask = uni.downloadFile({
					url: this.pdfUrl,
					success: ({
						statusCode,
						tempFilePath
					}) => {
						if (statusCode === 200) {
							uni.saveFile({
								tempFilePath,
								success: (res) => {
									this.getList()
								},
								fail: (e) => console.log('下载失败', e)
							})
						}
					}
				});

				downloadTask.onProgressUpdate((res) => {
					console.log('下载进度' + res.progress);
					console.log('已经下载的数据长度' + res.totalBytesWritten);
					console.log('预期需要下载的数据总长度' + res.totalBytesExpectedToWrite);
				});
			},
			/* 点击获取保存文件列表 */
			handleGetSaveFileList() {
				let that = this
				uni.getSavedFileList({
					success: function(res) {
						that.pdfList = res.fileList
						console.log(that.pdfList)
					}
				})
			},
			/* 预览PDF */
			previewPDF(url) {
				const path = plus.io.convertLocalFileSystemURL(url)
				let fileUrl = encodeURIComponent(path) // encodeURIComponent 函数可把字符串作为 URI 组件进行编码。
				this.allUrl = this.viewerUrl + '?file=' + fileUrl
			}
		}
	}
</script>
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将Uniapp打包成安卓应用并使用自有证书,可以按照以下步骤进行操作: 1. 在打包配置选项界面中选择Android作为目标平台,并选择使用自有证书。\[1\] 2. 如果你或者公司已经申请了证书,可以选择使用自有证书。如果没有,可以选择使用公测证书,用于测试目的。一般来说,广告等内容不需要添加。选择快速打包即可。\[1\] 3. 等待打包完成后,在控制台中会出现打包成功的提示。点击打开所在目录,你将会看到刚刚生成的apk文件。你可以进行自测,也可以将其发送给他人进行安装。如果要安装到手机上,可以通过将手机与电脑连接,然后右键apk文件,选择安装到手机。这样就可以在手机上安装并查看你编写的APP了。\[2\] 4. 生成自有证书的步骤如下: - 打开命令行工具,使用keytool -genkey命令生成证书。例如,使用以下命令生成证书: ``` keytool -genkey -alias testalias -keyalg RSA -keysize 2048 -validity 36500 -keystore test.keystore ``` 其中,testalias是后面在HBuilder上要填写的证书别名,test.keystore是后面在HBuilder上要填写的证书文件,test可以根据需要进行修改,36500表示证书的有效时间为100年,单位为天,可以根据需要进行调整。自己输入的密钥库口令是后面在HBuilder上要填写的证书私钥密码(例如123456)。\[3\] - 根据提示输入相关信息即可完成证书生成。 希望以上信息对你有所帮助! #### 引用[.reference_title] - *1* *2* [【uniapp小程序】—— APP项目云打包(安卓)](https://blog.csdn.net/qq_49002903/article/details/126937483)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [uniapp-打包安卓app(如何生成证书)](https://blog.csdn.net/qq_36738092/article/details/130644632)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值