我們先來看程式碼:
先看一下View部分:
<form action="<?= Url::to(['default/datafile']) ?>" method="post" enctype="multipart/form-data"> <label for="file">Filename:</label> <input type="file" name="myFile" id="file" /> <br /> <input type="submit" name="submit" value="Submit" /> </form>
上面的action是用YII的助手類別建構了一個內部可以辨識的url,就是DeaufaultController.php中的actionDatafile()
(推薦教學:yii框架)
public function actionDatafile(){ if(empty($_FILES)){ $status = 1; $info = '没有文件上传'; } if($_FILES['myFile']['error'] === 0 || $_FILES['myFile']['error'] === '0' ){ //文件上传成功 $tmp = pathinfo($_FILES['myFile']['name']); $new_fname = $tmp['filename'].'_'.rand(1000000,9999999).'.'.$tmp['extension']; echo $new_fname; if(!move_uploaded_file($_FILES['myFile']['tmp_name'], '../runtime/file/'.$new_fname)){ $status = 1; $info = '上传(移动)失败'; }else{ $status = 0; $info = '上传成功'; } } else { //文件上传失败 $info = '文件上传失败'; switch($_FILES['myFile']['error']){ case 1: $info = '上传文件超过php.ini中upload_max_filesize配置参数'; break; case 2: $info = '上传文件超过表单MAX_FILE_SIZE选项指定的值'; break; case 3: $info = '文件只有部份被上传'; break; case 4: $info = '没有文件被上传'; break; case 5: $info = '上传文件大小为0'; break; } $status = 1; } return $info; }
執行後發現
解決方法:
1、檢查設定(php.ini)
file_uploads、upload_max_filesize、post_max_size、upload_tmp_dir是否已設定。
2、檢查參數
發現參數中的crsf,這個參數是yii框架驗證所帶,提及驗證,便和錯誤提示相仿,添加取消驗證程式碼,如下:
public function beforeAction($action) { if ($action->id == 'datafile') { $this->enableCsrfValidation = false; } return parent::beforeAction($action); }
更多程式相關內容,請關注php中文網程式設計入門欄位!
以上是yii2上傳檔案失敗的詳細內容。更多資訊請關注PHP中文網其他相關文章!