Ausführliche Erklärung zur Verwendung des mit Yii 2.0 gelieferten Bestätigungscodes

怪我咯
Freigeben: 2023-03-12 15:18:02
Original
1132 Leute haben es durchsucht

In diesem Artikel werden hauptsächlich einige Erfahrungen mit der Verwendung des Bestätigungscodes vorgestellt, der mit Yii 2.0 geliefert wird, damit Anfänger schnell loslegen können und er für alle Freunde, die ihn benötigen, einen gewissen Referenz- und Lernwert hat Kommen Sie unten. Werfen wir einen Blick darauf.

Vorwort

Im Front-End-Bestätigungscode, der mit der offiziellen Website geliefert wird, befindet sich eine Datei „contact.php“. Wenn Sie nichts zu tun haben, können Sie zunächst einen Blick darauf werfen. Interessierte Freunde können sich die ausführliche Einführung unten ansehen:

Die Verwendungsmethode ist wie folgt:

Schritt eins: Da ich die Module selbst erstellt habe, habe ich unter meinen Modulen ein neues Modellverzeichnis erstellt (die standardmäßigen von Gii generierten Module haben dieses Verzeichnis nicht) und ich habe es LoginForm.php genannt

Der Code lautet wie folgt:

namespace app\modules\XXX\models;//这个你们写自己的命名空间,我以我的modules项目路径为例

use Yii;

use yii\base\Model;

use yii\captcha\Captcha;

class LoginForm extends Model
{ 
 public $name; 

 public $email; 

 public $subject; 

 public $body; 

 public $verifyCode;//验证码这个变量是必须建的,因为要储存验证码的值` /** * @return array the validation rules. */

 public function rules() 
 { 
   return [ 
     // name, email, subject and body are required 
     [['name', 'email', 'subject', 'body'], 'required'], 
     // email has to be a valid email 
     ['email', 'email'], 
     // verifyCode needs to be entered correctly 
     ['verifyCode', 'captcha'],//注意这里,在百度中查到很多教程,这里写的都不一样,最 简单的写法就像我这种写法,当然还有其它各种写法 
     //['verifyCode', 'captcha','captchaAction'=>'admin/index/captcha','message'=>'验 证码不正确!'], 这种写法在官网自带的LoginForm.php中有写到,大家可以没事看看 ]; 
 }
 /*
 * * @return array customized attribute labels 
 */ 
 public function attributeLabels() 
 { 
   return [ 
     // 'verifyCode' => 'Verification Code', 
     'verifyCode' => '',//在官网的教程里是加上了英文字母,我这里先给去掉了,这里去 掉会不会产生影响因为我还没做接收验证,只做了验证码显示的功能,你们可以自己测试下 
   ]; 
 } 
/***/
Nach dem Login kopieren

Dann gehen wir im zweiten Schritt zum Controller und fügen den Code hinzu

namespace app\modules\XXX\controllers;//你们自己的控制器空间

use yii\web\Controller;

use yii\web\Session;

use Yii;

use app\modules\XXX\models\LoginForm;//XXX你们自己定义的名字

use yii\filters\AccessControl;

use yii\filters\VerbFilter;

/*
 *这个是对应前台模版的action
 */
public function actionLogin()
{
  $loginForm = new LoginForm();//这里要把刚才写的类new下,注意你们要引入文件路径额
  $this->render('login',array('loginForm'=>$loginForm));//变量传到前台模版
}
/**
 * @用户授权规则
 */
public function behaviors()
{
 return [
   'access' => [
    'class' => AccessControl::className(),
    'only' => ['logout', 'signup','login'],//这里一定要加
    'rules' => [
     [
      'actions' => ['login','captcha'],
      'allow' => true,
      'roles' => ['?'],
     ],
     [
      'actions'=>['logout','edit','add','del','index','users','thumb','upload','cutpic','follow','nofollow'],
      'allow' => true,
      'roles' => ['@'],
     ],
    ],
   ],
   'verbs' => [
    'class' => VerbFilter::className(),
    'actions' => [
     'logout' => ['post'],
    ],
   ],
  ];
 }
 /**
  * @验证码独立操作 下面这个actions注意一点,验证码调试出来的样式也许你并不满意,这里就可
以需修改,这些个参数对应的类是@app\vendor\yiisoft\yii2\captcha\CaptchaAction.php,可以参照这个
类里的参数去修改,也可以直接修改这个类的默认参数,这样这里就不需要改了
  */
 public function actions()
 { 
  return [ 
//     'captcha' => 
//     [
//      'class' => 'yii\captcha\CaptchaAction',
//      'fixedVerifyCode' => YII_ENV_TEST ? 'testme' : null,
//     ], //默认的写法
      'captcha' => [
         'class' => 'yii\captcha\CaptchaAction',
         'fixedVerifyCode' => YII_ENV_TEST ? 'testme' : null,
         'backColor'=>0x000000,//背景颜色
         'maxLength' => 6, //最大显示个数
         'minLength' => 5,//最少显示个数
         'padding' => 5,//间距
         'height'=>40,//高度
         'width' => 130, //宽度 
         'foreColor'=>0xffffff,  //字体颜色
         'offset'=>4,  //设置字符偏移量 有效果
         //'controller'=>'login',  //拥有这个动作的controller
       ],
 ];
 }
Nach dem Login kopieren

Gehen Sie hier zum zweiten Schritt der Steuerung. Der Code des Geräts ist abgeschlossen. Sie sollten auf die hinzuzufügenden Klassen achten und diese nicht verpassen!

Schritt 3:

In der Ansichtsvorlage finden Sie hier login.php und fügen Sie den folgenden Code hinzu

 <?php 
   $form = ActiveForm::begin([
        &#39;id&#39; => &#39;login-form&#39;,         
          ]); 
 ?>
<?php 
 echo Captcha::widget([&#39;name&#39;=>&#39;captchaimg&#39;,&#39;captchaAction&#39;=>&#39;login/captcha&#39;,&#39;imageOptions&#39;=>[&#39;id&#39;=>&#39;captchaimg&#39;, &#39;title&#39;=>&#39;换一个&#39;, &#39;alt&#39;=>&#39;换一个&#39;, &#39;style&#39;=>&#39;cursor:pointer;margin-left:25px;&#39;],&#39;template&#39;=>&#39;{image}&#39;]);//我这里写的跟官方的不一样,因为我这里加了一个参数(login/captcha),这个参数指向你当前控制器名,如果不加这句,就会找到默认的site控制器上去,验证码会一直出不来,在style里是可以写css代码的,可以调试样式 ?>
<?php 
ActiveForm::end(); 
?>
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonAusführliche Erklärung zur Verwendung des mit Yii 2.0 gelieferten Bestätigungscodes. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!