何時間もの調査の後、origin-clean
FLAGが設定されていても(XSSを防止するため)、要素のスクリーンショットを撮るソリューションがようやく見つかりました。そのため、たとえばGoogleマップ(私の場合)をキャプチャすることもできます。スクリーンショットを取得するためのユニバーサル関数を作成しました。さらに必要なのは、html2canvasライブラリ(https://html2canvas.hertzen.com/)だけです。
例:
getScreenshotOfElement($("div#toBeCaptured").get(0), 0, 0, 100, 100, function(data) {
// in the data variable there is the base64 image
// exmaple for displaying the image in an <img>
$("img#captured").attr("src", "data:image/png;base64,"+data);
});
心に留めておくconsole.log()
と、alert()
画像のサイズが大きい場合は出力を生成won't。
関数:
function getScreenshotOfElement(element, posX, posY, width, height, callback) {
html2canvas(element, {
onrendered: function (canvas) {
var context = canvas.getContext('2d');
var imageData = context.getImageData(posX, posY, width, height).data;
var outputCanvas = document.createElement('canvas');
var outputContext = outputCanvas.getContext('2d');
outputCanvas.width = width;
outputCanvas.height = height;
var idata = outputContext.createImageData(width, height);
idata.data.set(imageData);
outputContext.putImageData(idata, 0, 0);
callback(outputCanvas.toDataURL().replace("data:image/png;base64,", ""));
},
width: width,
height: height,
useCORS: true,
taintTest: false,
allowTaint: false
});
}