html2canvas 的正确代理脚本

And*_*wby 1 html2canvas

我正在尝试让html2render ( http://html2canvas.hertzen.com/ ) 在我的网站上工作。它适用于基本内容 - 但没有任何图像显示(因为它们位于 cdn.domain.com 子域上)。

我一直在阅读,似乎它不喜欢开箱即用的其他域。我找到了几个 PHP 代理脚本:

我试图让这些继续下去,但我们没有在此服务器上启用curl 。所以,我打算用 Perl 写一些东西。

这是我到目前为止所得到的:

use MIME::Base64;
use File::Slurp;

handle();

sub handle {

    print ('Access-Control-Max-Age:' . 5 * 60 * 1000);
    print ("Access-Control-Allow-Origin: *");
    print ('Access-Control-Request-Method: *');
    print ('Access-Control-Allow-Methods: OPTIONS, GET');
    print ('Access-Control-Allow-Headers *');
    print ("Content-Type: application/javascript");

    #print $IN->header;

    my $url = $IN->param('url');

    $url =~ s|https://cdn.xxx.net|/srv/www/xxx.net/www|g;

    if (-e $url) {

        my $file = read_file($url);

        use JSON;

        my $mime_type;
        if ($url =~ /\.jpe?g$/i) {
            $mime_type = "image/jpg"
        } elsif ($url =~ /\.png$/i) {
            $mime_type = "image/png"
        }
        print JSON::encode_json([{
            "pathinfo" => $url,
            "error" => undef,
            "data" => encode_base64($file),
            "mime_type" => $mime_type
        }]);
    } else {
        print "ACK!";
    }

}
Run Code Online (Sandbox Code Playgroud)

但是,它仍然不起作用:( 关于代理的文档很少(没有?)(除了告诉您在某些情况下需要它!)

谁能分享输出的数据应该是什么样子?我尝试根据上面的示例代码来解决这个问题,但是我的 PHP 有点生疏(而且我没有启用 PHP 和 Curl 的服务器,我可以在上面进行测试)

谢谢!

And*_*wby 5

好吧,关于代理的答案不是很多 - 但我确实遇到了一篇文章:

S3 和 CloudFront 中具有 CORS 的 HTML2Canvas

在这里,显示了使用的示例:

 useCORS: true,
Run Code Online (Sandbox Code Playgroud)

...所以我尝试了:

html2canvas(document.body, {
  useCORS: true,
  onrendered: function(canvas) {

  }
});                    
Run Code Online (Sandbox Code Playgroud)

...它有效!

在我的例子中,我只是使用domain.com和cdn.domain.com作为CDN。如果您使用其他第 3 方 CDN,您可能需要考虑启用 COR 标头。