9月20日知识点记录


一.Laravel表单验证

创建控制器并在添加方法shore()中编写验证

 public function store(Request $request)
{
    // 验证以及保存提交的数据...
}

编写验证逻辑

validate 方法会接收 HTTP 传入的请求以及验证的规则。如果验证通过,你的代码就可以正常的运行。若验证失败,则会抛出异常错误消息并自动将其返回给用户。在一般的 HTTP 请求下,都会生成一个重定向响应,对于 AJAX 请求则会发送 JSON 响应

public function store(Request $request)
{
    $this->validate($request, [
        'title' => 'required|unique:posts|max:255',//标题不为空,post提交,最长255
        'body' => 'required',//主要内容不为空
    ]);

    //成功上传新数据,将其保存到数据库...    
}

嵌套属性

   $this->validate($request, [
       'title' => 'required|unique:posts|max:255',
       'author.name' => 'required',//在验证规则中使用「点」语法来指定他们
       'author.description' => 'required',
   ]);

显示验证错误

Laravel 会自动把用户重定向到先前的位置。另外,所有的验证错误会被自动 闪存至 session
$errors 变量在每次请求的所有视图中都可以被使用,你可以很方便的假设 $errors 变量已被定义且进行安全地使用

if (count($errors) > 0)
    <div class="alert alert-danger">
        <ul>
            @foreach ($errors->all() as $error)
                <li>{{ $error }}</li>//在视图中显示错误的消息
            @endforeach
        </ul>
    </div>
@endif

自定义闪存的错误消息格式

在控制器中重写 formatValidationErrors。别忘了将 Illuminate\Contracts\Validation\Validator 类引入到文件上方

<?php

namespace App\Http\Controllers;

use Illuminate\Foundation\Bus\DispatchesJobs;
use Illuminate\Contracts\Validation\Validator;
use Illuminate\Routing\Controller as BaseController;
use Illuminate\Foundation\Validation\ValidatesRequests;

abstract class Controller extends BaseController
{
    use DispatchesJobs, ValidatesRequests;

    /**
     * {@inheritdoc}
     */
    protected function formatValidationErrors(Validator $validator)
    {
        return $validator->errors()->all();
    }
}

表单请求验证

表单请求是一个自定义的请求类,里面包含着验证逻辑。要创建一个表单请求类,可使用 Artisan 命令行命令 make:request
php artisan make:request StoreBlogPostRequest
新生成的类文件会被放在 app/Http/Requests 目录下
public function rules() { return [ 'title' => 'required|unique:posts|max:255', 'body' => 'required', ]; }
在控制器方法中利用类型提示传入请求。传入的请求会在控制器方法被调用前进行验证,意思就是说你不会因为验证逻辑而把控制器弄得一团糟

/**
 * 保存传入的博客文章。
 *
 * @param  StoreBlogPostRequest  $request
 * @return Response
 */
public function store(StoreBlogPostRequest $request)
{
    // 传入的请求是有效的...
}

如果验证失败,就会生成一个重定向响应把用户返回到先前的位置。这些错误会被闪存到 session,所以这些错误都可以被显示

授权表单请求

表单的请求类内包含了 authorize 方法。在这个方法中,你可以确认用户是否真的通过了授权,以便更新指定数据

/**
 * 判断用户是否有权限做出此请求。
 *
 * @return bool
 */
public function authorize()
{
    $commentId = $this->route('comment');

    return Comment::where('id', $commentId)
                  ->where('user_id', Auth::id())->exists();
}

自定义闪存的错误消息格式
自定义验证失败时闪存到 session 的验证错误格式,可在你的基底请求 (App\Http\Requests\Request) 中重写 formatErrors,文件上方引入 Illuminate\Contracts\Validation\Validator 类

/**
 * {@inheritdoc}
 */
protected function formatErrors(Validator $validator)
{
    return $validator->errors()->all();
}

自定义错误消息
(你可以通过重写表单请求的 messages 方法来自定义错误消息。此方法必须返回一个数组,其中含有成对的属性或规则以及对应的错误消息)

/**
 * 获取已定义验证规则的错误消息。
 *
 * @return array
 */
public function messages()
{
    return [
        'title.required' => '标题是必填的',
        'body.required'  => '消息是必填的',
    ];
}

处理错误消息
调用一个 Validator 实例的 errors 方法,会得到一个 Illuminate\Support\MessageBag 的实例,里面有许多可让你操作错误消息的便利方法
$messages = $validator->errors(); echo $messages->first('email')//查看特定字段的第一个错误消息
foreach ($messages->get('email') as $message) { //查看特定字段的所有错误消息,取所有消息中的一个数组,可以使用 get 方法 }
foreach ($messages->all() as $message) { //查看所有字段的所有错误消息 }
if ($messages->has('email')) { //判断特定字段是否含有错误消息 }
echo $messages->first('email', '<p>:message</p>');//获取格式化后的错误消息
foreach ($messages->all('<li>:message</li>') as $message) { //获取所有格式化后的错误消息 }

自定义错误消息

通过传递三个参数到 Validator::make 方法来自定义验证消息

$messages = [
    'required' => ':attribute 的字段是必要的。',//:attribute 占位符会被通过验证的字段实际名称所取代
];

$validator = Validator::make($input, $rules, $messages);

指定自定义消息到特定的属性
$messages = [ 'email.required' => '我们需要知道你的 e-mail 地址!',//属性名称后加上「.」符号和指定验证的规则 ];

可用的验证规则<----#---->点我

二.重要知识点

1.随机数(PHP7)

random_bytes 函数返回 string 类型,并接受一个 int 类型为参数,该参数规定了所返回字符串的字节长度
$bytes = random_bytes('10'); var_dump(bin2hex($bytes));//bin2hex() 函数把 ASCII 字符的字符串转换为十六进制值。字符串可通过使用 pack() 函数再转换回去 //possible ouput: string(20) "7dfab0af960d359388e6"
random_int 函数返回给定范围内的整型数
var_dump(random_int(1, 100)); //possible output: 27

2.毫秒级时间戳

<?php
function getMillisecond() {
list($t1, $t2) = explode(' ', microtime());//microtime() 函数返回当前 Unix 时间戳的微秒数,explode() 函数把字符串打散为数组,list() 函数用于在一次操作中给一组变量赋值
return (float)sprintf('%.0f',(floatval($t1)+floatval($t2))*1000);//sprintf() 函数把格式化的字符串写入变量中,floatval ()获取变量的浮点值,(float)获取变量的浮点值
}

echo getMillisecond();

3.UUID(唯一识别码)

http://www.jianshu.com/p/792c2bbe107e

4.动态获取文件后缀

$ext = $file->getClientOriginalExtension();

5.文件类型表单验证

self::validate($request, [
            'img' => 'required|mimes:jpeg,bmp,png,gif,jpg',
            'photoName' => 'required|string|min:6|max:10'
        ]);

6.更换中文错误提示信息

复制resources/lang/en/validation.php文件到自己新建的zh-cn目录
然后替换其中的内容https://laravel-china.org/articles/5840/validation-validation-in-laravel-returns-chinese-prompt

'attributes' => [
    'name'          => '名字',
    'age'           => '年龄',
    'img'           => '图片',
    'photoName'     => '图片名称',
    'user_name' => '姓名',
    'pwd' => '密码',
    'sex' => '性别',//添加自定义字段
    ],

7.Laravel时间区修改

在config/app.php修改该字段
'timezone' => 'PRC',//把原来的TRC改为PRC

8.自定义配置使用

在config下新建一个存放配置的PHP文件

<?php
return [
    'upload_dir' => public_path() . '/uploads',//上传图片的路径
   ];

在页面中调用:
config('sys.upload_dir')

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容