几乎考虑到了每个细节的php图片上传

  1. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  2. <?php
  3. /******************************************************************************
  4. 参数说明:
  5. $max_file_size  : 上传文件大小限制, 单位BYTE
  6. $destination_folder : 上传文件路径
  7. $watermark   : 是否附加水印(1为加水印,其他为不加水印);
  8. 使用说明:
  9. 1. 将PHP.INI文件里面的"extension=php_gd2.dll"一行前面的;号去掉,因为我们要用到GD库;
  10. 2. 将extension_dir =改为你的php_gd2.dll所在目录;
  11. ******************************************************************************/
  12. //上传文件类型列表
  13. $uptypes=array(
  14. ‘image/jpg‘,
  15. ‘image/jpeg‘,
  16. ‘image/png‘,
  17. ‘image/pjpeg‘,
  18. ‘image/gif‘,
  19. ‘image/bmp‘,
  20. ‘image/x-png‘
  21. );
  22. $max_file_size=2000000;     //上传文件大小限制, 单位BYTE
  23. $destination_folder="uploadimg/"; //上传文件路径
  24. $watermark=1;      //是否附加水印(1为加水印,其他为不加水印);
  25. $watertype=1;      //水印类型(1为文字,2为图片)
  26. $waterposition=1;     //水印位置(1为左下角,2为右下角,3为左上角,4为右上角,5为居中);
  27. $waterstring="http://www.xplore.cn/";  //水印字符串
  28. $waterimg="xplore.gif";    //水印图片
  29. $imgpreview=1;      //是否生成预览图(1为生成,其他为不生成);
  30. $imgpreviewsize=1/2;    //缩略图比例
  31. ?>
  32. <html>
  33. <head>
  34. <title>ZwelL图片上传程序</title>
  35. <style type="text/css">
  36. <!--
  37. body
  38. {
  39. font-size: 9pt;
  40. }
  41. input
  42. {
  43. background-color: #66CCFF;
  44. border: 1px inset #CCCCCC;
  45. }
  46. -->
  47. </style>
  48. </head>
  49. <body>
  50. <form enctype="multipart/form-data" method="post" name="upform">
  51. 上传文件:
  52. <input name="upfile" type="file">
  53. <input type="submit" value="上传"><br>
  54. 允许上传的文件类型为:<?=implode(‘, ‘,$uptypes)?>
  55. </form>
  56. <?php
  57. if ($_SERVER[‘REQUEST_METHOD‘] == ‘POST‘)
  58. {
  59. if (!is_uploaded_file($_FILES["upfile"][tmp_name]))
  60. //是否存在文件
  61. {
  62. echo "图片不存在!";
  63. exit;
  64. }
  65. $file = $_FILES["upfile"];
  66. if($max_file_size < $file["size"])
  67. //检查文件大小
  68. {
  69. echo "文件太大!";
  70. exit;
  71. }
  72. if(!in_array($file["type"], $uptypes))
  73. //检查文件类型
  74. {
  75. echo "文件类型不符!".$file["type"];
  76. exit;
  77. }
  78. if(!file_exists($destination_folder))
  79. {
  80. mkdir($destination_folder);
  81. }
  82. $filename=$file["tmp_name"];
  83. $image_size = getimagesize($filename);
  84. $pinfo=pathinfo($file["name"]);
  85. $ftype=$pinfo[‘extension‘];
  86. $destination = $destination_folder.time().".".$ftype;
  87. if (file_exists($destination) && $overwrite != true)
  88. {
  89. echo "同名文件已经存在了";
  90. exit;
  91. }
  92. if(!move_uploaded_file ($filename, $destination))
  93. {
  94. echo "移动文件出错";
  95. exit;
  96. }
  97. $pinfo=pathinfo($destination);
  98. $fname=$pinfo[basename];
  99. echo " <font color=red>已经成功上传</font><br>文件名:  <font color=blue>".$destination_folder.$fname."</font><br>";
  100. echo " 宽度:".$image_size[0];
  101. echo " 长度:".$image_size[1];
  102. echo "<br> 大小:".$file["size"]." bytes";
  103. if($watermark==1)
  104. {
  105. $iinfo=getimagesize($destination,$iinfo);
  106. $nimage=imagecreatetruecolor($image_size[0],$image_size[1]);
  107. $white=imagecolorallocate($nimage,255,255,255);
  108. $black=imagecolorallocate($nimage,0,0,0);
  109. $red=imagecolorallocate($nimage,255,0,0);
  110. imagefill($nimage,0,0,$white);
  111. switch ($iinfo[2])
  112. {
  113. case 1:
  114. $simage =imagecreatefromgif($destination);
  115. break;
  116. case 2:
  117. $simage =imagecreatefromjpeg($destination);
  118. break;
  119. case 3:
  120. $simage =imagecreatefrompng($destination);
  121. break;
  122. case 6:
  123. $simage =imagecreatefromwbmp($destination);
  124. break;
  125. default:
  126. die("不支持的文件类型");
  127. exit;
  128. }
  129. imagecopy($nimage,$simage,0,0,0,0,$image_size[0],$image_size[1]);
  130. imagefilledrectangle($nimage,1,$image_size[1]-15,80,$image_size[1],$white);
  131. switch($watertype)
  132. {
  133. case 1:   //加水印字符串
  134. imagestring($nimage,2,3,$image_size[1]-15,$waterstring,$black);
  135. break;
  136. case 2:   //加水印图片
  137. $simage1 =imagecreatefromgif("xplore.gif");
  138. imagecopy($nimage,$simage1,0,0,0,0,85,15);
  139. imagedestroy($simage1);
  140. break;
  141. }
  142. switch ($iinfo[2])
  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=\"图片预览:\r文件名:".$destination."\r上传时间:\">";
  168. }
  169. }
  170. ?>
  171. </body>
  172. </html>
时间: 2025-01-02 09:59:28

几乎考虑到了每个细节的php图片上传的相关文章

PHP图片上传程序(完整版)

从PHP100上搜刮来的,功能很强大.几乎考虑到了每个细节,与大家分享!~~~ <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <?php /****************************************************************************** 参数说明: $max_file_size : 上传文件大小限

jq upload图片上传代码

/* * 图片上传 * */ function postImgData() { $("#addFileInfo input[name='file']").change(function () { console.log($(this).val()) if (!$(this).val()) { return } var fileTyle = $(this).val().split("."); console.log(fileTyle); if (fileTyle[1]

[项目构建 五]babasport ajax图片上传及FastDFS入门案例.

今天来开始写图片上传的功能, 现在的图片上传都讲求 上传完成后立刻回显且页面不刷新, 这里到底是怎么做的呢? 当然是借助于ajax了, 但是ajax又不能提交表单, 这里我们还要借助一个插件: jquery.form.js剩下的一个是FastDFS, 那么什么是FastDFS呢? FastDFS是一个开源的轻量级分布式文件系统,由跟踪服务器(tracker server).存储服务器(storage server)和客户端(client)三个部分组成,主要解决了海量数据存储问题,特别适合以中小文

ckeditor4.5.1配置图片上传的方法

本篇博文主要面向初学者,一步一步地实现ckeditor的图片上传,欢迎各位大神指正. ckeditor的图片上传默认是关闭的,网上也有很多相关的教程,可是不是讲的不完整,就是版本太旧已经不适用.我写这篇博文主要面向初学者,有错误的地方欢迎指正. 截止本文撰写,ckeditor最新版本是4.5.1,我下载的版本是4.5.1standard,如果本文的方法不管用,请下载同一版本尝试. 1.开启图片上传界面 文件地址:ckeditor/plugins/image/dialogs/image.js 搜索

数往知来 JQuery 图片上传_水印 &lt;二十二&gt;

一.图片上传  :enctype='multipart/form-date 首先在进行文件上传时,添加form表单中的enctype属性指定enctype='multipart/form-date', 文件数据发送给服务端,并不是把文件路径发送给服务端了,它会随机生成一个分割字符串, 把每一个表单元素分割开 <form method='post' action='' enctype='multipart/form-date'> //这里的enctype是提交请求报文的报文体的一种编码格式, 默

微信端调取相册和摄像头,实现图片上传,并上传到本地服务器

在微信公众号网页开发时,遇到了图片上传的问题,查看了微信的开发者文档,里面的资料比较全.接着我们看一下整个的流程 1.config权限配置 $.ajax({ url:'wx_getConfig', type:'get', dataType:'json', async:false, success:function(data){ var appId = data[0].appId; var timestamp = data[0].timestamp; var nonceStr = data[0].

java图片上传(mvc)

最近有开始学起了java,好久没写文章了,好久没来博客园了.最近看了看博客园上次写的图片上传有很多人看,今天在一些篇关于java图片上传的.后台接收用的是mvc.不墨迹了,直接上图. 先看目录结构.idea开发. 一.图片上传还是使用的这款jq插件.前端部署这款插件,不用说了吧.效果图       二.前台代码只需要盖一个位置.因为是比较好用的插件.插件样式自行修改. 三.后台代码. 后面看不见的. 这个图片上传主要是自己写了几个函数.让图片储存更加方便.分成了年月日储存.但是后期遍历比较困难,

.net core CKEditor 图片上传

最近在玩 asp.net core,不想用UEditor,想使用CKEditor.故需要图片上传功能. 废话不多说,先上效果图: CKEditor 前端代码: <text id="content" name="content"></text> <script> CKEDITOR.replace('content'); </script> CKeditor config.js 配置代码:需要配置图片上传路径 CKEDIT

微信JS-SDK接口 + FLASK实现图片上传

最近在做一个项目从全球各地采集图片,考虑采用微信JS-SDK来简化开发.图片会首先上传到微信的服务器,返回一个id,然后根据这个id去微信服务器获取图片.微信提供可选择的压缩图片功能.图片首先上传到微信的服务器,可以保障较好的上传稳定性. 详细内容请参考微信的官方文档:微信JS-SDK说明文档 运行页面如下 HTML 在微信demo的基础上修改,见微信JS-SDK DEMO页面 增加图片的多次选择,多次上传,删除等功能 uploadImage.html <!DOCTYPE html> <