用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

php实现给上传图片加水印的程序代码

时间:2015-01-23  来源:西部数据  作者:西部数据

用PHP给上传图片加水印的程序是通过判定文件类型建立图形,然后把其复制到原建立的图形上,填充并建立rectangle,以备写入imagestring()或是原已经定好的图像程序当中判定水印类型:一是字符串,另是增加一个图形对象在上面,假如你对PHP的GD库比较熟悉,看懂这篇文章一点都不难了.

php实现给上传图片加水印的程序代码如下:

  1. <?php 
  2. /*****************************************************  
  3. 参数说明:  
  4. $max_file_size : 上传文件大小限制, 单位BYTE  
  5. $destination_folder : 上传文件路径  
  6. $watermark : 是否附加水印(1为加水印,其他为不加水印);  
  7. 使用说明:  
  8. 1. 将PHP.INI文件里面的"extension=php_gd2.dll"一行前面的;号去掉,因为我们要用到GD库;  
  9. 2. 将extension_dir =改为你的php_gd2.dll所在目录;  
  10. ****************************************************/  
  11. //上传文件类型列表  
  12. $uptypes=array(  
  13. 'image/jpg',  
  14. 'image/jpeg',  
  15. 'image/png',  
  16. 'image/pjpeg',  
  17. 'image/gif',  
  18. 'image/bmp',  
  19. 'image/x-png'  
  20. );  
  21. $max_file_size=2000000; //上传文件大小限制, 单位BYTE  
  22. $destination_folder="uploadimg/"//上传文件路径  
  23. $watermark=1; //是否附加水印(1为加水印,其他为不加水印);  
  24. $watertype=1; //水印类型(1为文字,2为图片)  
  25. $waterposition=1; //水印位置(1为左下角,2为右下角,3为左上角,4为右上角,5为居中);  
  26. $waterstring="http:///"; //水印字符串  
  27. $waterimg="xplore.gif"//水印图片  
  28. $imgpreview=1; //是否生成预览图(1为生成,其他为不生成);  
  29. $imgpreviewsize=1/2; //缩略图比例  
  30. ?>  
  31. <html>  
  32. <head>  
  33. <title>ZwelL图片上传程序</title>  
  34. <style type="text/css">  
  35. <!--  
  36. body  
  37. {  
  38. font-size: 9pt;  
  39. }  
  40. input  
  41. {  
  42. background-color: #66CCFF;  
  43. border: 1px inset #CCCCCC;  
  44. }  
  45. -->  
  46. </style>  
  47. </head>  
  48. <body>  
  49. <form enctype="multipart/form-data" method="post" name="upform">  
  50. 上传文件:  
  51. <input name="upfile" type="file">  
  52. <input type="submit" value="上传"><br>  
  53. 答应上传的文件类型为:<?=implode(', ',$uptypes)?>  
  54. </form>  
  55. <?php  
  56. if ($_SERVER['REQUEST_METHOD'] == 'POST')  
  57. {  
  58. if (!is_uploaded_file($_FILES["upfile"][tmp_name]))  
  59. //是否存在文件  
  60. {  
  61. echo "图片不存在!";  
  62. exit;  
  63. }  
  64. $file = $_FILES["upfile"];  
  65. if($max_file_size < $file["size"])  
  66. //检查文件大小  
  67. {  
  68. echo "文件太大!";  
  69. exit;  
  70. }  
  71. if(!in_array($file["type"], $uptypes))  
  72. //检查文件类型  
  73. {  
  74. echo "文件类型不符!".$file["type"];  
  75. exit;  
  76. }  
  77. if(!file_exists($destination_folder))  
  78. {  
  79. mkdir($destination_folder);  
  80. }  
  81. $filename=$file["tmp_name"];  
  82. $image_size = getimagesize($filename);  
  83. $pinfo=pathinfo($file["name"]);  
  84. $ftype=$pinfo['extension'];  
  85. $destination = $destination_folder.time().".".$ftype;  
  86. if (file_exists($destination) && $overwrite != true)  
  87. {  
  88. echo "同名文件已经存在了";  
  89. exit;  
  90. }  
  91. if(!move_uploaded_file ($filename$destination))  
  92. {  
  93. echo "移动文件出错";  
  94. exit;  
  95. }  
  96. $pinfo=pathinfo($destination);  
  97. $fname=$pinfo[basename];  
  98. echo " <font color=red>已经成功上传</font><br>文件名: <font color=blue>".$destination_folder.$fname."</font><br>";  
  99. echo " 宽度:".$image_size[0];  
  100. echo " 长度:".$image_size[1];  
  101. echo "<br> 大小:".$file["size"]." bytes";  
  102. if($watermark==1)  
  103. {  
  104. $iinfo=getimagesize($destination,$iinfo);  
  105. $nimage=imagecreatetruecolor($image_size[0],$image_size[1]);  
  106. $white=imagecolorallocate($nimage,255,255,255);  
  107. $black=imagecolorallocate($nimage,0,0,0);  
  108. $red=imagecolorallocate($nimage,255,0,0);  
  109. imagefill($nimage,0,0,$white);  
  110. switch ($iinfo[2])  
  111. {  
  112. case 1:  
  113. $simage =imagecreatefromgif($destination);  
  114. break;  
  115. case 2:  
  116. $simage =imagecreatefromjpeg($destination);  
  117. break;  
  118. case 3:  
  119. $simage =imagecreatefrompng($destination);  
  120. break;  
  121. case 6:  
  122. $simage =imagecreatefromwbmp($destination);  
  123. break;  
  124. default:  
  125. die("不支持的文件类型");  
  126. exit;  
  127. }  
  128. imagecopy($nimage,$simage,0,0,0,0,$image_size[0],$image_size[1]);  
  129. imagefilledrectangle($nimage,1,$image_size[1]-15,80,$image_size[1],$white);  
  130. switch($watertype)  
  131. {  
  132. case 1: //加水印字符串  
  133. imagestring($nimage,2,3,$image_size[1]-15,$waterstring,$black);  
  134. break;  
  135. case 2: //加水印图片  
  136. $simage1 =imagecreatefromgif("xplore.gif");  
  137. imagecopy($nimage,$simage1,0,0,0,0,85,15);  
  138. imagedestroy($simage1);  
  139. break;  
  140. }  
  141. switch ($iinfo[2])  
  142.  
  143. {  
  144. case 1:  
  145. //imagegif($nimage, $destination);  
  146. imagejpeg($nimage$destination);  
  147. break;  
  148. case 2:  
  149. imagejpeg($nimage$destination);  
  150. break;  
  151. case 3:  
  152. imagepng($nimage$destination);  
  153. break;  
  154. case 6:  
  155. imagewbmp($nimage$destination);  
  156. //imagejpeg($nimage, $destination);  
  157. break;  
  158. }  
  159. //覆盖原上传文件  
  160. imagedestroy($nimage);  
  161. imagedestroy($simage);  
  162. }  
  163. if($imgpreview==1)  
  164. {  
  165. echo "<br>图片预览:<br>";  
  166. echo "<img src="".$destination."" width=".($image_size[0]*$imgpreviewsize)." height=".($image_size[1]*$imgpreviewsize);  
  167. echo " alt="图片预览: 文件名:".$destination." 上传时间:">";  
  168. }  
  169. }  
  170. ?>  
  171. </body>  
  172. </html> 
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
    无相关信息
栏目更新
栏目热门