Cet article présente principalement l'exemple de code de Yii2 utilisant des formulaires pour télécharger des fichiers. L'éditeur pense que c'est plutôt bon, je vais donc le partager avec vous maintenant et le donner comme référence. Suivons l'éditeur pour y jeter un œil, j'espère que cela pourra aider tout le monde.
1. Téléchargement d'un seul fichier
Créez d'abord un modèle models/UploadForm.php avec le contenu suivant
namespace app\models; use yii\base\Model; use yii\web\UploadedFile; /** * UploadForm is the model behind the upload form. */ class UploadForm extends Model { /** * @var UploadedFile file attribute */ public $file; /** * @return array the validation rules. */ public function rules() { return [ [['file'], 'file'], ]; } }
Créez ensuite un fichier de vue avec le contenu suivant
<?php use yii\widgets\ActiveForm; ?> <?php $form = ActiveForm::begin(['options' => ['enctype' => 'multipart/form-data']]) ?> <?= $form->field($model, 'file')->fileInput() ?> <button>Submit</button> <?php ActiveForm::end() ?>
Créez enfin le fichier du contrôleur, le contenu est le suivant
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->file = UploadedFile::getInstance($model, 'file'); if ($model->file && $model->validate()) { $model->file->saveAs('uploads/' . $model->file->baseName . '.' . $model->file->extension); } } return $this->render('upload', ['model' => $model]); } }
Notez que nous n'avons pas utilisé model->load(...) ici, mais utilisé UploadedFile : getInstance(... ). La différence est que ce dernier n'exécutera pas $model->validate(), vous devez donc exécuter manuellement $model->validate() pour vérifier la validité des données. Si la vérification réussit, le fichier téléchargé est enregistré dans le dossier des téléchargements, c'est-à-dire des téléchargements dans le répertoire Web.
Quelques options de configuration facultatives
Le fichier téléchargé ne peut pas être vide
public function rules() { return [ [['file'], 'file', 'skipOnEmpty' => false], ]; }
Le type de téléchargement peut être vérifié non seulement en fonction de l'extension, mais également en fonction sur le fichier Vérifier le contenu
public function rules() { return [ [['file'], 'file', 'extensions' => 'jpg, png', 'mimeTypes' => 'image/jpeg, image/png',], ]; }
2. Téléchargement de plusieurs fichiers
Si vous souhaitez télécharger plusieurs fichiers à la fois, il vous suffit d'ajuster quelques paramètres pour atteindre l'objectif
2. 🎜>class UploadForm extends Model { /** * @var UploadedFile|Null file attribute */ public $file; /** * @return array the validation rules. */ public function rules() { return [ [['file'], 'file', 'maxFiles' => 10], // <--- here! ]; } }
<?php use yii\widgets\ActiveForm; $form = ActiveForm::begin(['options' => ['enctype' => 'multipart/form-data']]); ?> <?= $form->field($model, 'file[]')->fileInput(['multiple' => true]) ?> <button>Submit</button> <?php ActiveForm::end(); ?>
$form->field($model, 'file[]')->fileInput(['multiple' => true])
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->file = UploadedFile::getInstances($model, 'file'); if ($model->file && $model->validate()) { foreach ($model->file as $file) { $file->saveAs('uploads/' . $file->baseName . '.' . $file->extension); } } } return $this->render('upload', ['model' => $model]); } }
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!