依赖pdf.js的插件,怎么解决跨域问题

JavaScript014

依赖pdf.js的插件,怎么解决跨域问题,第1张

目前最新的Mobile Substrate v0.9.5000依赖包已改名为cydia Substrate,它的发布使iOS7越狱真正变完美了,因为这意味着以后的插件都可以开始支持64位处理器。但是,在发布之初,Cydia Substrate总有一些bug让人神烦,很多用户都反映安装Cydia Substrate之后许多插件突然不工作了。碰到这样的情况怎么办了,来试试这个方法吧。你需要首先确认的是该插件是否真的已经针对iOS7优化过了,毕竟这是最大的前提。之后遵循以下步骤:1、卸载Cydia Substrate和Substrate SafeMode这一步将完全移除Cydia Substrate和它的附属物,这意味着许多插件和应用也会一并被去掉。如果这个结果让你很是在意,也可以继续等待更加“无害”的办法。2、重新安装Cydia SubstrateSubstrate SafeMode也会被自动安装上去。3、找一个已知的能够在iOS7下工作的插件测试如果这一步的执行完全正常,那么这个让人困扰的问题就解决了。如果你在更新Cydia Substrate依赖包后插件不工作,来试试这个方法吧。如果你碰到了新问题,可反馈给我们的PP助手客服,他们会尽力帮助大家解决的。

pdf.js预览文件必须只能是在服务器部署的项目路径下,不能通过修改配置的方式支持本地路径的文件,否则会有js跨域问题。如果要显示本地文件,可以折中考虑先做一个上传功能将文件上传到服务器上然后在页面上展示,这样基本实现了预览本地文件。

可参考:微信JS-SDK说明文档 >

此时可能出现白名单错误(忘截图了),需要在微信公众号中设置错误中的IP

注意:access_token和ticket都需要缓存

4. 获取签名 signature

将以上内容以键值对形式拼接,类似如下

本地引入sha1算法(需网上查找)

将上述拼接的字符串以参数的形式传递到sha1中得到 signature

signature = sha1(拼接完的字符串)

验证 signature 是否正确 >

将appId,nonceStr,timestamp和signature返回给前端

官网上是这样描述的:

这时候调用 updateAppMessageShareData , updateTimelineShareData 的时候就可以生效了,具体原理不清楚。。

注意:imgUrl配置有严格的要求

尺寸120 x 120,大小不超过10K,不支持GIF格式。必须采用https协议(最好写完整url),不支持base64。由于我使用的是vue,在webpack打包时图片小于10k的是会自动打包成base64导致无法正常显示图片,因此在webpack.base.config.js中修改默认配置

由于在网页中直接查看pdf的路径是无法在微信中查看(安卓)和分享(ios),因此使用pdf插件进行优化 --- pdf.js 。其原理是绘制成canvas,最终在真机上放大时可能出现模糊的问题。

创建之后控制台会报错出现跨域问题,因为pdf.js不支持跨域访问。此时可以将错误跨域信息在上一步你引入的文件中查找,然后将其判断语句注释掉即可解决这个问题。最后会发现pdf出现在这个容器中(忘截图了),也实现了微信中预览和分享的功能。