laravel 폼 검증 여러 필드 조합 을 실현 한 후 유일 합 니 다.
1.컨트롤 러 의 vaidate 방법 으로 매개 변수 검증
/**
* 。
*
* @param Request $request
* @return Response
*/
public function store(Request $request)
{
$this->validate($request, [
'title' => 'required|unique:posts|max:255',
'body' => 'required',
]);
// ,
}
2.수 동 으로 검증 기 인 스 턴 스 를 만 들 고 검증 합 니 다.기본 인증 정보 사용
/**
* 。
*
* @param Request $request
* @return Response
*/
public function store(Request $request)
{
$rules = [
'title' => 'required|unique:posts|max:255',
'body' => 'required',
];
$validator = Validator::make($request->all(), $rules);
if ($validator->fails()) {
return redirect('post/create')->withErrors($validator)->withInput();
}
// ,
}
사용자 정의 인증 정보 사용
/**
* 。
*
* @param Request $request
* @return Response
*/
public function store(Request $request)
{
$rules = [
'title' => 'required|unique:posts|max:255',
'body' => 'required',
];
$messages = [
'title.required' => ' ',
'title.unique' => ' ',
'title.max' => ' 255 ',
'body.required' => ' ',
];
$validator = Validator::make($request->all(), $rules, $messages);
if ($validator->fails()) {
return redirect('post/create')->withErrors($validator)->withInput();
}
// ,
}
3.폼 생 성 요청 검증폼 생 성 요청 파일:php artisan make:request ExampleRequest
폼 요청 파일 내용:
<?php
namespace App\Http\Requests;
use Illuminate\Contracts\Validation\Validator;
use Illuminate\Foundation\Http\FormRequest;
use Illuminate\Http\Exceptions\HttpResponseException;
use Illuminate\Http\JsonResponse;
class ExampleRequest extends FormRequest
{
/**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize()
{
return true;
}
/**
* Get the validation rules that apply to the request.
*
* @return array
*/
public function rules()
{
return [
'title' => 'required|max:20',
'name' => ['required', new Uppercase()],
];
}
/**
* 。
*
* @return array
*/
public function messages()
{
return [
'title.required' => 'A title is required',
'title.max' => 'The title may not be greater than 20 characters.',
];
}
/**
* form ajax json api
* ,
*
* @param Validator $validator
* @throws
*/
protected function failedValidation(Validator $validator)
{
if ($this->wantsJson() || $this->ajax()) {
throw new HttpResponseException(
new JsonResponse([
'code' => 500,
'msg' => $validator->errors()->first(),
'data' => new \stdClass()
])
);
} else {
parent::failedValidation($validator);
}
}
}
컨트롤 러 에 ExampleRequest 사용 하기
<?php
namespace App\Http\Controllers;
use App\Http\Controllers\Controller;
use App\Http\Requests\ExampleRequest;
class ExampleController extends Controller
{
public function valid(ExampleRequest $request)
{
$params = $request->all();
dd($params);
}
}
laravel 폼 검증 에 서 는 몇 개의 필드 를 조합 하여 유일한 제한 을 해 야 하 는 경우 가 많 습 니 다.해결 방안 은 다음 과 같다.
where[] = ['parentId','=',where[]=[′parentId ′,′ = ′,this->request->get('parentId')];
return [
'menuTitle' => ['required', 'max:32','min:2',Rule::unique('admin_menu','menuTitle')->where(function($query)use($where){
$query->where($where)->whereNull('deleted_at');
})->ignore($id) ],
'menuTitleEn' => ['required', 'max:32','min:2',Rule::unique('admin_menu','menuTitleEn')->where(function($query)use($where){
$query->where($where)->whereNull('deleted_at');
})->ignore($id) ],
'menuRoute' => ['required',Rule::unique('admin_menu','menuRoute')->ignore($id)],
'menuIcon' => ['required', 'min:2','max:32'],
'routeName' => ['sometimes', 'min:2','max:32'],
'parentId' => ['required','numeric'],
'order'=>['sometimes','numeric']
];
여기 서 laravel 폼 검증 이 여러 필드 조합 을 실현 한 후 유일한 글 을 소개 합 니 다.더 많은 관련 laravel 폼 검증 내용 은 우리 의 이전 글 을 검색 하거나 아래 의 관련 글 을 계속 조회 하 시기 바 랍 니 다.앞으로 많은 응원 바 랍 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Laravel - 변환된 유효성 검사 규칙으로 API 요청 제공동적 콘텐츠를 위해 API를 통해 Laravel CMS에 연결하는 모바일 앱(또는 웹사이트) 구축을 고려하십시오. 이제 앱은 CMS에서 번역된 콘텐츠를 받을 것으로 예상되는 다국어 앱이 될 수 있습니다. 일반적으로 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.