백엔드 개발 PHP 튜토리얼 ThinkPHP의 create() 메소드 자동 확인 정보

ThinkPHP의 create() 메소드 자동 확인 정보

Jun 08, 2018 pm 03:55 PM
thinkphp

다음은 ThinkPHP에서 create() 메소드를 자동으로 확인하는 예입니다. 내용이 꽤 괜찮아서 지금 공유해서 참고용으로 올려드리겠습니다.

자동 검증은 ThinkPHP 모델 계층에서 제공하는 데이터 검증 방법으로, create를 사용하여 데이터 개체를 생성할 때 자동으로 데이터 검증을 수행할 수 있습니다.

원리:

create() 메소드는 양식($_POST) 정보를 수집하여 반환하는 동시에 양식의 자동 확인을 트리거하고 불법 필드를 필터링합니다.

컨트롤러에서 create() 메소드를 사용합니다. , (반환 값은 true/false임) 모델 클래스의 $_validate 속성을 자동으로 트리거하고(상위 클래스 Model의 메소드이며 하위 클래스 Model에서 다시 작성됨) $_validate에서 확인 규칙을 사용자 정의합니다( 검증 규칙은 아래에서 자세히 설명합니다) , create() 메소드에 데이터가 없고 반환 값이 false인 경우 $xxx 객체->getError();를 통해 오류 정보를 얻어 반환합니다!

자동 검증 사용은 다음 규칙 형식에 따라 정의되어야 합니다.

protected $_validate = array(  
 array(验证字段1,验证规则,错误提示,[验证条件,附加规则,验证时间]), 
 array(验证字段2,验证规则,错误提示,[验证条件,附加规则,验证时间]),
  ......
);
로그인 후 복사

여기서 검증 필드, 검증 규칙 및 오류 프롬프트가 필요하며 검증 조건, 추가 규칙 및 검증 시간은 다음과 같습니다. 선택 과목!

유효성 검사 필드(필수): 양식 필드.

검증 규칙(필수): 필수 필드는 이메일 주소, URL URL 주소, 번호여야 하며 추가 규칙과 함께 사용할 수도 있습니다.

오류 프롬프트(필수): 인증 실패 시 반환되는 프롬프트 메시지입니다.

검증 조건(선택): 0, 1, 2 세 가지가 있습니다. 0: _POST에 존재하는 필드 검증, 기본값 1: 검증 규칙이 정의된 경우 검증이 필요합니다. 비어 있지 않습니다.

추가 규칙:

regex정규 검증, 정의된 검증 규칙은 정규 표현식입니다(기본값)
function함수 검증, 정의된 검증 규칙은 함수 이름
callback메서드 검증, 정의된 검증 규칙은 현재 모델 클래스의 메서드
confirm양식의 두 필드가 동일한지 확인합니다. 정의된 검증 규칙은 필드입니다. name
equal 이전 유효성 검사 규칙에서 정의한 특정 값과 같은지 확인
notequal이전 유효성 검사 규칙에서 정의한 특정 값과 같지 않은지 확인 유효성 검사 규칙 (버전 3.1.2의 새로운 기능)
in정의된 확인 규칙은 배열이거나 쉼표로 구분된 문자열일 수 있습니다.
notin여부를 확인하세요. 정의된 확인 규칙은 배열 또는 쉼표로 구분된 문자열일 수 있습니다(3.1.2 버전의 새로운 기능).
length 확인 길이는 숫자일 수 있습니다(고정된 문자열을 나타냄). 길이) 또는 숫자 범위(예: 3,12는 3~12 범위의 길이를 나타냄)
between검증 범위, 정의된 검증 규칙은 범위를 나타내며, 문자열이나 배열을 사용할 수 있습니다. 1,31 또는 array(1,31)
notbetween특정 범위에 속하지 않는지 확인하세요. 정의된 확인 규칙은 범위를 나타내며 문자열이나 배열을 사용할 수 있습니다(버전 3.1.2의 새로운 기능).
expire 유효 기간 내에 있는지 확인하기 위해 정의된 확인 규칙은 시간 범위를 나타내며 이는 최대 시간까지 가능합니다. 예를 들어 2012 -1-15,2013-1-을 사용할 수 있습니다. 15는 현재 제출 유효 기간이 2012-1-15에서 2013-1-15 사이임을 의미합니다. 또한 타임스탬프 정의
ip_allow를 사용하여 IP가 허용되는지 여부와 정의된 확인을 확인할 수도 있습니다. 허용된 IP 주소 목록(예: 201.12.2.5,201.12.2.6
ip_deny 해당 IP가 금지되었는지 확인하고 정의된 확인 규칙은 금지된 IP 주소 목록을 쉼표로 구분하여 나타냄) (예: 201.12.2.5, 201.12.2.6
unique 시스템은 필드의 현재 값을 기반으로 데이터베이스를 쿼리하여 동일한 값이 있는지 확인합니다. 기본 키 필드, 고유는 기본 키 필드 자체를 결정하는 데 사용할 수 없습니다

验证时间(可选):共有1,2,3三种,1:新增数据时候验证;2:编辑数据时候验证;3:全部情况下验证(默认);也可以可以根据业务需要增加其他的验证时间

下面附上代码:以注册为例

前台页面比较简单,代码就不贴出来了,下面是前台注册界面截图

控制器代码:

//注册
 public function register(){
  $user = new \Model\UserModel();

  //两个逻辑:收集,展示
  if (!empty($_POST)) {
  
  //create()方法收集表单($_POST)信息并返回,同时触发表单自动验证,过滤非法字段
  $date = $user->create();
  //通过create()方法的返回值$date判断验证是否成功
  if ($date) { //返回实在数据的时候才进行添加
   //implode()把数组变为字符串
   $date['user_hobby'] = implode(',', $date['user_hobby']);
   $info = $user->add($date);
   if ($info) {
   
   //跳转首页   
   $this->redirect('Index/index');
   }
  }else{

   //把错误信息分配到前台模板
   $error = $user->getError();
   $this->assign('error',$error);
  }
  }
  //调用view视图
  $this->display();
 }
로그인 후 복사

模型类代码:

class UserModel extends Model{
 
 //是否批量处理验证,批量获取全部的错误验证信息
 protected $patchValidate = true; //默认为false

 //自动验证定义
 protected $_validate = array(

  //array(字段,验证规则,错误提示,验证条件,附加规则,验证时间)
  //①用户名验证,不能为空
  array('username','require','用户名不能为空'),
  array('username','','该用户名已经被占用','0','unique'),
  //②密码验证,不为空
  array('password','require','密码不能为空'),
  //③验证确认密码,必须填写,与密码保持一致
  array('password2','require','确认密码必须填写'),
  array('password2','password','两次密码保持一致',0,'confirm'),
  //④邮箱验证
  array('user_email','email','邮箱格式不正确',2),
  //⑤qq验证,数字组成,5-12位
  array('user_qq','number','qq必须是数字'),
  array('user_qq','5,12','位数在5-12位之间',0,'length'),
  //⑥学历验证,必须选一个
  array('user_xueli','2,5','学位必须选择一个',0,'between'),
  //⑦爱好验证,必须选择二个以上
  //因为爱好返回的是数组,附加规则中没有可以直接用的规则,所以需自定义方法,用callback方法验证
  array('user_hobby','check_hobby','爱好必须选两项或以上',1,'callback'),
  );

 //定义方法进行爱好验证
 //参数$arg代表被验证的表单信息
 function check_hobby($arg)
 {
  //判断数组长度是否大于2
  if (count($arg)<2) {
   return false; //会自动输出验证错误信息
  }
  return true;
 }
}
로그인 후 복사

把验证的错误信息在模板中给展示出来(部分代码)

<td style="width:13%; text-align: right;">
 <label for="User_username" class="required">用户名 
 <span>*</span></label>
</td>

<td style="width:87%;">
 <input class="inputBg" size="25" name="username" id="User_username" type="text" value="" />     
 <span style="color:red;"><{$error.username|default:""}></span>
</td>
로그인 후 복사

结果:

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

对THINKPHP的addAll支持的最大数据量的分析

关于ThinkPHP CURD方法之table方法

关于ThinkPHP利用getlist方法实现数据搜索功能的分析

위 내용은 ThinkPHP의 create() 메소드 자동 확인 정보의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

thinkphp 프로젝트를 실행하는 방법 thinkphp 프로젝트를 실행하는 방법 Apr 09, 2024 pm 05:33 PM

ThinkPHP 프로젝트를 실행하려면 다음이 필요합니다: Composer를 설치하고, 프로젝트 디렉터리를 입력하고 php bin/console을 실행하고, 시작 페이지를 보려면 http://localhost:8000을 방문하세요.

thinkphp에는 여러 버전이 있습니다. thinkphp에는 여러 버전이 있습니다. Apr 09, 2024 pm 06:09 PM

ThinkPHP에는 다양한 PHP 버전용으로 설계된 여러 버전이 있습니다. 메이저 버전에는 3.2, 5.0, 5.1, 6.0이 포함되며, 마이너 버전은 버그를 수정하고 새로운 기능을 제공하는 데 사용됩니다. 최신 안정 버전은 ThinkPHP 6.0.16입니다. 버전을 선택할 때 PHP 버전, 기능 요구 사항 및 커뮤니티 지원을 고려하십시오. 최상의 성능과 지원을 위해서는 최신 안정 버전을 사용하는 것이 좋습니다.

thinkphp를 실행하는 방법 thinkphp를 실행하는 방법 Apr 09, 2024 pm 05:39 PM

ThinkPHP Framework를 로컬에서 실행하는 단계: ThinkPHP Framework를 로컬 디렉터리에 다운로드하고 압축을 풉니다. ThinkPHP 루트 디렉터리를 가리키는 가상 호스트(선택 사항)를 만듭니다. 데이터베이스 연결 매개변수를 구성합니다. 웹 서버를 시작합니다. ThinkPHP 애플리케이션을 초기화합니다. ThinkPHP 애플리케이션 URL에 접속하여 실행하세요.

laravel과 thinkphp 중 어느 것이 더 낫나요? laravel과 thinkphp 중 어느 것이 더 낫나요? Apr 09, 2024 pm 03:18 PM

Laravel과 ThinkPHP 프레임워크의 성능 비교: ThinkPHP는 일반적으로 최적화 및 캐싱에 중점을 두고 Laravel보다 성능이 좋습니다. Laravel은 잘 작동하지만 복잡한 애플리케이션의 경우 ThinkPHP가 더 적합할 수 있습니다.

개발 제안: ThinkPHP 프레임워크를 사용하여 비동기 작업을 구현하는 방법 개발 제안: ThinkPHP 프레임워크를 사용하여 비동기 작업을 구현하는 방법 Nov 22, 2023 pm 12:01 PM

"개발 제안: ThinkPHP 프레임워크를 사용하여 비동기 작업을 구현하는 방법" 인터넷 기술의 급속한 발전으로 인해 웹 응용 프로그램은 많은 수의 동시 요청과 복잡한 비즈니스 논리를 처리하기 위한 요구 사항이 점점 더 높아졌습니다. 시스템 성능과 사용자 경험을 향상시키기 위해 개발자는 이메일 보내기, 파일 업로드 처리, 보고서 생성 등과 같이 시간이 많이 걸리는 작업을 수행하기 위해 비동기 작업을 사용하는 것을 종종 고려합니다. PHP 분야에서 널리 사용되는 개발 프레임워크인 ThinkPHP 프레임워크는 비동기 작업을 구현하는 몇 가지 편리한 방법을 제공합니다.

thinkphp를 설치하는 방법 thinkphp를 설치하는 방법 Apr 09, 2024 pm 05:42 PM

ThinkPHP 설치 단계: PHP, Composer 및 MySQL 환경을 준비합니다. Composer를 사용하여 프로젝트를 만듭니다. ThinkPHP 프레임워크와 종속성을 설치합니다. 데이터베이스 연결을 구성합니다. 애플리케이션 코드를 생성합니다. 애플리케이션을 실행하고 http://localhost:8000을 방문하세요.

thinkphp 성능은 어떤가요? thinkphp 성능은 어떤가요? Apr 09, 2024 pm 05:24 PM

ThinkPHP는 캐싱 메커니즘, 코드 최적화, 병렬 처리 및 데이터베이스 최적화와 같은 장점을 갖춘 고성능 PHP 프레임워크입니다. 공식 성능 테스트에 따르면 초당 10,000개 이상의 요청을 처리할 수 있으며 JD.com, Ctrip과 같은 대규모 웹 사이트 및 엔터프라이즈 시스템에서 실제 응용 프로그램으로 널리 사용됩니다.

개발 제안: API 개발을 위해 ThinkPHP 프레임워크를 사용하는 방법 개발 제안: API 개발을 위해 ThinkPHP 프레임워크를 사용하는 방법 Nov 22, 2023 pm 05:18 PM

개발 제안: API 개발을 위해 ThinkPHP 프레임워크를 사용하는 방법 인터넷이 지속적으로 발전하면서 API(응용 프로그래밍 인터페이스)의 중요성이 점점 더 커지고 있습니다. API는 데이터 공유, 함수 호출 및 기타 작업을 실현할 수 있으며 개발자에게 비교적 간단하고 빠른 개발 방법을 제공합니다. 뛰어난 PHP 개발 프레임워크인 ThinkPHP 프레임워크는 효율적이고 확장 가능하며 사용하기 쉽습니다.

See all articles