ホームページ >バックエンド開発 >PHPチュートリアル >Yii Framework 公式ガイド シリーズ 18 - フォームの使用: アクションの作成
モデルを手に入れたら、このモデルを操作するためのロジックを書き始めることができます。 このロジックをコントローラーのアクションに組み込みます。ログイン フォームの例の場合、対応するコードは次のとおりです:
public function actionLogin() { $model=new LoginForm; if(isset($_POST['LoginForm'])) { // 收集用户输入的数据 $model->attributes=$_POST['LoginForm']; // 验证用户输入,并在判断输入正确后重定向到前一页 if($model->validate()) $this->redirect(Yii::app()->user->returnUrl); } // 显示登录表单 $this->render('login',array('model'=>$model)); }
上に示すように、リクエストが POST リクエスト (つまり、このログイン フォーム) の場合は、最初に LoginForm
モデルのサンプルを作成します。が送信されている場合)、送信されたデータ $_POST['LoginForm']
を使用して $model
を入力し、この入力を検証し、検証が成功した場合は繰り返します。ユーザーのブラウザを、以前に認証が必要だったページに誘導します。 検証が失敗した場合、またはこのアクションに初めてアクセスした場合は、login
ビューが表示されます。このビューの内容については、次のセクションで説明します。 LoginForm
模型示例; 如果请求是一个 POST 请求(意味着这个登录表单被提交了),我们则使用提交的数据 $_POST['LoginForm']
填充 $model
;然后我们验证此输入,如果验证成功,重定向用户浏览器到之前需要身份验证的页面。 如果验证失败,或者此动作被初次访问,我们则渲染 login
视图,此视图的内容我们在下一节中讲解。
提示: 在
login
动作中,我们使用Yii::app()->user->returnUrl
获取之前需要身份验证的页面URL。 组件Yii::app()->user
是一种 CWebUser (或其子类) ,它表示用户会话信息(例如 用户名,状态)。更多详情, 请参考 验证与授权.
让我们特别留意一下 login
动作中出现的下面的 PHP 语句:
$model->attributes=$_POST['LoginForm'];
正如我们在 安全的特性赋值 中所讲的, 这行代码使用用户提交的数据填充模型。 attributes
属性由 CModel定义,它接受一个名值对数组并将其中的每个值赋给相应的模型特性。 因此如果 $_POST['LoginForm']
给了我们这样的一个数组,上面的那段代码也就等同于下面冗长的这段 (假设数组中存在所有所需的特性):
$model->username=$_POST['LoginForm']['username']; $model->password=$_POST['LoginForm']['password']; $model->rememberMe=$_POST['LoginForm']['rememberMe'];
注意: 为了使
$_POST['LoginForm']
传递给我们的是一个数组而不是字符串, 我们需要在命名表单域时遵守一个规范。具体的,对应于模型类C
中的特性a
的表单域,我们将其命名为C[a]
。例如,我们可使用LoginForm[username]
命名username
特性相应的表单域。
现在剩下的工作就是创建 login
ヒント:login
アクションでは、Yii::app()- を使用します。 >user->returnUrl
以前に認証を必要としたページの URL を取得します。 コンポーネントYii::app()->user
は、ユーザー セッション情報 (ユーザー名、ステータスなど) を表す CWebUser (またはそのサブクラス) です。詳細については、「認証と認可」を参照してください。
login
アクションに表示される次の PHP ステートメントに特に注意してください: 🎜🎜🎜🎜🎜🎜rrreee🎜🎜 🎜安全なプロパティの割り当てで説明したように、このコード行はユーザーが送信したデータをモデルに設定します。 attributes
属性は CModel によって定義され、名前と値のペアの配列を受け取り、各値を対応するモデル属性に割り当てます。 したがって、$_POST['LoginForm']
が次のような配列を提供する場合、上記のコードは次の長い段落と同等になります (必要なプロパティがすべて配列内に存在すると仮定します): 🎜🎜🎜🎜 🎜🎜rrreee🎜🎜🎜注:🎜あとは、$_POST['LoginForm']
に文字列の代わりに配列を渡すようにするには、フォームフィールドに名前を付けるときの規則。具体的には、モデル クラスC
の機能a
のフォーム フィールドに対応して、C[a]
という名前を付けます。たとえば、LoginForm[username]
を使用して、username
属性に対応するフォーム フィールドに名前を付けることができます。 🎜
login
ビューを作成するだけです。このビューには、必要な入力を含む HTML フォームが含まれている必要があります。 🎜🎜上記は、Yii Framework 公式ガイド シリーズ 18 - フォームの使用: アクションの作成です。その他の関連コンテンツについては、PHP 中国語 Web サイト (www.php.cn) に注目してください。 🎜