当前位置: 首页 > news >正文

移动端浏览器 jquery 获取 pdf blob文件流 预览pdf

最近遇到一个需求,一个古早的移动端 juery 项目要求做一个页面,从接口获取 pdf 文件流,然后预览出来

这里使用第三方工具:pdf.js

代码如下:

// 引入相关文件<script src="../js/pdf.js" type="text/javascript" charset="utf-8"></script>
<script src="../js/pdf.worker.js" type="text/javascript" charset="utf-8"></script>
<script src="../js/jquery.min.js"></script>
<script src="../js/pdfh5.js" type="text/javascript" charset="utf-8"></script>
// 转化编码格式
function converData(data) {data = data.replace(/[\n\r]/g, '');var raw = window.atob(data);var rawLength = raw.length;var array = new Uint8Array(new ArrayBuffer(rawLength));for (var i = 0; i < rawLength; i++) {array[i] = raw.charCodeAt(i)}return array
}// 点击获取当前标签的 id 属性值
$("#contain-wrapper").on("click", ".contain-main", function(e) {var id = $(this).attr("id")const params = {reportDocId: id}$.ajax({xhrFields: {withCredentials: true},crossDomain: true == !(document.all),type: 'POST', // 请求方式url: '接口地址', // 接口地址data: JSON.stringify(params), // 请求参数dataType: 'json', // 返回参数格式responseType: "blob", // 设置响应类型cache: false,processData: false, // 告诉jQuery不要去处理发送的数据contentType: 'application/json;charset=utf-8',success: function (data) {console.log(data);if(data.status != '0') {toast(data.message, 2000);} else {var pdfEntity = data.data; // 获取文件流var array = converData(pdfEntity); // 转码成 base64$("#demo").show()var pdfh5 = new Pdfh5('#pdf-content', {data: array});// 监听完成事件pdfh5.on("complete", function (status, msg, time) {// 处理插件不隐藏 loadEffect 的问题$(".loadEffect").hide();})}},error: function () {toast('请求失败', 2000);},complete: function() {isLoading = false;}})
})

相关文章:

移动端浏览器 jquery 获取 pdf blob文件流 预览pdf

最近遇到一个需求&#xff0c;一个古早的移动端 juery 项目要求做一个页面&#xff0c;从接口获取 pdf 文件流&#xff0c;然后预览出来 这里使用第三方工具&#xff1a;pdf.js 代码如下&#xff1a; // 引入相关文件<script src"../js/pdf.js" type"text…...

Redis并发问题解决方案

目录 前言 1.分布式锁 1.基于单个节点 2.基于多个节点 3.watch(乐观锁) 2.原子操作 1.单命令操作 2.Lua 脚本(多命令操作) 3.事务 1.执行步骤 2.错误处理 3.崩溃处理 总结 前言 在多个客户端并发访问Redis的时候&#xff0c;虽然Redis是单线程执行指令&#xff…...

读取两个文件夹里不同名的文件,处理映射不对应的文件

解决方案&#xff1a;读取两个文件夹里不同名的文件&#xff0c;处理映射不对应的文件 # -*- coding: utf-8 -*- import ospath1 r/home/ubuntu/data/yoloData/images/train2017 path2 r/home/ubuntu/data/yoloData/labels/train2017def read_all_file_name():file_path ./t…...

SpringCloud原理-OpenFeign篇(四、请求原理)

文章目录 前言正文一、书接上回&#xff0c;从代理对象入手二、ReflectiveFeign.FeignInvocationHandler#invoke()三、SynchronousMethodHandler#invoke(...) 的实现原理3.1 invoke(...)源码3.2 executeAndDecode(...) 执行请求并解码 四、如何更换client 的实现 附录附1&#…...

什么是工业物联网(IOT)?这样的IOT平台你需要吗?——青创智通

物联网(IOT)是指在互联网上为传输和共享数据而嵌入传感器和软件的互联设备的广泛性网络。这允许将从物理对象收集的信息(数据)存储在专用服务器或云中。通过分析这些积累的信息&#xff0c;通过提供最优的设备控制和方法&#xff0c;可以实现一个更安全、更方便的社会。在智能家…...

MTK Pump Express 快速充电原理分析

1 MTK PE 1.1 原理 在讲正文之前&#xff0c;我们先看一个例子。 对于一块电池&#xff0c;我们假设它的容量是6000mAh&#xff0c;并且标称电压是3.7V&#xff0c;换算成Wh(瓦时)为单位的值是22.3Wh(6000mAh*3.7V)&#xff1b;普通的充电器输出电压电流是5V2A(10W)&#xff0c…...

leetcode刷题记录——1991. 找到数组的中间位置

找到数组的中间位置 给你一个下标从 0 开始的整数数组 nums &#xff0c;请你找到 最左边 的中间位置 middleIndex &#xff08;也就是所有可能中间位置下标最小的一个&#xff09;。 中间位置 middleIndex 是满足 nums[0] nums[1] … nums[middleIndex-1] nums[middleInd…...

跨域攻击分析和防御(上)

点击星标&#xff0c;即时接收最新推文 跨域攻击 在大型公司或大型跨国企业中都拥有自己的内网&#xff0c;跨国公司都有各个子公司一般以建立域林进行共享资源。根据不同职能区分的部门&#xff0c;从逻辑上以主域和子域进行划分以方便统一管理。在物理层使用防火墙将各个子公…...

GEE:梯度提升树(Gradient Boosting Tree)分类教程(样本制作、特征添加、训练、精度、参数优化、贡献度、统计面积)

作者:CSDN @ _养乐多_ 本文将介绍在Google Earth Engine (GEE)平台上进行梯度提升树(Gradient Boosting Tree)分类的方法和代码,其中包括制作样本点教程(本地、在线和本地在线混合制作样本点,合并样本点等),加入特征变量(各种指数、纹理特征、时间序列特征、物候特征…...

ubuntu22.04 arrch64版在线安装redis

脚本 apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 40976EAF437D05B5 apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 3B4FE6ACC0B21F32 echo "deb http://archive.ubuntu.com/ubuntu/ trusty main universe restricted multiverse" >…...

篮桥云课-摆玩具

思维好题 一开始掉进了二分的陷阱&#xff0c;发现看看逐个位置的差&#xff0c;我们要分成k段就是要取消k-1个最大的逐差 然后将剩余的加起来就可以了 因为本体保证是从小到大给出的 这一点保证了答案的正确性&#xff0c;自己没想出来 还是太菜了 #include<bits/stdc.h&…...

【python】python进阶知识点

eval函数用法 函数参数&#xff1a;字符串 # 计算表达式 print(eval("12*3")) # 把字符串当成python程序运行 print(eval("random.random()")) # 字符串转成列表 print(type(eval("[1,2,3,4]"))) # 字符串转成字典 print(type(eval("{name…...

LeetCode算法题解(动态规划)|LeetCode322. 零钱兑换、LeetCode279. 完全平方数

一、LeetCode322. 零钱兑换 题目链接&#xff1a;322. 零钱兑换 题目描述&#xff1a; 给你一个整数数组 coins &#xff0c;表示不同面额的硬币&#xff1b;以及一个整数 amount &#xff0c;表示总金额。 计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一…...

Python Web开发基础知识篇

一&#xff0c;基础知识篇 本片文章会简单地说一些python开发web中所必须的一些基础知识。主要包括HTML和css基础、JavaScript基础、网络编程基础、MySQL数据库基础、Web框架基础等知识。 1,Web简介 Web&#xff0c;全称为World Wide Web&#xff0c;也就是WWW&#xff0c;万…...

企业计算机服务器中了360勒索病毒怎么办,360勒索病毒解密文件恢复

计算机技术的不断发展&#xff0c;为企业的生产运营提供了极大便利&#xff0c;不仅提升了办公效率&#xff0c;还促进了企业的发展。企业计算机在日常工作中一定加以防护&#xff0c;减少网络威胁事件的产生&#xff0c;确保企业的生产生产运营。最近&#xff0c;网络上的360后…...

LeetCode无重复字符的最长字符串的Java实现

题目 给定一个字符串 s &#xff0c;请你找出其中不含有重复字符的 最长连续子字符串 的长度。 示例 1: 输入: s "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子字符串是 "abc"&#xff0c;所以其长度为 3。示例 2: 输入: s "bbbbb" 输…...

opencv-图像平滑

高斯平滑 高斯平滑即采用高斯卷积核对图像矩阵进行卷积操作。高斯卷积核是一个近似服从高斯分布的矩阵&#xff0c;随着距离中心点的距离增加&#xff0c;其值变小。这样进行平滑处理时&#xff0c;图像矩阵中锚点处像素值权重大&#xff0c;边缘处像素值权重小。 import cv2 …...

【开源】基于Vue.js的天然气工程运维系统的设计和实现

项目编号&#xff1a; S 022 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S022&#xff0c;文末获取源码。} 项目编号&#xff1a;S022&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 系统角色分类2.2 核心功能2.2.1 流程…...

数据丢失抢救神器之TOP10 Android 数据恢复榜单

在快节奏的数字时代&#xff0c;我们的生活越来越与智能手机交织在一起&#xff0c;使它们成为重要数据和珍贵记忆的存储库。由于意外删除、软件故障或硬件故障而丢失数据可能是一种痛苦的经历。值得庆幸的是&#xff0c;技术领域提供了 Android 数据恢复软件形式的解决方案。这…...

梨花声音教育,动作电影中配音也能带来听见“冲击力”

在为动作电影提供配音服务时&#xff0c;配音员家需要通过声音的力量来增强画面上的动作张力、传递角色的活力&#xff0c;以及呈现出电影中的紧迫感。动作片充斥着快节奏的场景交替、紧张的格斗和惊险的逃逸等元素&#xff0c;配音需要精确、生动且充满动力。为动作电影配音应…...

GPU云服务特征定价原理与LLM推理优化实践

1. GPU云服务特征定价的核心原理在传统云计算定价模型中&#xff0c;时间计费&#xff08;Time-based Pricing&#xff09;一直是主流方案。这种模式下&#xff0c;用户为GPU实例支付固定的小时费用&#xff0c;而无论实际使用了多少计算资源。随着大语言模型&#xff08;LLM&a…...

机械转行自学嵌入式,我用正点原子IMX6ULL复刻了一个智能仓储项目(附完整代码)

机械工程师的嵌入式转型之路&#xff1a;基于IMX6ULL的智能仓储实战 记得第一次拿起电烙铁时&#xff0c;我的手抖得像筛糠——这和我熟悉的游标卡尺、数控机床完全是两个世界。作为在汽车制造厂做了五年机械设计的工程师&#xff0c;我从未想过有一天会对着电路板调试UART通信…...

从模组混乱到游戏秩序:Scarab如何重塑《空洞骑士》的模组体验

从模组混乱到游戏秩序&#xff1a;Scarab如何重塑《空洞骑士》的模组体验 【免费下载链接】Scarab An installer for Hollow Knight mods written in Avalonia. 项目地址: https://gitcode.com/gh_mirrors/sc/Scarab 还记得第一次为《空洞骑士》安装模组时的迷茫吗&…...

面向高端汽车暖风系统控制器的功率MOSFET选型策略与器件适配手册

随着汽车电气化与智能化进程加速&#xff0c;高端汽车暖风系统&#xff08;HVAC&#xff09;正朝着高能效、高功率密度、高可靠性及智能热管理方向演进。其核心控制器需精准驱动PTC加热器、高效水泵、散热风扇及风门电机等多元负载&#xff0c;功率MOSFET作为电能转换与分配的执…...

【国之重器 · 龙虾终端】黄仁勋说AI Agent是操作系统,但普通人用不上怎么办?荣耀给出了答案

出厂即用&#xff1a;荣耀YOYO Claw的预制龙虾体系架构 荣耀发布的自研终端侧龙虾AI智能体——YOYO Claw技术&#xff0c;首发搭载于MagicBook系列轻薄本&#xff0c;开创了「养虾本」这个全新品类。 这不是把OpenClaw打包成一个安装包那么简单&#xff0c;而是从根子上重构了…...

【仅剩72小时】Spring Boot 4.0 RC2插件仓库临时开放——抢先下载3个GA版前唯一可用的Agent-Ready调试插件(含源码签名证书)

第一章&#xff1a;Spring Boot 4.0 Agent-Ready 架构插件下载与安装 Spring Boot 4.0 引入了原生支持 Java Agent 的运行时增强能力&#xff0c;使 APM、分布式追踪、无侵入式指标采集等场景得以在不修改业务代码的前提下实现。Agent-Ready 架构要求应用启动时能自动识别并加载…...

目标检测调参新思路:手把手教你用DIoU Loss替换YOLOv5的默认损失函数(附代码)

目标检测调参新思路&#xff1a;手把手教你用DIoU Loss替换YOLOv5的默认损失函数&#xff08;附代码&#xff09; 在目标检测任务中&#xff0c;边界框回归的精度直接影响模型性能。传统YOLOv5默认采用CIoU Loss&#xff0c;但在处理特定场景&#xff08;如密集目标、小目标检…...

除了FFmpeg,这4款小众但好用的M3U8下载工具你可能真不知道(含Python脚本示例)

超越FFmpeg&#xff1a;4款高效M3U8下载工具深度评测与实战指南 在视频处理领域&#xff0c;M3U8格式因其分片传输特性成为流媒体主流方案。虽然FFmpeg凭借其全能性成为首选工具&#xff0c;但在特定场景下&#xff0c;专业工具往往能提供更精细的控制和更优的体验。本文将深入…...

从‘123456’到PBKDF2:一个密码的‘进化史’与安全工程师的选型思考

从‘123456’到PBKDF2&#xff1a;密码存储技术的演进与安全选型指南 在2004年的某次数据泄露事件中&#xff0c;安全研究人员发现某社交平台存储的用户密码中&#xff0c;超过10%直接采用"123456"这样的明文。这种原始而危险的存储方式&#xff0c;如今已成为安全工…...

基于Arduino的EPSP软驱模拟器设计与实现

1. 项目概述&#xff1a;基于Arduino的EPSP软驱模拟器在复古计算机爱好者圈子里&#xff0c;给老机器扩展存储设备一直是个热门话题。我最近折腾的这台PFBDK设备&#xff0c;本质上是个用现代硬件模拟老式软驱的有趣方案。它通过Arduino Mega 2560和Micro Pro开发板&#xff0c…...