Protect your photos and videos with watermarks using php
It is possible to watermark photos and files embedded in your content without modifying the originals. One scenario is displaying photos from your server or photo server with different watermarks.
In the past, watermarked content required editing original photos and videos to change watermarks. The process of editing photos and videos to add watermarks becomes tedious when changes are required or different content is separated into different categories.
Using a simple php script to serve all your embedded content simplifies the process of adding custom watermarks because the only change required is modifying the watermark in the php file.
Tools Required:
Text editor for creating and modifying the php script and permissions
Web server such as apache
Php installed on your web server
Knowledge of the files to be served.
Php file
<?php /* * my_image_watermark.php * * Copyright 2010 edward <http://ojambo.com> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, * MA 02110-1301, USA. * * USAGE: * /my_image_watermark.php?fileName=myfile.jpg * chmod 644 for directory */ $fileName = basename(urldecode($_GET["fileName"])); $watermarkText = "Ojambo.com watermarked text"; $fileDir = "../images/"; //relative is best "../" // Make sure file exists if (file_exists($fileDir . $fileName)) { // Create the image $watermarkImage = imagecreatefrompng($fileDir . $fileName); // Create color alpha goes from 0 to 127 $grey = imagecolorallocatealpha($watermarkImage, 128, 128, 128, 75); // Coordinates of the text $px = (imagesx($watermarkImage) - 7.5 * strlen($watermarkText)) / 2; // Add the text imagestring($watermarkImage, 3, $px, 9, $watermarkText, $grey); // Set the content-type png gives better text header("Content-type: image/png"); // Using imagepng() results in clearer text imagepng($watermarkImage); imagedestroy($watermarkImage); } ?>
The beginning of the file after the php tag shows comments on its usage. $fileName is the name of the file that is sent as a server request. $fileDir is the location of the files. The location can be changed to be outside the webroot. It is possible to use absolute paths, but relative paths are best for added security.
Next, check whether the file exists. If the file exists create a png file. Create the watermark colour. Create the text coordinates. Add the text to the created png. Php requires a header in order to display files on the web server. The Content-Type will be for the png file. The file is displayed using imagepng, and then will be destroyed.
Create a folder called images and place it anywhere on your server or on in a remote location, be sure to edit the $fileDir in the php file. The process of creating a permissions file was discussed for the Ojambo.com image proxy article.
Watermarked image
How to use
Usage:
<a href="my_image_watermark.php?fileName=photo.jpg">My Photo File </a>
Recommendations:
All files should have their permissions set to 644 or read only. This post will be updated as new technology emerges especially php and apache.