JavaScript を使用して Web ページのスクリーンショットを撮り、それをサーバーに送信することはできますか?
私はブラウザのセキュリティの問題についてはあまり気にしていません。など、実装はHTA用です。しかし、それは可能ですか?
JavaScript を使用して Web ページのスクリーンショットを撮り、それをサーバーに送信することはできますか?
私はブラウザのセキュリティの問題についてはあまり気にしていません。など、実装はHTA用です。しかし、それは可能ですか?
Google はこれを Google+ で行っており、有能な開発者がリバース エンジニアリングを行い、http://html2canvas.hertzen.com/を作成しました。IE で作業するには、 http://excanvas.sourceforge.net/などのキャンバス サポート ライブラリが必要です。
ActiveX コントロールを使用して、HTA に対してこれを行いました。VB6 でコントロールを作成してスクリーンショットを撮るのは非常に簡単でした。SendKeys は PrintScreen を実行できないため、keybd_event API 呼び出しを使用する必要がありました。そのためのコードは次のとおりです。
Declare Sub keybd_event Lib "user32" _
(ByVal bVk As Byte, ByVal bScan As Byte, ByVal dwFlags As Long, ByVal dwExtraInfo As Long)
Public Const CaptWindow = 2
Public Sub ScreenGrab()
keybd_event &H12, 0, 0, 0
keybd_event &H2C, CaptWindow, 0, 0
keybd_event &H2C, CaptWindow, &H2, 0
keybd_event &H12, 0, &H2, 0
End Sub
それは、ウィンドウをクリップボードに入れることだけです。
別のオプションとして、スクリーンショットが必要なウィンドウが HTA の場合は、XMLHTTPRequest を使用して DOM ノードをサーバーに送信し、サーバー側でスクリーンショットを作成します。
私が発見した別の可能な解決策はhttp://www.phantomjs.org/で、ページのスクリーンショットなどを非常に簡単に撮ることができます。この質問に対する私の最初の要件はもはや有効ではありませんが (別の仕事)、PhantomJS を将来のプロジェクトに統合する可能性があります。
これが可能な場合は、ボディ要素全体をキャンバスに設定してから canvas2image を使用しますか?
これを行うには、Windows で実行していて .NET がインストールされている場合、次の方法があります。
public Bitmap GenerateScreenshot(string url)
{
// This method gets a screenshot of the webpage
// rendered at its full size (height and width)
return GenerateScreenshot(url, -1, -1);
}
public Bitmap GenerateScreenshot(string url, int width, int height)
{
// Load the webpage into a WebBrowser control
WebBrowser wb = new WebBrowser();
wb.ScrollBarsEnabled = false;
wb.ScriptErrorsSuppressed = true;
wb.Navigate(url);
while (wb.ReadyState != WebBrowserReadyState.Complete) { Application.DoEvents(); }
// Set the size of the WebBrowser control
wb.Width = width;
wb.Height = height;
if (width == -1)
{
// Take Screenshot of the web pages full width
wb.Width = wb.Document.Body.ScrollRectangle.Width;
}
if (height == -1)
{
// Take Screenshot of the web pages full height
wb.Height = wb.Document.Body.ScrollRectangle.Height;
}
// Get a Bitmap representation of the webpage as it's rendered in the WebBrowser control
Bitmap bitmap = new Bitmap(wb.Width, wb.Height);
wb.DrawToBitmap(bitmap, new Rectangle(0, 0, wb.Width, wb.Height));
wb.Dispose();
return bitmap;
}
そして、PHPを介して次のことができます:
exec("CreateScreenShot.exe -url http://.... -save C:/shots domain_page.png");
次に、サーバー側にスクリーンショットがあります。
これはあなたにとって理想的な解決策ではないかもしれませんが、それでも言及する価値があるかもしれません。
Snapsieは、 InternetExplorerのスクリーンショットをキャプチャして保存できるオープンソースのActiveXオブジェクトです。DLLファイルがクライアントに登録されると、スクリーンショットをキャプチャして、JavaScriptを使用してファイルをサーバーにアップロードできるようになります。欠点:DLLファイルをクライアントに登録する必要があり、InternetExplorerでのみ機能します。
バグの報告についても同様の要件がありました。これはイントラネット シナリオ用だったので、ブラウザー アドオン ( FirefoxのFireshotや Internet Explorer のIE Screenshotなど) を使用することができました。
SnapEngageは、Java アプレット(1.5+) を使用してブラウザのスクリーンショットを作成します。私の知る限り、仕事をする必要があります-ユーザーはアプレットにそれを許可するだけです(1回)。java.awt.Robot
そして、私はそれについての投稿を見つけました:
これは、HTA とVBScriptを使用して実現できます。スクリーンショットを作成するには、外部ツールを呼び出すだけです。名前は忘れましたが、Windows Vista にはスクリーンショットを作成するツールがあります。追加のインストールは必要ありません。
自動に関しては、使用するツールに完全に依存します。API があれば、何回か Visual Basic を呼び出すだけで、ユーザーが何をしたかを知らなくても、スクリーンショットと保存プロセスをトリガーできると確信しています。
HTA について言及されたので、Windows を使用していて、(おそらく) 環境 (OS やバージョンなど) をよく知っていると思います。
私は、rasterizeHTML を使用してページ コンテンツを含む svg および/または画像を作成する単純な関数を作成しました。
見てみな :
Javascript でスクリーンショットを撮るための優れたソリューションは、https://grabz.itのものです。
それらには、あらゆるタイプの JS アプリケーションで使用できる、柔軟で使いやすいスクリーンショット API があります。
試してみたい方は、まずは認可アプリのキー+シークレットと無料のSDKを入手してください
次に、アプリでの実装手順は次のようになります。
// include the grabzit.min.js library in the web page you want the capture to appear
<script src="grabzit.min.js"></script>
//use the key and the secret to login, capture the url
<script>
GrabzIt("KEY", "SECRET").ConvertURL("http://www.google.com").Create();
</script>
スクリーンショットは、さまざまなパラメーターでカスタマイズできます。例えば:
GrabzIt("KEY", "SECRET").ConvertURL("http://www.google.com",
{"width": 400, "height": 400, "format": "png", "delay", 10000}).Create();
</script>
それで全部です。次に、少し待つだけで、ページをリロードする必要なく、ページの下部に画像が自動的に表示されます。
スクリーンショット メカニズムには、ここで調べることができる他の機能があります。
スクリーンショットをローカルに保存することもできます。そのためには、GrabzIt サーバー側 API を利用する必要があります。詳細については、こちらの詳細なガイドを確認してください。