Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Laravel advanced validation rules for real-life scenarios.

License

NotificationsYou must be signed in to change notification settings

arifszn/laravel-advanced-validation

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Laravel advanced validation rules for real-life scenarios.

Installation

Install viacomposer

composer require arifszn/laravel-advanced-validation

Laravel uses Package Auto-Discovery, so doesn't require you to manually add the ServiceProvider.

Translations

If you wish to edit the package translations, you can run the following command to publish them into yourresources/lang folder

php artisan vendor:publish --provider="Arifszn\AdvancedValidation\ServiceProvider"

Custom Error Message

You can specify the error message on the fly when declaring the rules. Simple pass the error message parameter.

useArifszn\AdvancedValidation\Rules\Username;publicfunctionrules(){return ['foo' => [newUsername('Your custom error message')],    ];}

Available Validation Rules

Ascii

The field under validation must contain ASCII chars only.

public Arifszn\AdvancedValidation\Rules\Ascii::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Ascii;publicfunctionrules(){return ['foo' => [newAscii()],    ];}

Base64Image

The field under validation must be a Base64 encoded image.

public Arifszn\AdvancedValidation\Rules\Base64Image::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Base64Image;publicfunctionrules(){return ['avatar' => [newBase64Image()],    ];}

Base64String

The field under validation must be a Base64 encoded string.

public Arifszn\AdvancedValidation\Rules\Base64String::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Base64String;publicfunctionrules(){return ['foo' => [newBase64String()],    ];}

BIC

The field under validation must be a BIC(Business Identifier Code) or SWIFT code.

public Arifszn\AdvancedValidation\Rules\BIC::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\BIC;publicfunctionrules(){return ['foo' => [newBIC()],    ];}

BtcAddress

The field under validation must be a valid BTC address.

public Arifszn\AdvancedValidation\Rules\BtcAddress::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\BtcAddress;publicfunctionrules(){return ['foo' => [newBtcAddress()],    ];}

CreditCard

The field under validation must be a valid credit card number.

public Arifszn\AdvancedValidation\Rules\CreditCard::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\CreditCard;publicfunctionrules(){return ['foo' => [newCreditCard()],    ];}

DataURI

The field under validation must havedata uri format.

public Arifszn\AdvancedValidation\Rules\DataURI::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\DataURI;publicfunctionrules(){return ['foo' => [newDataURI()],    ];}

DivisibleBy

The field under validation must be divisible by the given number.

public Arifszn\AdvancedValidation\Rules\DivisibleBy::__construct(int $number, string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\DivisibleBy;publicfunctionrules(){return ['foo' => [newDivisibleBy(2)],    ];}

EthereumAddress

The field under validation must be anEthereum address. Does not validate address checksums.

public Arifszn\AdvancedValidation\Rules\EthereumAddress::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\EthereumAddress;publicfunctionrules(){return ['foo' => [newEthereumAddress()],    ];}

FloatNumber

The field under validation must be a float number.

public Arifszn\AdvancedValidation\Rules\FloatNumber::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\FloatNumber;publicfunctionrules(){return ['foo' => [newFloatNumber()],    ];}

Hash

The field under validation must be a hash of type algorithm.

Algorithm is one of'md4', 'md5', 'sha1', 'sha256', 'sha384', 'sha512', 'ripemd128', 'ripemd160', 'tiger128', 'tiger160', 'tiger192', 'crc32', 'crc32b'.

public Arifszn\AdvancedValidation\Rules\Hash::__construct(string $algorithm, string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Hash;publicfunctionrules(){return ['foo' => [newHash('md4')],    ];}

ImageURL

The field under validation must be a valid image URL.

https://www.php.net/images/logos/php-logo.png
https://imaginarysite123.com/invalid.png

public Arifszn\AdvancedValidation\Rules\ImageURL::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\ImageURL;publicfunctionrules(){return ['avatar' => [newImageURL()],    ];}

JWT

The field under validation must have a valid format of JWT (JSON Web Token).

public Arifszn\AdvancedValidation\Rules\Jwt::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Jwt;publicfunctionrules(){return ['foo' => [newJwt()],    ];}

Name

The field under validation must be a valid name.

  • no emoji
  • no number (if$allowNumber flag is true, it will accept numbers, default is false)
  • special characters are allowed (restricting special characters will cause false-negative for names likeMartin Luther King, Jr. or李小龍)
public Arifszn\AdvancedValidation\Rules\Name::__construct(bool $allowNumber = false, string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Name;publicfunctionrules(){return ['name' => [newName()],    ];}

Phone

The field under validation must be a valid phone number.

✓ +x-xxx-xxx-xxxx
✓ +xxxxxxxxxxx
✓ (xxx) xxx-xxxx
✓ xxxxxxxxxx

public Arifszn\AdvancedValidation\Rules\Phone::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Phone;publicfunctionrules(){return ['foo' => [newPhone()],    ];}

Username

The field under validation must be a valid username.

  • starts with a letter (alpha)
  • only alpha-numeric (a-z, A-Z, 0-9), underscore, minus and dot
  • multiple underscores, minus and are not allowed (-- or __ or ..)
  • underscores, minus and dot are not allowed at the beginning or end
public Arifszn\AdvancedValidation\Rules\Username::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Username;publicfunctionrules(){return ['username' => [newUsername()],    ];}

WithoutSpaces

The field under validation must not contain spaces.

public Arifszn\AdvancedValidation\Rules\WithoutSpaces::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\WithoutSpaces;publicfunctionrules(){return ['foo' => [newWithoutSpaces()],    ];}

Tips

If you want to use the rules as strings and use them globally e.g.'foo' => ['phone'], you can do so by adding them to the boot method of your project'sAppServiceProvider.

<?phpnamespaceApp\Providers;useIlluminate\Support\ServiceProvider;useIlluminate\Support\Facades\Validator;useArifszn\AdvancedValidation\Rules\Phone;class AppServiceProviderextends ServiceProvider{publicfunctionboot()    {        Validator::extend('phone','Arifszn\AdvancedValidation\Rules\Phone@passes',            (newPhone())->message()        );    }}

Testing

composertest

Contributing

Any contributors who want to make this project better can make contributions, which will be greatly appreciated. To contribute, clone this repo locally and commit your code to a new branch. Feel free to create an issue or make a pull request.

Credits

Support

Buy Me A Coffee

License

This package is licensed under theMIT License.

Sponsor this project

    Languages


    [8]ページ先頭

    ©2009-2025 Movatter.jp