imagemagick — Как сделать снимок экрана с URL-адресом или URL-адресом PNG на сервере Share Hosting с помощью переполнения стека

Я получаю проблему с снимком экрана URL с помощью PHP

Я старался ImageMagick со следующим кодом.
Но не знаю, как я могу его использовать.

import -window root images/my1.png

Я заменил корень на «мой URL»

Я запускаю выше команды, используя Exec в PHP, но это не дает мне никакого вывода.

Может ли кто-нибудь дать мне какие-либо предложения по этому вопросу.

Я был бы вам очень благодарен за это.

Благодарю.

-1

Решение

Попробуйте использовать webkit2png или подобное, как это:

webkit2png http:/google.com -o grab

который даст вам эти файлы:

-rw-r--r--   1 mark  staff     14754 30 Sep 18:46 grab-thumb.png
-rw-r--r--   1 mark  staff     68830 30 Sep 18:46 grab-full.png
-rw-r--r--   1 mark  staff     13552 30 Sep 18:46 grab-clipped.png

введите описание изображения здесь

0

Другие решения

Вам не нужно использовать ImageMagick сейчас. Другой способ сделать снимок экрана с помощью PHP без каких-либо дополнительных ресурсов сервера — использовать Google API PageSpeed ​​Insights, который не требует какой-либо аутентификации. Это бесплатно и открыто прямо сейчас, так что воспользуйтесь им.

Детали реализации для того же здесь: Создание скриншотов URL с использованием секретного магического API Google.

Исходный код

<?php
// Creating a proxy to use GET request to hit the Google Page Speed API and receive a screenshot.
// Check if the URL parameter for our proxy is set.
if (!empty($_GET['url'])) {
// Make sure the given value is a URL.
if (filter_var($_GET['url'], FILTER_VALIDATE_URL)) {
// Hit the Google PageSpeed Insights API.
// Catch: Your server needs to allow file_get_contents() to make this run. Or you need to use cURL.
$googlePagespeedResponse = file_get_contents("https://www.googleapis.com/pagespeedonline/v2/runPagespeed?screenshot=true&url={$_GET['url']}");

// Convert the JSON response into an array.
$googlePagespeedObject = json_decode($googlePagespeedResponse, true);

// Grab the Screenshot data.
$screenshot = $googlePagespeedObject['screenshot']['data'];
// Replace Google's anamolies.
$screenshot = str_replace(array('_','-'), array('/','+'), $screenshot);

// Build the Data URI scheme and spit out an <img /> Tag.
echo "<img src=\"data:image/jpeg;base64,{$screenshot}\" alt=\"Screenshot\" />";
} else {
// If not a valid URL.
echo "Given URL is not valid.";
}
} else {
// URL not set.
echo "You need to specify the URL.";
}
?>

Вы также можете сделать это с помощью Client Side:

$(function () {
// Get the URL.
var url = "https://praveen.science/";
// Prepare the URL.
url = encodeURIComponent(url);
// Hit the Google Page Speed API.
$.get("https://www.googleapis.com/pagespeedonline/v1/runPagespeed?screenshot=true&strategy=mobile&url=" + url, function (data) {
// Get the screenshot data.
var screenshot = data.screenshot;
// Convert the Google's Data to Data URI scheme.
var imageData = screenshot.data.replace(/_/g, "/").replace(/-/g, "+");
// Build the Data URI.
var dataURI = "data:" + screenshot.mime_type + ";base64," + imageData;
// Set the image's source.
$("img").attr("src", dataURI);
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<h1>Hard Coded Screenshot of my Website:</h1>
<img src="//placehold.it/300x50?text=Loading+Screenshot..." alt="Screenshot" />
0

По вопросам рекламы [email protected]