當前位置:首頁 » 文件管理 » thinkphp非法上傳文件

thinkphp非法上傳文件

發布時間: 2023-03-19 19:12:20

Ⅰ Thinkphp上傳圖片出現:Fatal error: Class 'UploadFile' not found是怎麼回事

UploadFile 需要引入的

Public function upload(){
import('配喊ORG.Net.UploadFile');
$upload = new UploadFile();// 實例化上傳類
$upload->maxSize = 3145728 ;// 設置附培虛野件上傳大小
$upload->allowExts = array('jpg', 'gif', 'png', 'jpeg');// 設置附件上傳類型
$upload->savePath = './Public/Uploads/';// 設置附件上傳目錄
if(!$upload->upload()) {// 上傳錯誤提示錯誤信譽渣息
$this->error($upload->getErrorMsg());
}else{// 上傳成功 獲取上傳文件信息
$info = $upload->getUploadFileInfo();
}

Ⅱ thinkphp 裡面報非法操作 該如何解決

在本身action類中加方法:吵肢
function _empty(){
header("HTTP/廳碰凱扮喚1.0 404 Not Found");//使HTTP返回404狀態碼
$this->display("Public:404");
}

Ⅲ thinkPHP 上傳文件的時候不支持flv 格式的怎麼解決啊

①$upload->allowExts = array('jpg', 'gif', 'png', 'jpeg');// 設置附件上傳類型
這樣寫試試。
②不知道你的Thinkphp是哪個版本的。你去看下上傳文件的類裡面具體怎麼寫的,是UploadFile.class.php文件。看下protected function error($errorNo) 這個方法,也就是提示錯誤的函數,看寫「非法數據對象」是哪裡出錯了。有可能不是因為類型的原因。
(不行再問我,QQ617762749)

Ⅳ thinkphp 多文件上傳失敗 ,只上傳第一張大神求救!!

//定義函數判斷是否有上傳的圖片
private function haveimg($data){
foreach ($data['error'] as $value) {
# code...
if($value==0){
return TRUE;
}
else{
return FALSE;
}
}
}
/***********判斷當前是否有圖片*****************/
if($this->haveimg($_FILES['imgs'])){
//上傳圖片
$upload = new \Think\Upload();// 實例化上傳類
$upload->maxSize = 3145728 ;// 設置附件上傳大小
$upload->exts = array('jpg', 'gif', 'png', 'jpeg');// 設置附件上傳類型
$upload->rootPath = './盯仔Uploads/'; /蠢扒/ 設置附件上傳根目錄
$upload->savePath = 'Pricture/'; // 設置附件上傳(子)目錄
// 上傳文件
$info=$upload->upload(array('picurl' => $_FILES['imgs']));
if($info){
$pmodel=M('goods_pics');
foreach ($info as $k=>$v) {
$url=$v['savepath'].$v['savename'凱檔汪];
$pmodel->add(array(
'picurl'=>$url,
'gid'=>$data['gid']
));
}

}

Ⅳ thinkphp5上傳文件方法不存在

thinkphp5上孝旅皮傳文鎮此件方法不存在是代碼錯誤的原因。在move復制文件前,對文件名進去中文轉碼,轉換成巧差gb2312,復制完成,轉換回utf-8即可。

Ⅵ thinkphp3.2.3 怎麼上傳form表單

上傳表單
在ThinkPHP中使用上傳功能無需進行特別處理。例如,下面是一個帶有附件上傳的表單提交:
<form action="__URL__/upload" enctype="multipart/form-data" method="post" >
<input type="text" name="name" />
<input type="file" name="photo" />
<input type="submit" value="提交" >
</form>
注意,要使用上傳功能 你的表單需要設置 enctype="multipart/form-data"
多文件上傳支持
如果需要使用多個文件上傳,只需要修改表單,把
<input type='file' name='photo'>
改為
<input type='file' name='photo1'>
<input type='file' name='photo2'>
<input type='file' name='photo3'>
或者
<input type='file' name='photo[]'>
<input type='file' name='photo[]'>
<input type='file' name='photo[]'>
兩種方式的多附件上傳系統的文件上傳類都可以自動識別。
上傳操作
ThinkPHP文件上傳操作使用Think\Upload類,假設前面的表單提交到當前控制器的upload方法,我們來看下upload方法的實現代碼:
public function upload(){
$upload = new \Think\Upload();// 實例化上傳類
$upload->maxSize = 3145728 ;// 設置附件上傳大小
$upload->exts = array('jpg', 'gif', 'png', 'jpeg');// 設置附件上傳類型
$upload->rootPath = './Uploads/'; // 設置附件上傳根目錄
$upload->savePath = ''; // 設置附件上傳(子)目錄
// 上傳文件
$info = $upload->upload();
if(!$info) {// 上傳錯誤提示錯誤信息
$this->error($upload->getError());
}else{// 上傳成功
$this->success('上傳成功!');
}
}
上傳類對圖片文件的上傳安全做了支持,如果企圖上傳非法的圖像文件,系統會提示 非法圖像文件。 為了更好的使用上傳功能,建議你的伺服器開啟finfo模塊支持
上傳參數
在上傳操作之前,我們可以對上傳的屬性進行一些設置,Upload類支持的屬性設置包括:
屬性描述
maxSize文件上傳的最大文件大小(以位元組為單位),0為不限大小
rootPath文件上傳保存的根路徑
savePath文件上傳的保存路徑(相對於根路徑)
saveName上傳文件的保存規則,支持數組和字元串方式定義
saveExt上傳文件的保存後綴,不設置的話使用原文件後綴
replace存在同名文件是否是覆蓋,默認為false
exts允許上傳的文件後綴(留空為不限制),使用數組或者逗號分隔的字元串設置,默認為空
mimes允許上傳的文件類型(留空為不限制),使用數組或者逗號分隔的字元串設置,默認為空
autoSub自動使用子目錄保存上傳文件 默認為true
subName子目錄創建方式,採用數組或者字元串方式定義
hash是否生成文件的hash編碼 默認為true
callback檢測文件是否存在回調,如果存在返迴文件信息數組
上面的屬性可以通過兩種方式傳入:
實例化傳入
我們可以在實例化的時候直接傳入參數數組,例如:
$config = array(
'maxSize' => 3145728,
'rootPath' => './Uploads/',
'savePath' => '',
'saveName' => array('uniqid',''),
'exts' => array('jpg', 'gif', 'png', 'jpeg'),
'autoSub' => true,
'subName' => array('date','Ymd'),
);
$upload = new \Think\Upload($config);// 實例化上傳類
關於saveName和subName的使用後面我們會有詳細的描述。
動態賦值
支持在實例化後動態賦值上傳參數,例如:
$upload = new \Think\Upload();// 實例化上傳類
$upload->maxSize = 3145728;
$upload->rootPath = './Uploads/';
$upload->savePath = '';
$upload->saveName = array('uniqid','');
$upload->exts = array('jpg', 'gif', 'png', 'jpeg');
$upload->autoSub = true;
$upload->subName = array('date','Ymd');
上面的設置和實例化傳入的效果是一致的。
上傳文件信息
設置好上傳的參數後,就可以調用Think\Upload類的upload方法進行附件上傳,如果失敗,返回false,並且用getError方法獲取錯誤提示信息;如果上傳成功,就返回成功上傳的文件信息數組。
$upload = new \Think\Upload();// 實例化上傳類
$upload->maxSize = 3145728 ;// 設置附件上傳大小
$upload->exts = array('jpg', 'gif', 'png', 'jpeg');// 設置附件上傳類型
$upload->rootPath = './Uploads/'; // 設置附件上傳根目錄
$upload->savePath = ''; // 設置附件上傳(子)目錄
// 上傳文件
$info = $upload->upload();
if(!$info) {// 上傳錯誤提示錯誤信息
$this->error($upload->getError());
}else{// 上傳成功 獲取上傳文件信息
foreach($info as $file){
echo $file['savepath'].$file['savename'];
}
}
每個文件信息又是一個記錄了下面信息的數組,包括:
屬性描述
key附件上傳的表單名稱
savepath上傳文件的保存路徑
name上傳文件的原始名稱
savename上傳文件的保存名稱
size上傳文件的大小
type上傳文件的MIME類型
ext上傳文件的後綴類型
md5上傳文件的md5哈希驗證字元串 僅當hash設置開啟後有效
sha1上傳文件的sha1哈希驗證字元串 僅當hash設置開啟後有效
文件上傳成功後,就可以使用這些文件信息來進行其他的數據操作,例如保存到當前數據表或者單獨的附件數據表。
例如,下面表示把上傳信息保存到數據表的欄位:
$model = M('Photo');
// 取得成功上傳的文件信息
$info = $upload->upload();
// 保存當前數據對象
$data['photo'] = $info[0]['savename'];
$data['create_time'] = NOW_TIME;
$model->add($data);
單文件上傳
upload方法支持多文件上傳,有時候,我們只需要上傳一個文件,就可以使用Upload類提供的uploadOne方法上傳單個文件,例如:
public function upload(){
$upload = new \Think\Upload();// 實例化上傳類
$upload->maxSize = 3145728 ;// 設置附件上傳大小
$upload->exts = array('jpg', 'gif', 'png', 'jpeg');// 設置附件上傳類型
$upload->rootPath = './Uploads/'; // 設置附件上傳根目錄
// 上傳單個文件
$info = $upload->uploadOne($_FILES['photo1']);
if(!$info) {// 上傳錯誤提示錯誤信息
$this->error($upload->getError());
}else{// 上傳成功 獲取上傳文件信息
echo $info['savepath'].$info['savename'];
}
}
uploadOne方法上傳成功後返回的文件信息和upload方法的區別是只有單個文件信息的一維數組。
上傳文件的命名規則
上傳文件的命名規則(saveName)用於確保文件不會產生沖突或者覆蓋的情況。命名規則的定義可以根據你的業務邏輯來調整,不是固定的。例如,如果你採用時間戳的方式來定義命名規范,那麼在同時上傳多個文件的時候可能產生沖突(因為同一秒內可以上傳多個文件),因此你需要根據你的業務需求來設置合適的上傳命名規則。這里順便來說下saveName參數的具體用法。
一、採用函數方式
如果傳入的字元串是一個函數名,那麼表示採用函數動態生成上傳文件名(不包括文件後綴),例如:
// 採用時間戳命名
$upload->saveName = 'time';
// 採用GUID序列命名
$upload->saveName = 'com_create_guid';
也可以採用用戶自定義函數
// 採用自定義函數命名
$upload->saveName = 'myfun';
默認的命名規則設置是採用uniqid函數生成一個唯一的字元串序列。
saveName的值支持數組和字元串兩種方式,如果是只有一個參數或者沒有參數的函數,直接使用字元串設置即可,如果需要傳入額外的參數,可以使用數組方式,例如:
// 採用date函數生成命名規則 傳入Y-m-d參數
$upload->saveName = array('date','Y-m-d');
// 如果有多個參數需要傳入的話 可以使用數組
$upload->saveName = array('myFun',array('__FILE__','val1','val2'));
如果需要使用上傳的原始文件名,可以採用__FILE__傳入,所以上面的定義規則,最終的結果是 myFun('上傳文件名','val1','val2')執行的結果。
二、直接設置上傳文件名
如果傳入的參數不是一個函數名,那麼就會直接當做是上傳文件名,例如:
$upload->saveName = time().'_'.mt_rand();
表示上傳的文件命名採用時間戳加一個隨機數的組合字元串方式。
當然,如果覺得有必要,你還可以固定設置一個上傳文件的命名規則,用於固定保存某個上傳文件。
$upload->saveName = 'ThinkPHP';
三、保持上傳文件名不變
如果你想保持上傳的文件名不變,那麼只需要設置命名規范為空即可,例如:
$upload->saveName = '';
一般來說不建議保持不變,因為會導致相同的文件名上傳後被覆蓋的情況。
子目錄保存
saveName只是用於設置文件的保存規則,不涉及到目錄,如果希望對上傳的文件分子目錄保存,可以設置autoSub和subName參數來完成,例如:
// 開啟子目錄保存 並以日期(格式為Ymd)為子目錄
$upload->autoSub = true;
$upload->subName = array('date','Ymd');
可以使用自定義函數來保存,例如:
// 開啟子目錄保存 並調用自定義函數get_user_id生成子目錄
$upload->autoSub = true;
$upload->subName = 'get_user_id';
和saveName參數一樣,subName的定義可以採用數組和字元串的方式。
注意:如果get_user_id函數未定義的話,會直接以get_user_id字元串作為子目錄的名稱保存。
子目錄保存和文件命名規則可以結合使用。
上傳驅動
上傳類可以支持不同的環境,通過相應的上傳驅動來解決,默認情況下使用本地(Local)上傳驅動,當然,你還可以設置當前默認的上傳驅動類型,例如:
'FILE_UPLOAD_TYPE' => 'ftp',
'UPLOAD_TYPE_CONFIG' => array(
'host' => '192.168.1.200', //伺服器
'port' => 21, //埠
'timeout' => 90, //超時時間
'username' => 'ftp_user', //用戶名
'password' => 'ftp_pwd', //密碼 ),
表示當前使用Ftp作為上傳類的驅動,上傳的文件會通過FTP傳到指定的遠程伺服器。
也可以在實例化上傳類的時候指定,例如:
$config = array(
'maxSize' = 3145728,
'rootPath' = './Uploads/',
'savePath' = '',
'saveName' = array('uniqid',''),
'exts' = array('jpg', 'gif', 'png', 'jpeg'),
'autoSub' = true,
'subName' = array('date','Ymd'),
);
$ftpConfig = array(
'host' => '192.168.1.200', //伺服器
'port' => 21, //埠
'timeout' => 90, //超時時間
'username' => 'ftp_user', //用戶名
'password' => 'ftp_pwd', //密碼 );
$upload = new \Think\Upload($config,'Ftp',$ftpConfig);// 實例化上傳類
目前已經支持的上傳驅動包括Local、Ftp、Sae、Bcs、七牛和又拍雲等。

Ⅶ THINKPHP上傳大文件問題

樓主,問題解決了嗎?我的解決了,滲祥我是通過查看php.log文件,看到因運喊乎為我旁悉post提交的數據過大,而被php拋棄了,後來我在php.ini中修改了post提交大小的數值,改成了沒有限制,就行了

Ⅷ thinkphp非法操作,該怎麼解決

這個非法操作的原因有很多
主要是語法錯誤,一般報錯的話,會顯示抱消輪錯行數,看下有沒有首橋侍語法操作錯誤,然後去改正下者吵!一般都會有報錯行數呢,就在那附近!
對於這類問題,要貫穿程序的先先後後,去推測哪個地方有問題,然後自己去一步一步去調試!慢慢的,自己的排錯水平就提升上去了!

Ⅸ 【thinkphp】上傳圖片,總是提示「操作失敗!非法圖像文件」是怎麼回事

首先你找到提示「操作失敗!非法圖像文件」部分代碼,分析原因:為什麼會滿足產生這個提示的條件?
因為你沒貼上代碼,所以這里我很難幫你分析什麼原因。不過估計,既然你本地運行正常,而上傳到伺服器就不正常了。很可能是你伺服器環境和本地環境不用,代碼兼容性問題

Ⅹ thinkphp 修改圖片信息提示非法上傳文件

表單的Form標簽中一定要添加 enctype=」multipart/form-data」文件才能上傳。因為表單提交到當前模塊的upload操作方法,所以我們李老在模塊類裡面添加下面的upload方法即可:
Public function upload(){
import('ORG.Net.UploadFile');
$upload = new UploadFile();
$upload->maxSize = 3145728 ;
$upload->allowExts = array('jpg', 'gif', 'png', 'jpeg');
$upload->savePath = './Public/Uploads/';
if(!$upload->upload()) {// 上傳錯誤提示錯誤信息
哪早升$this->error($upload->getErrorMsg());
}else{// 上傳成功 獲取上傳文件信息
$info = $upload->getUploadFileInfo();
睜改}
// 保存表單數據 包括附件數據
$User = M("User"); // 實例化User對象
$User->create();
$User->photo = $info[0]['savename'];
$User->add();
$this->success('數據保存成功!');
}
更多問題到後盾網論壇問題求助專區http://bbs.hounwang.com

熱點內容
韓劇tv一直等待緩存 發布:2023-03-23 00:18:43 瀏覽:717
javaeejdk 發布:2023-03-23 00:15:27 瀏覽:537
開機後為什麼一直顯示配置錯誤 發布:2023-03-23 00:15:20 瀏覽:100
win10新建文件夾的快捷鍵 發布:2023-03-23 00:14:08 瀏覽:21
jpg不能上傳 發布:2023-03-23 00:12:07 瀏覽:419
電腦伺服器ip地址查詢方法 發布:2023-03-23 00:11:53 瀏覽:97
好用的DNS伺服器IP 發布:2023-03-23 00:06:51 瀏覽:102
sqlserver2008任務 發布:2023-03-22 23:55:13 瀏覽:96
有限訪問現權 發布:2023-03-22 23:53:50 瀏覽:887
兩目c語言 發布:2023-03-22 23:51:54 瀏覽:162