- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
用户自定义 SVG,当他们满意时,我想为他们提供在 Facebook 上共享图像的选项。
我知道 Facebook 不接受 SVG,所以,在阅读之后 this问题,我想出了以下使用canvg
:
var svgText = "<svg>" + $("#canvas2").html() + "</svg>";
canvg(document.getElementById('drawingCanvas'), svgText);
var img = document.getElementById('drawingCanvas').toDataURL("image/png");
尽管 .toDataURL
的命名,img
不是一个 URL(至少,我不认为它是),而是一个超过 10,000 个字符的字符串data:image/png;base64,...
的存在。
如果我然后尝试允许用户在 Facebook 上共享 PNG,
window.FB.ui({
href: "https://dna.land",
method: 'feed',
name: 'name',
link: "dna.land",
picture: img,
caption: 'mywebsite.com',
description: "description",
message: "message"
}, function(response) {});
我收到的错误消息是“需要参数 href”(我清楚地提供了......也许 img
太长并且 JSON 被 chop 了?),虽然我有还看到我没有为 picture
提供有效的 URL。
如何在 Facebook 上分享图像数据?
如果无法使用 PNG 的原始 base 64 编码来执行此操作,我不反对将 PNG 文件临时存储在服务器上。但是,理想情况下,我只会存储 24 小时、几个月或一小段时间,然后能够在用户的帖子不消失的情况下将其删除。这可能吗?
最佳答案
Despite the naming of .toDataURL, img is not then a URL (at least, I don't think it is), but a >10,000-character string that beings with data:image/png;base64,....
这正是Data URI方法!并且函数名称 toDataURL()
没有误导性。
在您的情况下,您需要将 Base64 编码 图像(由数据 URI 表示)转换为文件并将其上传到某处(可能在您自己的服务器或任何服务器上)云存储提供商,如 Amazon S3 或谷歌云存储),然后在 Facebook 上分享该网址。
在您自己的服务器上:
如果您要将其上传到您自己的服务器,那么您只需通过 ajax 发布数据 URL,将其转换为图像并返回该图像的 URL。要转换 Base64 图像,您需要寻找有关如何使用后端语言/系统进行转换的具体方法。例如,将Base64编码的图片转换成文件在
对于任何其他后端,只需执行 Google 搜索,您应该找到执行此操作的方法。
上传到第三方云存储服务:
如果您想将图像上传到任何第三方服务,您可以获得Blob使用 Canvas.toBlob() 从 Canvas 中删除对象函数并将生成的 blob 上传到提供者(可能通过使用他们提供的 Javascript/REST API)。据我所知,许多流行的云存储提供商将允许您上传具有适当 MIME 类型的 blob,但您应该始终检查是否支持。
关于javascript - 将 SVG 分享到 Facebook,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44293328/
直接上代码,可以写在公共文件common和继承的基础类中,方便调用 ?
1、php服务端环境搭建 1.php 服务端环境 安装套件 xampp(apach+mysql+php解释器) f:\mydoc文件(重要)\dl_学习\download重要资源\apache
如下所示: Eclipse快捷键 Ctrl+1 快速修复 Ctrl+D: 删除当前行 Ctrl+Alt+↓ 复制当前行到下一行(复制增加) Ctrl+Alt+↑ 复制当前行到上一行(复制增加)
第一步:conn.PHP文件,用于连接数据库并定义接口格式,代码如下: php" id="highlighter_808731">
本篇文章整理了几道Linux下C语言的经典面试题,相信对大家更好的理解Linux下的C语言会有很大的帮助,欢迎大家探讨指正。 1、如果在Linux下使用GCC编译器执行下列程序,输出结果是什么?
安装完最新的Boost库 官方说明中有一句话: Finally, $ ./b2 install will leave Boost binaries in the lib/ subdirecto
为了梳理前面学习的《spring整合mybatis(maven+mysql)一》与《spring整合mybatis(maven+mysql)二》中的内容,准备做一个完整的示例完成一个简单的图书管理功
网站内容质量仅仅是页面综合得分里面的一项.不管算法如何改变调整,搜索引擎都不会丢弃网站页面的综合得分。 一般情况下我们把页面的综合得分为8个点: 1、标题的设置 (标题的设置要有独特性)
最近事情很忙,一个新项目赶着出来,但是很多功能都要重新做,一直在编写代码、debug。今天因为一个新程序要使用fragment来做,虽然以前也使用过fragment,不过没有仔细研究,今天顺道写篇文
Android资源命名规范 最近几个月,大量涉及android资源的相关工作。对于复杂的应用而言,资源命名的规范很有必要。除了开发人员之外,UI设计人员(或者切图相关人员)也需要对资源使用的位置非常
以前一直使用Hibernate,基本上没用过Mybatis,工作中需要做映射关系,简单的了解下Mybatis的映射。 两者相差不多都支持一对一,一对多,多对多,本章简单介绍一对一的使用以及注意点。
如下所示: ? 1
如果想在自定义的View上面显示Button 等View组件需要完成如下任务 1.在自定义View的类中覆盖父类的构造(注意是2个参数的) 复制代码 代码如下: publ
实现功能:实现表格tr拖动,并保存因为拖动改变的等级. jsp代码 ?
代码:测试类 java" id="highlighter_819000"> ?
红黑树是一种二叉平衡查找树,每个结点上有一个存储位来表示结点的颜色,可以是red或black。 红黑树具有以下性质: (1) 每个结点是红色或是黑色 (2) 根结点是黑色的 (3) 如果一个
废话不多说,直接上代码 ? 1
码代码时,有时候需要根据比较大小分别赋值: ? 1
实际项目开发中,我们经常会用一些版本控制器来托管自己的代码,今天就来总结下Git的相关用法,废话不多说,直接开写。 目的:通过Git管理github托管项目代码 1、下载安装Git 1、下载
直接上代码: 复制代码 代码如下: //验证码类 class ValidateCode { private $charset = 'abcdefghkmnprstuvwxyzABC
我是一名优秀的程序员,十分优秀!