In web development, it is often necessary to convert HTML pages into images for functions such as generating verification codes and email screenshots. As a very popular server scripting language, PHP can also convert HTML to images. This article will explain how to use PHP to convert HTML pages into images.
Before introducing the specific implementation, let’s briefly understand the principle of converting HTML to pictures. A common way is to use a third-party library to render the HTML page into an image, and then output the image to the browser or save it as a file.
PHP does not natively support converting HTML into images and needs to rely on third-party extensions. Among the more popular ones are wkhtmltoimage
, dompdf
, phantomjs
, etc.
Taking wkhtmltoimage
as an example, you need to install the wkhtmltox
library on the server first.
sudo apt-get update sudo apt-get install wkhtmltopdf
Then install the PHP extension php-wkhtmltox
.
sudo apt-get install php-wkhtmltox
wkhtmltoimage
extensionAfter installing the wkhtmltoimage
extension, you can use the following code to convert the HTML page into pictures.
<?php $command = 'wkhtmltoimage http://www.baidu.com ./baidu.jpg'; $result = shell_exec($command);
In the above code, the wkhtmltoimage
command renders the http://www.baidu.com
page into an image and saves it as ./baidu. jpg
file.
In addition to converting images from web addresses, you can also convert local HTML files into images:
<?php $command = 'wkhtmltoimage ./local.html ./local.jpg'; $result = shell_exec($command);
dompdf
extensiondompdf
is a PHP extension that converts HTML to PDF. It can also convert HTML to images.
Install the dompdf
extension.
composer require dompdf/dompdf
Use the following code to convert HTML pages into images.
<?php use Dompdf\Dompdf; $html = file_get_contents('http://www.baidu.com'); $dompdf = new Dompdf(); $dompdf->loadHtml($html); $dompdf->render(); $file = './baidu.png'; file_put_contents($file, $dompdf->output());
In the above code, use file_get_contents
to get the page HTML content, and then use Dompdf
to render it into an image on the server side and save it locally.
phantomjs
Extension Similar to dompdf
, phantomjs
is also a tool that can convert HTML pages into Tools for rendering into images. Install the phantomjs
library.
sudo apt-get install phantomjs
Then use the following code to convert the HTML page into an image.
<?php $html = file_get_contents('http://www.baidu.com'); $command = 'phantomjs rasterize.js ' . escapeshellarg($html) . ' ./baidu.png 800px*600px'; $result = shell_exec($command);
In the above code, the phantomjs
command uses the rasterize.js
script to complete page rendering. Among them, the first parameter is the HTML content to be rendered, the second parameter is the output file, and the third parameter is the size of the output image.
This article describes how to use PHP to convert HTML pages into images. We can use extensions such as wkhtmltoimage
, dompdf
or phantomjs
to achieve this functionality. When using different extensions, you also need to pay attention to the installation of its dependent environment and the use of related libraries.
The above is the detailed content of How to convert HTML pages into images using PHP. For more information, please follow other related articles on the PHP Chinese website!