如何使用 Canvas 显示 JavaScript 对象?
How can I display a JavaScript Object with Canvas?
我有一个新项目,我正在构建一个全新的网站。
现在我想做我自己的验证码。为此,我使用 hertzen.
中的 html2canvas 库
到目前为止,还不错。我可以将主页上的固定节点转换为图像 return。但是我现在要做的是创建一种带有 JavaScript 和 return 的“假”节点作为图像。
这是我尝试过的:
image_string = getCaptchaCheck_code(image_string).split("\"");
image_string = image_string[3];
image_string = getCaptchaCheck_code(image_string)
let fakeObject = '<div id="talltweets">'+image_string+'</div>';
let temp = document.createElement('div');
temp.innerHTML = fakeObject;
let htmlObject = temp.firstChild;
html2canvas(htmlObject, {
onrendered: function (canvas) {
var screenshot = canvas.toDataURL("image/jpg");
document.getElementById("textScreenshot").setAttribute("src", screenshot);
captcha = document.getElementById("textScreenshot").value;
},
});
function getCaptchaCheck_code(str) {
return decodeURIComponent(escape(this.atob(str)));
}
我的 trie 的实际结果是 empty picture。
如果需要,这里是 image_string 变量:
let image_string = "eyIxIjoiUEhVK2N6d3ZkVDQ4YVQ1YVBDOXBQanhwUGpVOEwyaytjenhpUGpROEwySStORHhwUGpROEwyaytWenhpUGpNOEwySSsifQ==";
我有来自 here 的 HTML2Canvas 的原件。
所以你可以看到预期的功能。
如果有人能帮助我,我会很高兴。
我自己解决了
首先,我需要在元素值中拆分 image_string
。这是必需的,因为 image_string
是一个完整的字符串类型。然后将值依次写入数组进行迭代。
let image_string = "eyIxIjoiUEdJK1pUd3ZZajQ4ZFQ1UlBDOTFQanhwUGtVOEwyaytQSFUrZVR3dmRUNTBRVHgxUGpBOEwzVStQR2srZUR3dmFUNDhkVDVZUEM5MVBnPT0ifQ==";
image_string = getCaptchaCheck_code(image_string).split("\"");
image_string = image_string[3];
image_string = getCaptchaCheck_code(image_string)
var nodeText = ""+image_string+""
var newDiv = document.createElement("div");
newDiv.setAttribute('id', 'talltweets')
var childDiv = document.createElement("div");
var regex = /([<][\/][a-zA-Z0-9][>])/gm;
var newstr = nodeText.replace(regex, " ")
regex = /([<][a-zA-Z0-9][>])/gm;
newstr = newstr.replace(regex, "")
var letter = newstr.split(' ');
在迭代中我创建新的子节点并将它们写在一起。
for (var i = 0; i < letter.length; i++) {
var node = nodeText[nodeText.indexOf(letter[i])-2];
childNode = document.createElement(node);
childNodeText= document.createTextNode(letter[i]);
childNode.appendChild(childNodeText);
newDiv.appendChild(childNode);
}
迭代后,我在我的 HTML 文件中创建了一个占位符 div 容器。
现在需要填写占位符。
const placeholderElement = document.getElementById("eyIxI");
placeholderElement.appendChild(newDiv);
我还向上拉了 getCaptchaCheck_code
函数以确保它在 html2canvas
函数之前加载。
function getCaptchaCheck_code(str) {
return decodeURIComponent(escape(this.atob(str)));
}
html2canvas(document.getElementById("talltweets"), {
onrendered: function (canvas) {
var screenshot = canvas.toDataURL("image/png");
document.getElementById("textScreenshot").setAttribute("src", screenshot);
placeholderElement.removeChild(newDiv);
},
});
如您在最后一段代码中所见,placeholderElement
将删除“验证码文本”。
代码现在 100% 有效。
尽情享受吧。
我有一个新项目,我正在构建一个全新的网站。
现在我想做我自己的验证码。为此,我使用 hertzen.
中的 html2canvas 库到目前为止,还不错。我可以将主页上的固定节点转换为图像 return。但是我现在要做的是创建一种带有 JavaScript 和 return 的“假”节点作为图像。
这是我尝试过的:
image_string = getCaptchaCheck_code(image_string).split("\"");
image_string = image_string[3];
image_string = getCaptchaCheck_code(image_string)
let fakeObject = '<div id="talltweets">'+image_string+'</div>';
let temp = document.createElement('div');
temp.innerHTML = fakeObject;
let htmlObject = temp.firstChild;
html2canvas(htmlObject, {
onrendered: function (canvas) {
var screenshot = canvas.toDataURL("image/jpg");
document.getElementById("textScreenshot").setAttribute("src", screenshot);
captcha = document.getElementById("textScreenshot").value;
},
});
function getCaptchaCheck_code(str) {
return decodeURIComponent(escape(this.atob(str)));
}
我的 trie 的实际结果是 empty picture。
如果需要,这里是 image_string 变量:
let image_string = "eyIxIjoiUEhVK2N6d3ZkVDQ4YVQ1YVBDOXBQanhwUGpVOEwyaytjenhpUGpROEwySStORHhwUGpROEwyaytWenhpUGpNOEwySSsifQ==";
我有来自 here 的 HTML2Canvas 的原件。
所以你可以看到预期的功能。
如果有人能帮助我,我会很高兴。
我自己解决了
首先,我需要在元素值中拆分 image_string
。这是必需的,因为 image_string
是一个完整的字符串类型。然后将值依次写入数组进行迭代。
let image_string = "eyIxIjoiUEdJK1pUd3ZZajQ4ZFQ1UlBDOTFQanhwUGtVOEwyaytQSFUrZVR3dmRUNTBRVHgxUGpBOEwzVStQR2srZUR3dmFUNDhkVDVZUEM5MVBnPT0ifQ==";
image_string = getCaptchaCheck_code(image_string).split("\"");
image_string = image_string[3];
image_string = getCaptchaCheck_code(image_string)
var nodeText = ""+image_string+""
var newDiv = document.createElement("div");
newDiv.setAttribute('id', 'talltweets')
var childDiv = document.createElement("div");
var regex = /([<][\/][a-zA-Z0-9][>])/gm;
var newstr = nodeText.replace(regex, " ")
regex = /([<][a-zA-Z0-9][>])/gm;
newstr = newstr.replace(regex, "")
var letter = newstr.split(' ');
在迭代中我创建新的子节点并将它们写在一起。
for (var i = 0; i < letter.length; i++) {
var node = nodeText[nodeText.indexOf(letter[i])-2];
childNode = document.createElement(node);
childNodeText= document.createTextNode(letter[i]);
childNode.appendChild(childNodeText);
newDiv.appendChild(childNode);
}
迭代后,我在我的 HTML 文件中创建了一个占位符 div 容器。 现在需要填写占位符。
const placeholderElement = document.getElementById("eyIxI");
placeholderElement.appendChild(newDiv);
我还向上拉了 getCaptchaCheck_code
函数以确保它在 html2canvas
函数之前加载。
function getCaptchaCheck_code(str) {
return decodeURIComponent(escape(this.atob(str)));
}
html2canvas(document.getElementById("talltweets"), {
onrendered: function (canvas) {
var screenshot = canvas.toDataURL("image/png");
document.getElementById("textScreenshot").setAttribute("src", screenshot);
placeholderElement.removeChild(newDiv);
},
});
如您在最后一段代码中所见,placeholderElement
将删除“验证码文本”。
代码现在 100% 有效。
尽情享受吧。