定制 joshralph/password-policy 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

joshralph/password-policy

最新稳定版本:0.3.0

Composer 安装命令:

composer require joshralph/password-policy

包简介

A library to intuitively create password policies and validate a subject against them.

README 文档

README

Build Status

A fluent password policy builder library. The package can be used stand-alone or easily added to Laravel.

Table of Contents

Install

$ composer require joshralph/password-policy

Usage

Policy Builder

$builder = new \PasswordPolicy\PolicyBuilder(new \PasswordPolicy\Policy);
$builder->minLength(6)
    ->upperCase();

Any of the following methods may be chained on the builder class to build your password policy.

minLength(length)

length

Type: int

Minimum number of characters the password must contain.

maxLength(length)

length

Type: int

Maximum number of characters the password must contain.

upperCase([min])

min

Type: int

Minimum number of upper case characters the password must contain.

lowerCase([min])

min

Type: int

Minimum number of lower case characters the password must contain.

digits([min])

min

Type: int

Minimum number of numeric characters the password must contain.

specialCharacters([min])

min

Type: int

Minimum number of special characters the password must contain.

doesNotContain(phrases [,phrases])

phrases

Type: string|array

Phrases that the password should not contain

Example

->doesNotContain('password', $firstName, $lastName)

minPassingRules(passesRequired, ruleSet)

passesRequired

Type: int

The minimum number of rules in the ruleSet that need to pass, in order for this rule to pass

ruleSet

Type: \Closure

A closure which is given a new PolicyBuilder instance.

Example

// One of these rules must pass
->minPassingRules(1, function (PolicyBuilder $builder) {
    $builder->doesNotContain('password')
        ->minLength(10);
})

Laravel

If you are a Laravel user, this package can seamlessly integrate with your validators.

Install Package

Begin by adding the below service provider.

// config/app.php

'providers' => [
    // ...
    \PasswordPolicy\Providers\Laravel\PasswordPolicyServiceProvider::class,
],

Define Policies

Within an app service provider (e.g. AppServiceProvider.php) you can start defining password policies.

// App/Providers/AppServiceProvider.php

// use PasswordPolicy\PolicyBuilder;
 

/**
 * Bootstrap any application services.
 *
 * @return void
 */
public function boot()
{
    \PasswordPolicy::define('default', function (PolicyBuilder $builder) {
        $builder->minLength(8)
            ->upperCase(3);
            // ...
    });
}

You can define as many policies as you require, however it's recommended to stick with 'default' when possible.

Setup Validation

Once you're policies have been defined, you're ready to start using the policies. A new 'password' validation rule is now available to use.

// Request class

/**
 * Declare validation rules
 * 
 * @return array
 */
public function rules()
{
    return [
        // ...
        'password' => 'required|password'
    ];
}

The validator will use the 'default' policy by default. To use an alternative policy, add an additional parameter:

'password' => 'required|password:admin'

统计信息

  • 总下载量: 370.19k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 15
  • 点击次数: 2
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 15
  • Watchers: 2
  • Forks: 6
  • 开发语言: PHP

其他信息

  • 授权协议: Unknown
  • 更新时间: 2016-07-28