목차
1. 모델 클래스 정의
2. 유효성 검사 규칙 선언
3. 安全的特性赋值
4. 触发验证
5. 提取验证错误
6. 特性标签
백엔드 개발 PHP 튜토리얼 Yii 프레임워크 공식 가이드 시리즈 17 - 양식 사용: 모델 생성

Yii 프레임워크 공식 가이드 시리즈 17 - 양식 사용: 모델 생성

Feb 13, 2017 am 09:10 AM



양식에 필요한 HTML 코드를 작성하기 전에 먼저 최종 사용자 입력에서 오는 데이터 유형과 데이터가 무엇인지 결정해야 합니다. 그러한 규칙을 따르십시오. 모델 클래스를 사용하여 이 정보를 기록할 수 있습니다. 모델 장에서 정의한 대로 모델은 사용자 입력을 저장하고 해당 입력을 검증하는 중앙 위치입니다.

사용자가 입력한 데이터가 어떻게 사용되는지에 따라 두 가지 유형의 모델을 만들 수 있습니다. 사용자 입력을 수집하고 사용한 다음 삭제하는 경우 양식 모델을 만들어야 하며, 사용자 입력을 수집한 후 데이터베이스에 저장하는 경우 활성 레코드를 사용해야 합니다. 두 가지 유형의 모델 모두 양식에 필요한 공통 인터페이스를 정의하는 동일한 기본 클래스 CModel을 공유합니다.

참고: 이 섹션의 예에서는 주로 양식 모델을 사용합니다. 그러나 Active Record 모델에도 동일한 작업이 적용될 수 있습니다.

1. 모델 클래스 정의

아래에서는 로그인 페이지에서 사용자 입력을 수집하기 위한 LoginForm 모델 클래스를 만듭니다. 로그인 정보는 사용자 인증을 위해서만 사용되며 저장할 필요가 없으므로 폼 모델로 LoginForm을 생성하겠습니다.


class LoginForm extends CFormModel
{
    public $username;
    public $password;
    public $rememberMe=false;
}
로그인 후 복사

LoginForm$username, $password$rememberMe의 세 가지 속성을 정의합니다. 이는 사용자가 입력한 사용자 이름과 비밀번호를 저장하는 데 사용되며 사용자가 자신의 로그인을 기억하려는 경우에도 사용할 수 있습니다. $rememberMe의 기본값은 false이므로 로그인 양식에 처음 표시될 때 해당 옵션이 선택 취소됩니다.

정보: 이러한 멤버 변수를 일반 속성과 구별하기 위해 속성 대신 속성이라고 부릅니다. 속성은 주로 사용자 입력이나 데이터베이스의 데이터를 저장하는 데 사용되는 속성입니다.

2. 유효성 검사 규칙 선언

사용자가 입력을 제출하고 모델이 채워지면 사용하기 전에 사용자의 입력이 유효한지 확인해야 합니다. 이는 일련의 규칙에 대해 사용자 입력을 검증함으로써 달성됩니다. 규칙 구성 배열을 반환해야 하는 rules() 메서드에 이러한 유효성 검사 규칙을 지정합니다.


class LoginForm extends CFormModel
{
    public $username;
    public $password;
    public $rememberMe=false;

    private $_identity;

    public function rules()
    {
        return array(
            array('username, password', 'required'),
            array('rememberMe', 'boolean'),
            array('password', 'authenticate'),
        );
    }

    public function authenticate($attribute,$params)
    {
        $this->_identity=new UserIdentity($this->username,$this->password);
        if(!$this->_identity->authenticate())
            $this->addError('password','错误的用户名或密码。');
    }
}
로그인 후 복사

위 코드는 usernamepassword가 필수이며 password를 확인해야 함을 지정합니다( 인증됨), rememberMe은 부울 값이어야 합니다.

rules() 반환된 각 규칙은 다음 형식이어야 합니다.


array('AttributeList', 'Validator', 'on'=>'ScenarioList', ...附加选项)
로그인 후 복사

여기서 AttributeList(特性列表)는 이 규칙으로 확인해야 하는 기능의 목록 문자열입니다. 각 기능 이름은 쉼표로 구분됩니다. Validator(验证器)는 수행할 확인 유형을 지정하고 on 매개변수는 선택 사항입니다. 규칙이 적용되어야 합니다. 추가 옵션은 해당 유효성 검사기의 속성 값을 초기화하는 데 사용되는 이름-값 쌍의 배열입니다.

유효성 검사 규칙에 Validator을 지정하는 방법에는 세 가지가 있습니다.

먼저 Validator는 위 예시의 처럼 모델 클래스 authenticate에 있는 메서드의 이름일 수 있습니다. 검증 방법은 다음 구조여야 합니다.


/**
 * @param string 所要验证的特性的名字
 * @param array 验证规则中指定的选项
 */
public function ValidatorName($attribute,$params) { ... }
로그인 후 복사

둘째, Validator는 검증자가 될 수 있습니다. 클래스의 이름입니다. 이 규칙이 적용되면 실제 유효성 검사를 수행하는 유효성 검사기 클래스의 인스턴스가 생성됩니다. 규칙의 추가 옵션은 인스턴스의 속성 값을 초기화하는 데 사용됩니다. Validator 클래스는 CValidator에서 상속되어야 합니다.

셋째, Validator은 미리 정의된 유효성 검사기 클래스 의 별칭일 수 있습니다. 위의 예에서 required 이름은 유효성을 검사하는 속성 값이 비어 있지 않은지 확인하는 데 사용되는 CRequiredValidator의 별칭입니다. 다음은 사전 정의된 유효성 검사기 별칭의 전체 목록입니다.

  • boolean: CBooleanValidator에 대한 별칭입니다. 속성에 CBooleanValidator::trueValue 또는 CBooleanValidator::falseValue 값이 있는지 확인하세요.

  • captcha: CCaptchaValidator의 별칭으로, 속성 값이 CAPTCHA에 표시된 확인 코드와 동일한지 확인합니다.

  • compare: CCompareValidator의 별칭으로, 속성이 다른 속성 또는 상수와 동일하도록 보장합니다.

  • email: CEmailValidator의 별칭, 속성이 유효한 이메일 주소인지 확인합니다.

  • default: CDefaultValueValidator의 별칭, 속성의 기본값을 지정합니다.

  • exist: CExistValidator 的别名,确保特性值可以在指定表的列中可以找到。

  • file: CFileValidator 的别名,确保特性含有一个上传文件的名字。

  • filter: CFilterValidator 的别名,通过一个过滤器改变此特性。

  • in: CRangeValidator 的别名,确保数据在一个预先指定的值的范围之内。

  • length: CStringValidator 的别名,确保数据的长度在一个指定的范围之内。

  • match: CRegularExpressionValidator 的别名,确保数据可以匹配一个正则表达式。

  • numerical: CNumberValidator 的别名,确保数据是一个有效的数字。

  • required: CRequiredValidator 的别名,确保特性不为空。

  • type: CTypeValidator 的别名,确保特性是指定的数据类型。

  • unique: CUniqueValidator 的别名,确保数据在数据表的列中是唯一的。

  • url: CUrlValidator 的别名,确保数据是一个有效的 URL。

下面我们列出了几个只用这些预定义验证器的示例:


// 用户名为必填项
array('username', 'required'),
// 用户名必须在 3 到 12 个字符之间
array('username', 'length', 'min'=>3, 'max'=>12),
// 在注册场景中,密码password必须和password2一致。
array('password', 'compare', 'compareAttribute'=>'password2', 'on'=>'register'),
// 在登录场景中,密码必须接受验证。
array('password', 'authenticate', 'on'=>'login'),
로그인 후 복사

3. 安全的特性赋值

在一个类的实例被创建后,我们通常需要用最终用户提交的数据填充它的特性。 这可以通过如下块赋值(massive assignment)方式轻松实现:


$model=new LoginForm;
if(isset($_POST['LoginForm']))
    $model->attributes=$_POST['LoginForm'];
로그인 후 복사

最后的表达式被称作 块赋值(massive assignment) ,它将 $_POST['LoginForm'] 中的每一项复制到相应的模型特性中。这相当于如下赋值方法:


foreach($_POST['LoginForm'] as $name=>$value)
{
    if($name 是一个安全的特性)
        $model->$name=$value;
}
로그인 후 복사

检测特性的安全非常重要,例如,如果我们以为一个表的主键是安全的而暴露了它,那么攻击者可能就获得了一个修改记录的主键的机会, 从而篡改未授权给他的内容。

检测特性安全的策略在版本 1.0 和 1.1 中是不同的,下面我们将分别讲解:

1.1 中的安全特性

在版本 1.1 中,特性如果出现在相应场景的一个验证规则中,即被认为是安全的。 例如:


array('username, password', 'required', 'on'=>'login, register'),
array('email', 'required', 'on'=>'register'),
로그인 후 복사

如上所示, username 和 password 特性在 login 场景中是必填项。而 usernamepassword 和 email 特性在register 场景中是必填项。 于是,如果我们在 login 场景中执行块赋值,就只有 username 和 password 会被块赋值。 因为只有它们出现在 login 的验证规则中。 另一方面,如果场景是 register ,这三个特性就都可以被块赋值。


// 在登录场景中
$model=new User('login');
if(isset($_POST['User']))
    $model->attributes=$_POST['User'];

// 在注册场景中
$model=new User('register');
if(isset($_POST['User']))
    $model->attributes=$_POST['User'];
로그인 후 복사

那么为什么我们使用这样一种策略来检测特性是否安全呢? 背后的基本原理就是:如果一个特性已经有了一个或多个可检测有效性的验证规则,那我们还担心什么呢?

请记住,验证规则是用于检查用户输入的数据,而不是检查我们在代码中生成的数据(例如时间戳,自动产生的主键)。 因此,不要 为那些不接受最终用户输入的特性添加验证规则。

有时候,我们想声明一个特性是安全的,即使我们没有为它指定任何规则。 例如,一篇文章的内容可以接受用户的任何输入。我们可以使用特殊的 safe 规则实现此目的:


array('content', 'safe')
로그인 후 복사

为了完成起见,还有一个用于声明一个属性为不安全的 unsafe 规则:


array('permission', 'unsafe')
로그인 후 복사

unsafe 规则并不常用,它是我们之前定义的安全特性的一个例外。

1.0 中的安全特性

在版本1.0中,决定一个数据项是否是安全的,基于一个名为 safeAttributes 方法的返回值和数据项被指定的场景. 默认的,这个方法返回所有公共成员变量作为 CFormModel 的安全特性,而它也返回了除了主键外, 表中所有字段名作为 CActiveRecord的安全特性.我们可以根据场景重写这个方法来限制安全特性 .例如, 一个用户模型可以包含很多特性,但是在 login 场景.里,我们只能使用 username 和 password 特性.我们可以按照如下来指定这一限制 :


public function safeAttributes()
{
    return array(
        parent::safeAttributes(),
        'login' => 'username, password',
    );
}
로그인 후 복사

safeAttributes 方法更准确的返回值应该是如下结构的 :


array(
   // these attributes can be massively assigned in any scenario
   // that is not explicitly specified below
   'attr1, attr2, ...',
     *
   // these attributes can be massively assigned only in scenario 1
   'scenario1' => 'attr2, attr3, ...',
     *
   // these attributes can be massively assigned only in scenario 2
   'scenario2' => 'attr1, attr3, ...',
)
로그인 후 복사

如果模型不是场景敏感的(比如,它只在一个场景中使用,或者所有场景共享了一套同样的安全特性),返 回值可以是如下那样简单的字符串.


'attr1, attr2, ...'
로그인 후 복사

而那些不安全的数据项,我们需要使用独立的赋值语句来分配它们到相应的特性.如下所示:


$model->permission='admin';
$model->id=1;
로그인 후 복사

4. 触发验证

一旦模型被用户提交的数据填充,我们就可以调用 CModel::validate() 出发数据验证进程。此方法返回一个指示验证是否成功的值。 对 CActiveRecord 模型来说,验证也可以在我们调用其 CActiveRecord::save() 方法时自动触发。

我们可以使用 scenario 设置场景属性,这样,相应场景的验证规则就会被应用。

验证是基于场景执行的。 scenario 属性指定了模型当前用于的场景和当前使用的验证规则集。 例如,在 login场景中,我们只想验证用户模型中的 username 和 password 输入; 而在 register 场景中,我们需要验证更多的输入,例如 emailaddress, 等。 下面的例子演示了如何在 register 场景中执行验证:


// 在注册场景中创建一个  User 模型。等价于:
// $model=new User;
// $model->scenario='register';
$model=new User('register');

// 将输入的值填充到模型
$model->attributes=$_POST['User'];

// 执行验证
if($model->validate())   // if the inputs are valid
    ...
else
    ...
로그인 후 복사

规则关联的场景可以通过规则中的 on 选项指定。如果 on 选项未设置,则此规则会应用于所有场景。例如:


public function rules()
{
    return array(
        array('username, password', 'required'),
        array('password_repeat', 'required', 'on'=>'register'),
        array('password', 'compare', 'on'=>'register'),
    );
}
로그인 후 복사

第一个规则将应用于所有场景,而第二个将只会应用于 register 场景。

5. 提取验证错误

验证完成后,任何可能产生的错误将被存储在模型对象中。 我们可以通过调用 CModel::getErrors() 和CModel::getError() 提取这些错误信息。 这两个方法的不同点在于第一个方法将返回 所有 模型特性的错误信息,而第二个将只返回 第一个 错误信息。

6. 特性标签

当设计表单时,我们通常需要为每个表单域显示一个标签。 标签告诉用户他应该在此表单域中填写什么样的信息。虽然我们可以在视图中硬编码一个标签, 但如果我们在相应的模型中指定(标签),则会更加灵活方便。

默认情况下 CModel 将简单的返回特性的名字作为其标签。这可以通过覆盖 attributeLabels() 方法自定义。 正如在接下来的小节中我们将看到的,在模型中指定标签会使我们能够更快的创建出更强大的表单。

以上就是Yii框架官方指南系列17——使用表单:创建模型的内容,更多相关内容请关注PHP中文网(www.php.cn)!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Yii 프레임워크에서 RESTful API 개발 Yii 프레임워크에서 RESTful API 개발 Jun 21, 2023 pm 12:34 PM

Yii는 PHP를 기반으로 하는 고성능 MVC 프레임워크로 웹 애플리케이션의 빠르고 효율적인 개발을 지원하는 매우 풍부한 도구 및 기능 세트를 제공합니다. 그 중에서도 Yii 프레임워크의 RESTfulAPI 기능은 점점 더 많은 개발자들의 관심과 사랑을 받고 있습니다. 왜냐하면 Yii 프레임워크를 사용하면 고성능, 쉽게 확장 가능한 RESTful 인터페이스를 쉽게 구축할 수 있고 웹 애플리케이션 개발을 위한 강력한 지원을 제공할 수 있기 때문입니다. RESTfulAPI 소개 RESTfulAPI는

PHP에서 Yii 프레임워크를 사용하는 방법 PHP에서 Yii 프레임워크를 사용하는 방법 Jun 27, 2023 pm 07:00 PM

웹 애플리케이션의 급속한 발전으로 인해 현대적인 웹 개발은 중요한 기술이 되었습니다. 효율적인 웹 애플리케이션 개발을 위해 많은 프레임워크와 도구를 사용할 수 있으며, 그중 Yii 프레임워크가 매우 널리 사용되는 프레임워크입니다. Yii는 최신 디자인 패턴과 기술을 사용하고 강력한 도구와 구성 요소를 제공하며 복잡한 웹 애플리케이션을 구축하는 데 이상적인 고성능 구성 요소 기반 PHP 프레임워크입니다. 이 글에서는 Yii 프레임워크를 사용하여 웹 애플리케이션을 구축하는 방법에 대해 설명합니다. Yii 프레임워크를 먼저 설치하고,

Yii 프레임워크 미들웨어: 애플리케이션에 대한 다중 데이터 스토리지 지원 제공 Yii 프레임워크 미들웨어: 애플리케이션에 대한 다중 데이터 스토리지 지원 제공 Jul 28, 2023 pm 12:43 PM

Yii 프레임워크 미들웨어: 애플리케이션에 대한 다중 데이터 저장소 지원 제공 소개 미들웨어(미들웨어)는 애플리케이션에 대한 다중 데이터 저장소 지원을 제공하는 Yii 프레임워크의 중요한 개념입니다. 미들웨어는 필터처럼 작동하여 애플리케이션의 요청과 응답 사이에 사용자 정의 코드를 삽입합니다. 미들웨어를 통해 요청을 처리, 확인, 필터링한 후 처리된 결과를 다음 미들웨어 또는 최종 처리기로 전달할 수 있습니다. Yii 프레임워크의 미들웨어는 사용하기 매우 쉽습니다.

Yii 프레임워크를 사용하여 웹 페이지 캐싱 및 페이지 청크를 구현하는 단계 Yii 프레임워크를 사용하여 웹 페이지 캐싱 및 페이지 청크를 구현하는 단계 Jul 30, 2023 am 09:22 AM

Yii 프레임워크를 사용하여 웹 페이지 캐싱 및 페이지 청크를 구현하는 단계 소개: 웹 개발 프로세스 중에 웹 사이트의 성능과 사용자 경험을 향상시키기 위해 페이지를 캐시하고 청크해야 하는 경우가 종종 있습니다. Yii 프레임워크는 개발자가 웹 페이지 캐싱 및 페이지 청킹을 신속하게 구현하는 데 도움이 되는 강력한 캐싱 및 레이아웃 기능을 제공합니다. 이 기사에서는 Yii 프레임워크를 사용하여 웹 페이지 캐싱 및 페이지 청킹을 구현하는 방법을 소개합니다. 1. 웹 페이지 캐싱을 활성화합니다. Yii 프레임워크에서는 구성 파일을 통해 웹 페이지 캐싱을 활성화할 수 있습니다. 기본 구성 파일 co를 엽니다.

Yii 프레임워크를 사용하여 게임 가이드 웹사이트 만들기 Yii 프레임워크를 사용하여 게임 가이드 웹사이트 만들기 Jun 21, 2023 pm 01:45 PM

최근 몇 년 동안 게임 산업의 급속한 발전과 함께 점점 더 많은 플레이어가 게임을 통과하는 데 도움이 되는 게임 전략을 찾기 시작했습니다. 따라서 게임 가이드 웹사이트를 만들면 플레이어가 게임 가이드를 더 쉽게 얻을 수 있는 동시에 플레이어에게 더 나은 게임 경험을 제공할 수도 있습니다. 이러한 웹사이트를 만들 때 Yii 프레임워크를 사용하여 개발할 수 있습니다. Yii 프레임워크는 PHP 프로그래밍 언어를 기반으로 하는 웹 애플리케이션 개발 프레임워크입니다. 고효율, 보안성, 강력한 확장성 등의 특징을 가지고 있어 보다 빠르고 효율적으로 게임 가이드를 생성할 수 있도록 도와줍니다.

Yii Framework 미들웨어: 애플리케이션에 로깅 및 디버깅 기능을 추가하세요. Yii Framework 미들웨어: 애플리케이션에 로깅 및 디버깅 기능을 추가하세요. Jul 28, 2023 pm 08:49 PM

Yii 프레임워크 미들웨어: 애플리케이션에 로깅 및 디버깅 기능 추가 [소개] 웹 애플리케이션을 개발할 때 일반적으로 애플리케이션의 성능과 안정성을 향상시키기 위해 몇 가지 추가 기능을 추가해야 합니다. Yii 프레임워크는 애플리케이션이 요청을 처리하기 전후에 몇 가지 추가 작업을 수행할 수 있게 해주는 미들웨어 개념을 제공합니다. 이 글에서는 Yii 프레임워크의 미들웨어 기능을 사용하여 로깅 및 디버깅 기능을 구현하는 방법을 소개합니다. [미들웨어란] 미들웨어란 애플리케이션이 요청을 처리하기 전과 후에 요청과 응답을 처리하는 것을 말합니다.

컨트롤러를 사용하여 Yii 프레임워크에서 Ajax 요청을 처리하는 방법 컨트롤러를 사용하여 Yii 프레임워크에서 Ajax 요청을 처리하는 방법 Jul 28, 2023 pm 07:37 PM

Yii 프레임워크에서 컨트롤러는 요청 처리에 중요한 역할을 합니다. 일반 페이지 요청을 처리하는 것 외에도 컨트롤러를 사용하여 Ajax 요청을 처리할 수도 있습니다. 이 기사에서는 Yii 프레임워크에서 Ajax 요청을 처리하는 방법을 소개하고 코드 예제를 제공합니다. Yii 프레임워크에서 Ajax 요청 처리는 다음 단계를 통해 수행될 수 있습니다. 첫 번째 단계는 컨트롤러(Controller) 클래스를 생성하는 것입니다. Yii 프레임워크에서 제공하는 기본 컨트롤러 클래스 yiiwebCo를 상속받을 수 있습니다.

Yii 프레임워크 미들웨어를 사용하여 민감한 데이터 암호화 및 복호화 Yii 프레임워크 미들웨어를 사용하여 민감한 데이터 암호화 및 복호화 Jul 28, 2023 pm 07:12 PM

Yii 프레임워크 미들웨어를 사용하여 민감한 데이터 암호화 및 해독 소개: 최신 인터넷 애플리케이션에서 개인 정보 보호 및 데이터 보안은 매우 중요한 문제입니다. 승인되지 않은 방문자가 사용자의 민감한 데이터에 접근할 수 없도록 하려면 이 데이터를 암호화해야 합니다. Yii 프레임워크는 민감한 데이터를 암호화하고 해독하는 기능을 구현하는 간단하고 효과적인 방법을 제공합니다. 이 글에서는 Yii 프레임워크의 미들웨어를 사용하여 이를 달성하는 방법을 다룰 것입니다. Yii 프레임워크 소개 Yii 프레임워크는 고성능 PHP 프레임워크입니다.

See all articles