现在很多时候都采用前后端分离的方式开发,或者页面不是php来写,前端不会使用yii2的view挂件,这个时候我们要使用yii2自带的文件上传功能就需要告诉前端定义input file框的name:
1.创建model
namespace app\models;
use yii\base\Model;
use yii\web\UploadedFile;
class UploadForm extends Model
{
/**
* @var UploadedFile[]
*/
public $imageFiles;
public function rules()
{
return [
[['imageFiles'], 'file', 'skipOnEmpty' => false, 'extensions' => 'png, jpg', 'maxFiles' => 4],
];
}
public function upload()
{
if ($this->validate()) {
foreach ($this->imageFiles as $file) {
$file->saveAs('uploads/' . $file->baseName . '.' . $file->extension);
}
return true;
} else {
return false;
}
}
}
2.创建控制器
namespace app\controllers;
use Yii;
use yii\web\Controller;
use app\models\UploadForm;
use yii\web\UploadedFile;
class SiteController extends Controller
{
public function actionUpload()
{
$model = new UploadForm();
if (Yii::$app->request->isPost) {
$model->imageFiles = UploadedFile::getInstances($model, 'imageFiles');
if ($model->upload()) {
// 文件上传成功
return;
}
}
return $this->render('upload');
}
}
3.自定义视图
<form>
<input type=“file” name=“UploadForm[imageFiles][]”/>
<input type=“submit” value=“提交”/>
</form>
自定义的时候name很重要,要设置成UploadForm[imageFiles][],就是上面创建的model名 + 需要传递过去的名字 + [] , 因为是多文件上传,单文件上传也类似,设置更简单