这篇文章主要为大家分享了php文件上传类的相关代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了php文件上传类的具体代码,供大家参考,具体内容如下
<?php $upload = new UpLoad(); $upload->uploadFile('fm'); /*打印错误信息*/ // var_dump($upload->errorNumber); // var_dump($upload->errorInfo); class UpLoad{ //文件上传路径 protected $path = 'upload/'; //允许文件上传的后缀 protected $allowSuffix = ['jpg','jpeg', 'gif','wbmp','png']; //mime类型 protected $allowMime =['image/jpg','image/jpeg', 'image/gif','image/wbmp','image/png']; //允许上传的大小 protected $maxSize = 2000000; //是否启用默认的前缀 protected $isRandName =true ; //文件的前缀 protected $prefix = 'up_'; //错误号和错误信息 protected $errorNumber; protected $errorInfo; //文件的信息 //文件名 protected $oldName; //文件的后缀 protected $suffix; //文件的大小 protected $size; //文件的mime protected $mime; //文件的临时文件的路径 protected $tmpName; //文件新名字 protected $newName; //构造方法 //因为成员属性比较多就用数组来显示 public function __construct($arr =[]){ foreach ($arr as $key=>$value){ $this->setOption($key,$value); } } //判断$key是不是我的成员属性,如果是就设置 protected function setOption($key,$value){ //得到所有的成员属性 $keys = array_keys(get_class_vars(__CLASS__)); if(in_array($key, $keys)){ $this->$key = $value; } } //文件上传函数 //key 就是input框中的name属性值 public function uploadFile($key){ //判断有没有设置路径 path if(empty($this->path)){ $this->setOption('errorNumber',-1 ); return false; } //判断该路径是否存在是否可写 if (!$this->check()){ $this->setOption('errorNumber', -2); return false; } //判断$_FILES里面的error信息是否为0,如果为0则说明文件信息在服务器端可以直接获取,提取信息保存到成员属性中 $error = $_FILES[$key]['error']; if($error){ $this->setOption('errorNumber', -3); return false; }else { //提取文件相关信息并且保存到成员属性中 $this->getFileInfo($key); } //判断文件的大小、mime、后缀是否符合 if(!$this->checkSize() || !$this->checkMime()|| !$this->checkSuffix()){ return false; } //得到新的文件名字 $this->newName = $this->createNewName(); //判断是否是上传文件,并且是移动上传文件 if(is_uploaded_file($this->tmpName)){ if(move_uploaded_file($this->tmpName, $this->path.$this->newName)){ return $this->path.$this->newName; }else { $this->setOption('errorNumber', -7); return false; } }else{ $this->setOption('errorNumber', -6); return false; } } //检测文件夹是否存在,是否可写 protected function check(){ //文件夹不存在或者不是目录。创建文件夹 if(!file_exists($this->path) ||!is_dir($this->path)){ return mkdir($this->path,0777,true); } //判断文件是否可写 if(!is_writeable($this->path)){ return chmod($this->path, 0777); } return true; } //根据key得到文件信息 protected function getFileInfo($key){ //得到文件的名字 $this->oldName = $_FILES[$key]['name']; //得到文件的mime类型 $this->mime = $_FILES[$key]['type']; //得到文件的临时文件 $this->tmpName = $_FILES[$key]['tmp_name']; //得到文件大小 $this->size = $_FILES[$key]['size']; //得到文件后缀 $this->suffix = pathinfo($this->oldName)['extension']; } //判断文件大小 protected function checkSize(){ if($this->size > $this->maxSize){ $this->setOption('errorNumber', -3); return false; } return true; } //判断mime类型 protected function checkMime(){ if(!in_array($this->mime, $this->allowMime)){ $this->setOption('errorNumber', -4); return false; } return true; } //判断后缀 protected function checkSuffix(){ if(!in_array($this->suffix, $this->allowSuffix)){ $this->setOption('errorNumber', -5); return false; } return true; } //创建新名字 protected function createNewName(){ if($this->isRandName){ $name = $this->prefix.uniqid().'.'.$this->suffix; }else { $name = $this->prefix.$this->oldName; } return $name; } public function __get($name){ if($name == 'errorNumber'){ return $this->errorNumber; }elseif ($name == 'errorInfo'){ return $this->getErrorInfo(); } } protected function getErrorInfo(){ switch ($this->errorNumber){ case -1: $str = '文件路径没有设置'; break; case -2: $str = '文件不是目录或者不可写'; break; case -3: $str = '文件超过指定大小'; break; case -4: $str = 'mime类型不符合'; break; case -5: $str = '文件后缀不符合'; break; case -6: $str = '不是上传文件'; break; case -7: $str = '移动失败'; break; case 1: $str = '超出ini设置大小'; break; case 2: $str = '超出html表单大小'; break; case 3: $str = '文章只有部分上传'; break; case 4: $str = '没有文件上传'; break; case 6: $str = '找不到临时文件'; break; case 7: $str = '文件写入失败'; break; } return $str; } }
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8" /> <title>文件上传</title> </head> <body> <form action="UpLoad.php" method="post" enctype="multipart/form-data" > <input type="file" name="fm" value=""><br> <input type="submit" value="上传文件" /><br> </form> </body> </html>
注意:input中的name必须和上传类中的uploadFile中是传值一致!
更多精彩内容请参考php文件上传操作汇总进行学习。
Atas ialah kandungan terperinci 分享php文件上传类. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Timeout sesi mutlak bermula pada masa penciptaan sesi, sementara waktu tamat sesi terbiar bermula pada masa operasi pengguna. Tamat masa sesi mutlak sesuai untuk senario di mana kawalan ketat kitaran hayat sesi diperlukan, seperti aplikasi kewangan; Timeout sesi terbiar sesuai untuk aplikasi yang mahu pengguna menyimpan sesi mereka aktif untuk masa yang lama, seperti media sosial.

Kegagalan sesi pelayan boleh diselesaikan dengan mengikuti langkah -langkah: 1. Semak konfigurasi pelayan untuk memastikan sesi ditetapkan dengan betul. 2. Sahkan kuki klien, sahkan bahawa penyemak imbas menyokongnya dan hantar dengan betul. 3. Periksa perkhidmatan penyimpanan sesi, seperti Redis, untuk memastikan bahawa mereka beroperasi secara normal. 4. Semak kod aplikasi untuk memastikan logik sesi yang betul. Melalui langkah -langkah ini, masalah perbualan dapat didiagnosis dengan berkesan dan diperbaiki dan pengalaman pengguna dapat diperbaiki.

session_start () iscrucialinphpformanaginguserSessions.1) itinitiatesanewsessionifnoneexists, 2) resumeSanexistingsession, dan3) setSasessionCookieforcontinuityAcrossrequests, enableingApplicationeUseUshenticationandPersonalConizedConizedContentContentContentContentContentContentContentContentContentContentContentC.

Menetapkan bendera httponly adalah penting untuk cookies sesi kerana ia dapat mencegah serangan XSS dengan berkesan dan melindungi maklumat sesi pengguna. Khususnya, 1) bendera httponly menghalang JavaScript daripada mengakses kuki, 2) bendera boleh ditetapkan melalui setcookies dan make_response dalam php dan flask, 3) walaupun ia tidak dapat dicegah dari semua serangan, ia harus menjadi sebahagian daripada dasar keselamatan keseluruhan.

PhpsSesionssolveThublemofMainTainStateAsmultipHttprequestsByStoringDataontheserverArverArsociatingWithauniquesession.1) merekaSTOREdataServer-sisi, biasanya

Phpsessionscanstorestrings, nombor, tatasusunan, andobjects.1.strings: textdatalikeusernames.2.numbers: integersorfloatsforcounters.3.Arrays: ListsLikeshoppingCarts.4.Objects: complextructureSturesthatareserialized.

Tostartaphpsession, usesession_start () atthescript'sbeginning.1) placeitbeforeanyoutputtosetthesessioncookie.2) usesessionsforusererdatalikeloginstatusorshoppingcarts.3)

Penjanaan semula sesi merujuk kepada menjana ID sesi baru dan membatalkan ID lama apabila pengguna melakukan operasi sensitif dalam kes serangan tetap sesi. Langkah-langkah pelaksanaan termasuk: 1. Mengesan Operasi Sensitif, 2. Menjana ID Sesi Baru, 3. Memusnahkan ID Sesi Lama, 4. Kemas kini maklumat sesi pengguna.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

SublimeText3 versi Inggeris
Disyorkan: Versi Win, menyokong gesaan kod!

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa
