>PHP 프레임워크 >Laravel >Laravel의 검증 방법

Laravel의 검증 방법

WBOY
WBOY원래의
2023-05-20 22:16:361327검색

Laravel은 사용하기 쉽고 강력한 기능을 갖춘 인기 있는 PHP 프레임워크입니다. 중요한 기능 중 하나는 유효성 검사입니다. Laravel은 양식으로 제출된 데이터를 쉽게 확인하고 애플리케이션 데이터의 정확성과 보안을 보장하기 위한 다양한 유효성 검사 방법을 제공합니다. 이번 글에서는 Laravel에서 일반적으로 사용되는 검증 방법을 소개합니다.

  1. 양식 유효성 검사

양식 유효성 검사는 Laravel에서 가장 일반적으로 사용되는 유효성 검사 방법으로, 양식에 의해 제출된 데이터가 지정된 규칙을 준수하는지 확인하는 데 사용됩니다. 각 유효성 검사 규칙은 유효성 검사가 실패할 경우 출력될 오류 메시지를 정의할 수 있습니다. 다음은 양식 유효성 검사의 예입니다.

public function store(Request $request)
{
    $request->validate([
        'name' => 'required|string|max:255',
        'email' => 'required|string|email|max:255|unique:users',
        'password' => 'required|string|min:8|confirmed',
    ]);

    // 数据通过验证,将数据存储到数据库中
}

위의 예에서 $request->validate([]) 메서드는 요청의 데이터 유효성을 검사하는 데 사용됩니다. 이 메서드는 유효성 검사 규칙이 포함된 배열을 허용합니다. 배열의 키 이름은 확인할 필드 이름을 나타내고, 키 값은 필드에 대한 유효성 검사 규칙을 나타냅니다. $request->validate([])方法用于验证请求中的数据。该方法接受一个包含验证规则的数组,数组的键名表示要验证的字段名称,而键值表示该字段的验证规则。

每个验证规则都由一个管道符|分隔,其中包含了该规则的验证参数。例如,required|string|max:255表示字段为必填项、字符串类型,并且最大长度为255个字符。unique:users表示验证该字段在users表格中的唯一性。

如果验证失败,将会自动返回一个错误信息。如果验证成功,将会继续执行下面的代码逻辑。

  1. JSON验证

Laravel还提供了JSON数据验证方法。JSON验证通常用于API接口开发,用于验证发送到服务器的JSON数据是否符合指定规则。与表单验证相似,JSON验证也可以定义验证规则和错误信息。

以下是一个JSON验证的示例:

public function store(Request $request)
{
    $validator = Validator::make($request->all(), [
        'name' => 'required|string|max:255',
        'email' => 'required|string|email|max:255|unique:users',
        'password' => 'required|string|min:8|confirmed',
    ]);

    if ($validator->fails()) {
        return response()->json([
            'status' => 'error',
            'message' => $validator->errors(),
        ], 422);
    }

    // 数据通过验证,将数据存储到数据库中
}

在上面的示例中,使用Validator::make()方法创建一个验证实例。与表单验证不同,make()方法需要传递两个参数:验证的数据和验证规则。如果验证失败,则需要返回一个包含错误信息的JSON响应。如果验证成功,将会继续执行下面的代码逻辑。

  1. 自定义验证规则

除了Laravel内置的验证规则外,开发人员还可以自定义验证规则。自定义规则可以满足特殊的验证需求,例如验证时间、密码强度等。

以下是一个自定义验证规则的示例:

Validator::extend('strong_password', function ($attribute, $value, $parameters, $validator) {
    return preg_match('/^(?=.*[a-zA-Z])(?=.*d)(?=.*(_|[^w])).+$/', $value);
});

$validator = Validator::make($request->all(), [
    'password' => 'required|string|min:8|strong_password',
]);

在上面的示例中,使用Validator::extend()方法创建自定义验证规则strong_password。该方法接受两个参数:规则名称和一个闭包函数,该函数接受四个参数:验证字段名称、验证字段值、验证参数、验证器对象。

在定义自定义规则后,需要在验证器实例中使用自定义规则。如上述代码所示,min:8|strong_password表示密码长度至少为8个字符,并且必须包含至少一个大小写字母、一个数字和一个特殊字符(下划线_除外)。

  1. 错误信息自定义

在开发应用程序时,通常需要自定义验证错误信息。在Laravel中,可以使用message()方法自定义错误信息。

以下是一个自定义验证错误信息的示例:

$validator = Validator::make($request->all(), [
    'name' => 'required|string|max:255',
    'email' => 'required|string|email|max:255|unique:users',
    'password' => 'required|string|min:8|confirmed',
]);

$validator->message('email.required', '邮箱不能为空');

if ($validator->fails()) {
    return response()->json([
        'status' => 'error',
        'message' => $validator->errors(),
    ], 422);
}

在上面的示例中,使用message()

각 유효성 검사 규칙은 규칙의 유효성 검사 매개 변수가 포함된 파이프 문자 |로 구분됩니다. 예를 들어 required|string|max:255는 필드가 필수이고 문자열 유형이며 최대 길이가 255자임을 나타냅니다. unique:usersusers 테이블에서 이 필드의 고유성을 확인하는 것을 의미합니다.

인증에 실패하면 자동으로 오류 메시지가 반환됩니다. 검증에 성공하면 다음 코드 로직이 계속 실행됩니다. 🎜
    🎜JSON 유효성 검사🎜🎜🎜Laravel은 JSON 데이터 유효성 검사 방법도 제공합니다. JSON 유효성 검사는 일반적으로 API 인터페이스 개발에서 서버로 전송된 JSON 데이터가 지정된 규칙을 준수하는지 확인하는 데 사용됩니다. 양식 유효성 검사와 마찬가지로 JSON 유효성 검사도 유효성 검사 규칙과 오류 메시지를 정의할 수 있습니다. 🎜🎜다음은 JSON 유효성 검사의 예입니다. 🎜rrreee🎜위 예에서는 Validator::make() 메서드를 사용하여 유효성 검사 인스턴스를 생성합니다. 양식 유효성 검사와 달리 make() 메서드에는 유효성 검사 데이터와 유효성 검사 규칙이라는 두 가지 매개 변수를 전달해야 합니다. 유효성 검사에 실패하면 오류 정보가 포함된 JSON 응답이 반환되어야 합니다. 검증에 성공하면 다음 코드 로직이 계속 실행됩니다. 🎜
      🎜사용자 정의 유효성 검사 규칙🎜🎜🎜Laravel에 내장된 유효성 검사 규칙 외에도 개발자는 유효성 검사 규칙을 사용자 정의할 수도 있습니다. 사용자 정의 규칙은 확인 시간, 비밀번호 강도 등과 같은 특별한 확인 요구 사항을 충족할 수 있습니다. 🎜🎜다음은 사용자 정의 유효성 검사 규칙의 예입니다. 🎜rrreee🎜위 예에서 사용자 정의 유효성 검사 규칙 strong_passwordValidator::extend() 메서드를 사용하여 생성됩니다. . 이 메소드는 규칙 이름과 유효성 검사 필드 이름, 유효성 검사 필드 값, 유효성 검사 매개 변수 및 유효성 검사기 개체의 네 가지 매개 변수를 허용하는 클로저 함수라는 두 가지 매개 변수를 허용합니다. 🎜🎜사용자 정의 규칙을 정의한 후에는 유효성 검사기 인스턴스에서 사용자 정의 규칙을 사용해야 합니다. 위 코드에서 볼 수 있듯이 min:8|strong_password는 비밀번호가 8자 이상이어야 하며 대문자와 소문자, 숫자, 특수 문자가 각각 1개 이상 포함되어야 함을 의미합니다. 밑줄_). 🎜
        🎜오류 메시지 사용자 정의🎜🎜🎜애플리케이션을 개발할 때 유효성 검사 오류 메시지를 사용자 정의해야 하는 경우가 많습니다. Laravel에서는 message() 메서드를 사용하여 오류 메시지를 맞춤 설정할 수 있습니다. 🎜🎜다음은 유효성 검사 오류 메시지를 사용자 정의하는 예입니다. 🎜rrreee🎜위 예에서는 message() 메서드를 사용하여 오류 메시지를 사용자 정의합니다. 이 메서드는 유효성 검사 규칙 이름과 사용자 지정 오류 메시지라는 두 가지 매개 변수를 허용합니다. 🎜🎜위 내용은 Laravel에서 일반적으로 사용되는 검증 방법입니다. 신청서를 작성할 때 올바른 검증 방법을 사용하면 데이터의 정확성과 보안을 효과적으로 보장할 수 있습니다. 🎜

위 내용은 Laravel의 검증 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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