cari
Rumahpembangunan bahagian belakangtutorial php分享一个PHP文件上传类

  1. //-------------------------------------
  2. // 文件说明:文件上传处理类
  3. // 文件作者:Jesse Lee
  4. // 作者主页:http://bbs.it-home.org
  5. // 最后更新:2011-5-14
  6. //-------------------------------------
  7. class upload {
  8. var $dir; //附件存放物理目录
  9. var $time; //自定义文件上传时间
  10. var $allow_types; //允许上传附件类型
  11. var $field; //上传控件名称
  12. var $maxsize; //最大允许文件大小,单位为KB
  13. var $thumb_width; //缩略图宽度
  14. var $thumb_height; //缩略图高度
  15. var $watermark_file; //水印图片地址
  16. var $watermark_pos; //水印位置
  17. var $watermark_trans;//水印透明度
  18. //构造函数
  19. //$types : 允许上传的文件类型 , $maxsize : 允许大小 , $field : 上传控件名称 , $time : 自定义上传时间
  20. function upload($types = 'jpg|png', $maxsize = 1024, $field = 'attach', $time = '') {
  21. $this->allow_types = explode('|',$types);
  22. $this->maxsize = $maxsize * 1024;
  23. $this->field = $field;
  24. $this->time = $time ? $time : time();
  25. }
  26. //设置并创建文件具体存放的目录
  27. //$basedir : 基目录,必须为物理路径
  28. //$filedir : 自定义子目录,可用参数{y}、{m}、{d}
  29. function set_dir($basedir,$filedir = '') {
  30. $dir = $basedir;
  31. !is_dir($dir) && @mkdir($dir,0777);
  32. if (!empty($filedir)) {
  33. $filedir = str_replace(array('{y}','{m}','{y}'),array(date('Y',$this->time),date('m',$this->time),date('d',$this->time)),strtolower($filedir));
  34. $dirs = explode('/',$filedir);
  35. foreach ($dirs as $d) {
  36. !empty($d) && $dir .= $d.'/';
  37. !is_dir($dir) && @mkdir($dir,0777);
  38. }
  39. }
  40. $this->dir = $dir;
  41. }
  42. //图片缩略图设置,如果不生成缩略图则不用设置
  43. //$width : 缩略图宽度 , $height : 缩略图高度
  44. function set_thumb ($width = 0, $height = 0) {
  45. $this->thumb_width = $width;
  46. $this->thumb_height = $height;
  47. }
  48. //图片水印设置,如果不生成添加水印则不用设置
  49. //$file : 水印图片 , $pos : 水印位置 , $trans : 水印透明度
  50. function set_watermark ($file, $pos = 6, $trans = 80) {
  51. $this->watermark_file = $file;
  52. $this->watermark_pos = $pos;
  53. $this->watermark_trans = $trans;
  54. }
  55. /*----------------------------------------------------------------
  56. 执行文件上传,处理完返回一个包含上传成功或失败的文件信息数组,
  57. 其中:name 为文件名,上传成功时是上传到服务器上的文件名,上传失败则是本地的文件名
  58. dir 为服务器上存放该附件的物理路径,上传失败不存在该值
  59. size 为附件大小,上传失败不存在该值
  60. flag 为状态标识,1表示成功,-1表示文件类型不允许,-2表示文件大小超出
  61. ----------------------------------------------------------------- */
  62. function execute() {
  63. $files = array(); //成功上传的文件信息
  64. $field = $this->field;
  65. $keys = array_keys($_FILES[$field]['name']);
  66. foreach ($keys as $key) {
  67. if (!$_FILES[$field]['name'][$key]) continue;
  68. $fileext = $this->fileext($_FILES[$field]['name'][$key]); //获取文件扩展名
  69. $filename = $this->time.mt_rand(100,999).'.'.$fileext; //生成文件名
  70. $filedir = $this->dir; //附件实际存放目录
  71. $filesize = $_FILES[$field]['size'][$key]; //文件大小
  72. //文件类型不允许
  73. if (!in_array($fileext,$this->allow_types)) {
  74. $files[$key]['name'] = $_FILES[$field]['name'][$key];
  75. $files[$key]['flag'] = -1;
  76. continue;
  77. }
  78. //文件大小超出
  79. if ($filesize > $this->maxsize) {
  80. $files[$key]['name'] = $_FILES[$field]['name'][$key];
  81. $files[$key]['flag'] = -2;
  82. continue;
  83. }
  84. $files[$key]['name'] = $filename;
  85. $files[$key]['dir'] = $filedir;
  86. $files[$key]['size'] = $filesize;
  87. //保存上传文件并删除临时文件
  88. if (is_uploaded_file($_FILES[$field]['tmp_name'][$key])) {
  89. move_uploaded_file($_FILES[$field]['tmp_name'][$key],$filedir.$filename);
  90. @unlink($_FILES[$field]['tmp_name'][$key]);
  91. $files[$key]['flag'] = 1;
  92. //对图片进行加水印和生成缩略图
  93. if (in_array($fileext,array('jpg','png','gif'))) {
  94. if ($this->thumb_width) {
  95. if ($this->create_thumb($filedir.$filename,$filedir.'thumb_'.$filename)) {
  96. $files[$key]['thumb'] = 'thumb_'.$filename; //缩略图文件名
  97. }
  98. }
  99. $this->create_watermark($filedir.$filename);
  100. }
  101. }
  102. }
  103. return $files;
  104. }
  105. //创建缩略图,以相同的扩展名生成缩略图
  106. //Php.aspx_file : 来源图像路径 , $thumb_file : 缩略图路径
  107. function create_thumb (Php.aspx_file,$thumb_file) {
  108. $t_width = $this->thumb_width;
  109. $t_height = $this->thumb_height;
  110. if (!file_exists(Php.aspx_file)) return false;
  111. Php.aspx_info = getImageSize(Php.aspx_file);
  112. //如果来源图像小于或等于缩略图则拷贝源图像作为缩略图
  113. if (Php.aspx_info[0] if (!copy(Php.aspx_file,$thumb_file)) {
  114. return false;
  115. }
  116. return true;
  117. }
  118. //按比例计算缩略图大小
  119. if (Php.aspx_info[0] - $t_width > Php.aspx_info[1] - $t_height) {
  120. $t_height = ($t_width / Php.aspx_info[0]) * Php.aspx_info[1];
  121. } else {
  122. $t_width = ($t_height / Php.aspx_info[1]) * Php.aspx_info[0];
  123. }
  124. //取得文件扩展名
  125. $fileext = $this->fileext(Php.aspx_file);
  126. switch ($fileext) {
  127. case 'jpg' :
  128. Php.aspx_img = ImageCreateFromJPEG(Php.aspx_file); break;
  129. case 'png' :
  130. Php.aspx_img = ImageCreateFromPNG(Php.aspx_file); break;
  131. case 'gif' :
  132. Php.aspx_img = ImageCreateFromGIF(Php.aspx_file); break;
  133. }
  134. //创建一个真彩色的缩略图像
  135. $thumb_img = @ImageCreateTrueColor($t_width,$t_height);
  136. //ImageCopyResampled函数拷贝的图像平滑度较好,优先考虑
  137. if (function_exists('imagecopyresampled')) {
  138. @ImageCopyResampled($thumb_img,Php.aspx_img,0,0,0,0,$t_width,$t_height,Php.aspx_info[0],Php.aspx_info[1]);
  139. } else {
  140. @ImageCopyResized($thumb_img,Php.aspx_img,0,0,0,0,$t_width,$t_height,Php.aspx_info[0],Php.aspx_info[1]);
  141. }
  142. //生成缩略图
  143. switch ($fileext) {
  144. case 'jpg' :
  145. ImageJPEG($thumb_img,$thumb_file); break;
  146. case 'gif' :
  147. ImageGIF($thumb_img,$thumb_file); break;
  148. case 'png' :
  149. ImagePNG($thumb_img,$thumb_file); break;
  150. }
  151. //销毁临时图像
  152. @ImageDestroy(Php.aspx_img);
  153. @ImageDestroy($thumb_img);
  154. return true;
  155. }
  156. //为图片添加水印
  157. //$file : 要添加水印的文件
  158. function create_watermark ($file) {
  159. //文件不存在则返回
  160. if (!file_exists($this->watermark_file) || !file_exists($file)) return;
  161. if (!function_exists('getImageSize')) return;
  162. //检查GD支持的文件类型
  163. $gd_allow_types = array();
  164. if (function_exists('ImageCreateFromGIF')) $gd_allow_types['image/gif'] = 'ImageCreateFromGIF';
  165. if (function_exists('ImageCreateFromPNG')) $gd_allow_types['image/png'] = 'ImageCreateFromPNG';
  166. if (function_exists('ImageCreateFromJPEG')) $gd_allow_types['image/jpeg'] = 'ImageCreateFromJPEG';
  167. //获取文件信息
  168. $fileinfo = getImageSize($file);
  169. $wminfo = getImageSize($this->watermark_file);
  170. if ($fileinfo[0] if (array_key_exists($fileinfo['mime'],$gd_allow_types)) {
  171. if (array_key_exists($wminfo['mime'],$gd_allow_types)) {
  172. //从文件创建图像
  173. $temp = $gd_allow_types[$fileinfo['mime']]($file);
  174. $temp_wm = $gd_allow_types[$wminfo['mime']]($this->watermark_file);
  175. //水印位置
  176. switch ($this->watermark_pos) {
  177. case 1 : //顶部居左
  178. $dst_x = 0; $dst_y = 0; break;
  179. case 2 : //顶部居中
  180. $dst_x = ($fileinfo[0] - $wminfo[0]) / 2; $dst_y = 0; break;
  181. case 3 : //顶部居右
  182. $dst_x = $fileinfo[0]; $dst_y = 0; break;
  183. case 4 : //底部居左
  184. $dst_x = 0; $dst_y = $fileinfo[1]; break;
  185. case 5 : //底部居中
  186. $dst_x = ($fileinfo[0] - $wminfo[0]) / 2; $dst_y = $fileinfo[1]; break;
  187. case 6 : //底部居右
  188. $dst_x = $fileinfo[0]-$wminfo[0]; $dst_y = $fileinfo[1]-$wminfo[1]; break;
  189. default : //随机
  190. $dst_x = mt_rand(0,$fileinfo[0]-$wminfo[0]); $dst_y = mt_rand(0,$fileinfo[1]-$wminfo[1]);
  191. }
  192. if (function_exists('ImageAlphaBlending')) ImageAlphaBlending($temp_wm,True); //设定图像的混色模式
  193. if (function_exists('ImageSaveAlpha')) ImageSaveAlpha($temp_wm,True); //保存完整的 alpha 通道信息
  194. //为图像添加水印
  195. if (function_exists('imageCopyMerge')) {
  196. ImageCopyMerge($temp,$temp_wm,$dst_x,$dst_y,0,0,$wminfo[0],$wminfo[1],$this->watermark_trans);
  197. } else {
  198. ImageCopyMerge($temp,$temp_wm,$dst_x,$dst_y,0,0,$wminfo[0],$wminfo[1]);
  199. }
  200. //保存图片
  201. switch ($fileinfo['mime']) {
  202. case 'image/jpeg' :
  203. @imageJPEG($temp,$file);
  204. break;
  205. case 'image/png' :
  206. @imagePNG($temp,$file);
  207. break;
  208. case 'image/gif' :
  209. @imageGIF($temp,$file);
  210. break;
  211. }
  212. //销毁零时图像
  213. @imageDestroy($temp);
  214. @imageDestroy($temp_wm);
  215. }
  216. }
  217. }
  218. //获取文件扩展名
  219. function fileext($filename) {
  220. return strtolower(substr(strrchr($filename,'.'),1,10));
  221. }
  222. }
  223. ?>
复制代码

使用示例:

  1. if ($_GET['action'] == 'save') {
  2. $up = new upload();
  3. $up->set_dir(dirname(__FILE__).'/upload/','{y}/{m}');
  4. $up->set_thumb(100,80);
  5. $up->set_watermark(dirname(__FILE__).'/jblog/images/watermark.png',6,90);
  6. $fs = $up->execute();
  7. var_dump($fs);
  8. }
  9. ?>
  10. test
复制代码


Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Terangkan konsep sesi PHP secara ringkas.Terangkan konsep sesi PHP secara ringkas.Apr 26, 2025 am 12:09 AM

PhpSSsionsTrackUserDataacrossmultiplePagerequestSuseUniquidStoredinacookie.here'ShoWtomanAgeThemEffectely: 1) startAnSessionWithSession_Start () danStoRedatain $ _Session.2)

Bagaimana anda melengkapkan semua nilai yang disimpan dalam sesi PHP?Bagaimana anda melengkapkan semua nilai yang disimpan dalam sesi PHP?Apr 26, 2025 am 12:06 AM

Dalam PHP, iterating melalui data sesi dapat dicapai melalui langkah -langkah berikut: 1. Mulakan sesi menggunakan session_start (). 2. ITERATE melalui gelung foreach melalui semua pasangan nilai utama dalam array $ _Session. 3. Apabila memproses struktur data kompleks, gunakan fungsi is_array () atau is_object () dan gunakan print_r () untuk mengeluarkan maklumat terperinci. 4. Apabila mengoptimumkan traversal, paging boleh digunakan untuk mengelakkan memproses sejumlah besar data pada satu masa. Ini akan membantu anda mengurus dan menggunakan data sesi PHP dengan lebih cekap dalam projek sebenar anda.

Terangkan cara menggunakan sesi untuk pengesahan pengguna.Terangkan cara menggunakan sesi untuk pengesahan pengguna.Apr 26, 2025 am 12:04 AM

Sesi ini menyedari pengesahan pengguna melalui mekanisme pengurusan negara pelayan. 1) Penciptaan sesi dan penjanaan ID unik, 2) IDS diluluskan melalui kuki, 3) kedai pelayan dan mengakses data sesi melalui ID, 4) Pengesahan pengguna dan pengurusan status direalisasikan, meningkatkan keselamatan aplikasi dan pengalaman pengguna.

Beri contoh bagaimana untuk menyimpan nama pengguna dalam sesi PHP.Beri contoh bagaimana untuk menyimpan nama pengguna dalam sesi PHP.Apr 26, 2025 am 12:03 AM

TOSTOREAUSER'SNAMEINAPHPSESSION, startTheSessionWithSsion_Start (), thenassignthenameto $ _Session ['username']

Apakah beberapa masalah biasa yang boleh menyebabkan sesi PHP gagal?Apakah beberapa masalah biasa yang boleh menyebabkan sesi PHP gagal?Apr 25, 2025 am 12:16 AM

Sebab -sebab kegagalan phpsession termasuk kesilapan konfigurasi, isu cookie, dan tamat tempoh sesi. 1. Ralat Konfigurasi: Semak dan tetapkan session.save_path yang betul. Masalah 2.Cookie: Pastikan kuki ditetapkan dengan betul. 3.Session Expires: Laraskan Nilai Sesi.GC_MAXLifetime untuk melanjutkan masa sesi.

Bagaimanakah anda menyebarkan isu berkaitan sesi dalam PHP?Bagaimanakah anda menyebarkan isu berkaitan sesi dalam PHP?Apr 25, 2025 am 12:12 AM

Kaedah untuk masalah sesi debug dalam PHP termasuk: 1. Periksa sama ada sesi dimulakan dengan betul; 2. Sahkan penghantaran ID sesi; 3. Semak penyimpanan dan bacaan data sesi; 4. Semak konfigurasi pelayan. Dengan mengeluarkan ID dan data sesi, melihat kandungan fail sesi, dan lain-lain, anda boleh mendiagnosis dan menyelesaikan masalah yang berkaitan dengan sesi.

Apa yang berlaku jika session_start () dipanggil beberapa kali?Apa yang berlaku jika session_start () dipanggil beberapa kali?Apr 25, 2025 am 12:06 AM

Pelbagai panggilan ke session_start () akan menghasilkan mesej amaran dan kemungkinan penggantian data. 1) PHP akan mengeluarkan amaran, menyebabkan sesi telah dimulakan. 2) Ia boleh menyebabkan penggantian data sesi yang tidak dijangka. 3) Gunakan session_status () untuk memeriksa status sesi untuk mengelakkan panggilan berulang.

Bagaimana anda mengkonfigurasi seumur hidup sesi di PHP?Bagaimana anda mengkonfigurasi seumur hidup sesi di PHP?Apr 25, 2025 am 12:05 AM

Mengkonfigurasi kitaran hayat sesi dalam PHP boleh dicapai dengan menetapkan sesi.gc_maxlifetime dan session.cookie_lifetime. 1) session.gc_maxlifetime mengawal masa survival data sesi pelayan, 2) session.cookie_lifetime mengawal kitaran hayat kuki klien. Apabila ditetapkan ke 0, kuki tamat apabila penyemak imbas ditutup.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

MinGW - GNU Minimalis untuk Windows

MinGW - GNU Minimalis untuk Windows

Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

SublimeText3 Linux versi baharu

SublimeText3 Linux versi baharu

SublimeText3 Linux versi terkini

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini