Laravel之哈希/常用函数/分页

摘要:
一.哈希1.简介LaravelHash门面为存储用户密码提供了安全的Bcrypt哈希算法。如果你正在使用Laravel应用自带的AuthController控制器,将会自动为注册和认证使用该Bcrypt。}6.csrf_token()csrf_token函数获取当前CSRF令牌的值:$token=csrf_token();7.env()env函数获取环境变量值或返回默认值:$env=env;//Returnadefaultvalueifthevariabledoesn'texist...$env=env;8.dd函数输出给定变量值并终止脚本执行:dd;9.elixir()elixir函数获取带版本号的Elixir文件路径:10.event()event函数分发给定事件到对应监听器:event;11.factory()factory函数为给定类、名称和数量创建模型工厂构建器,可用于测试或数据填充:$user=factory-˃make();12.method_field()method_field函数生成包含HTTP请求方法的HTML隐藏域,例如:{!!

一.哈希

1.简介
Laravel Hash 门面为存储用户密码提供了安全的Bcrypt 哈希算法。如果你正在使用Laravel 应用自带的Au
thController 控制器,将会自动为注册和认证使用该Bcrypt 。
Bcrypt 是散列密码的绝佳选择,因为其”工作因子“是可调整的,这意味着随着硬件功能的提升,生成哈希所
花费的时间也会增加。

2.基本使用
$user = User::findOrFail($id);
// 验证新密码长度...
$user->fill([
  'password' => Hash::make($request->newPassword)
])->save();

此外,还可以使用全局的帮助函数bcrypt:
bcrypt('plain-text')

3.验证哈希密码
check 方法允许你验证给定原生字符串和给定哈希是否相等,然而,如果你在使用Laravel 自带的AuthController (详见用户认证一节),就不需要再直接使用该方法,因为自带的认证控制器自动调用了该方法:

if (Hash::check('plain-text', $hashedPassword)) {
  // 密码匹配...
}

二.路径函数

1.app_path()
app_path 函数返回app 目录的绝对路径

$path = app_path();
你还可以使用app_path 函数为相对于app 目录的给定文件生成绝对路径:
$path = app_path('Http/Controllers/Controller.php');

2.base_path()
base_path 函数返回项目根目录的绝对路径:

$path = base_path();

你还可以使用base_path 函数为相对于应用目录的给定文件生成绝对路径:
$path = base_path('vendor/bin');

3.config_path()
config_path 函数返回应用配置目录的绝对路径

4.database_path()
database_path 函数返回应用数据库目录的绝对路径

5.public_path()
public_path 函数返回public 目录的绝对路径

6.storage_path()
storage_path 函数返回storage 目录的绝对路径
$path = storage_path();

还可以使用storage_path 函数生成相对于storage 目录的给定文件的绝对路径:
$path = storage_path('app/file.txt');

三.URL函数

1.action()
action 函数为给定控制器动作生成URL ,你不需要传递完整的命名空间到该控制器,传递相对于命名空间AppHttpControllers 的类名即可:

$url = action('HomeController@getIndex');
如果该方法接收路由参数,你可以将其作为第二个参数传递进来:
$url = action('UserController@profile', ['id' => 1]);

2.asset()
使用当前请求的scheme(HTTP 或 HTTPS) 为前端资源生成一个 URL:
$url = asset('img/photo.jpg');

3.secure_asset()
使用HTTPS 为前端资源生成一个 URL:
echo secure_asset('foo/bar.zip', $title, $attributes = []);

4.route()
route 函数为给定命名路由生成一个URL :
$url = route('routeName');
如果该路由接收参数,你可以将其作为第二个参数传递进来:
$url = route('routeName', ['id' => 1]);

5.url()
url 函数为给定路径生成绝对路径:
echo url('user/profile');
echo url('user/profile', [1]);

四.其他重要函数

1.auth()
auth 函数返回一个认证器实例,为方便起见你可以用其取代Auth 门面:
$user = auth()->user();

2.back()
back 函数生成重定向响应到用户前一个位置:
return back();

3.bcrypt()
bcrypt 函数使用Bcrypt 对给定值进行哈希,你可以用其替代Hash 门面:
$password = bcrypt('my-secret-password');

4.config()
config 函数获取配置变量的值,配置值可以通过使用”.”号访问,包含文件名以及你想要访问的选项。如果配置选项不存在的话默认值将会被指定并返回:
$value = config('app.timezone');$value = config('app.timezone', $default);
帮助函数config 还可以用于在运行时通过传递键值对数组设置配置变量值:
config(['app.debug' => true]);

5.csrf_field()
csrf_field 函数生成一个包含CSRF 令牌值的HTML 隐藏域,例如,使用Blade 语法:
{!! csrf_field() !!}

6.csrf_token()
csrf_token 函数获取当前CSRF 令牌的值:
$token = csrf_token();

7.env()
env 函数获取环境变量值或返回默认值:
$env = env('APP_ENV');
// Return a default value if the variable doesn't exist...
$env = env('APP_ENV', 'production');

8.dd 函数输出给定变量值并终止脚本执行:
dd($value);

9.elixir()
elixir 函数获取带版本号的Elixir文件路径:

10.event()
event 函数分发给定事件到对应监听器:
event(new UserRegistered($user));

11.factory()
factory 函数为给定类、名称和数量创建模型工厂构建器,可用于测试或数据填充:
$user = factory('AppUser')->make();

12.method_field()
method_field 函数生成包含HTTP 请求方法的HTML 隐藏域,例如:
<form method="POST">
{!! method_field('delete') !!}</form>

13.old()
old 函数获取一次性存放在session 中的值:
$value = old('value');

14.redirect()
redirect 函数返回重定向器实例进行重定向:
return redirect('/home');

15.response()
response 函数创建一个响应实例或者获取响应工厂实例:
return response('Hello World', 200, $headers);return response()->json(['foo' => 'bar'], 200, $headers)

16.value()
value 函数返回给定的值,然而,如果你传递一个闭包到该函数,该闭包将会被执行并返回执行结果:
$value = value(function() { return 'bar'; });

17.view()
view 函数获取一个视图实例:
return view('auth.login');

18.with()
with 函数返回给定的值,该函数在方法链中特别有用,别的地方就没什么用了:
$value = with(new Foo)->work();

五.分页

默认情况下,当前页通过 HTTP 请求查询字符串参数?page 的值判断。当然,该值由 Laravel 自动检测,然后自动插入分页器生成的链接中;simplePaginate仅有上一页和下一页链接,paginate// 上一页,下一页和数字页码

1.使用DB门面
$users = DB::table('users')->simplePaginate(15); //仅有上一页和下一页链接
$users = DB::table('users')->paginate(15); // 上一页,下一页和数字页码

2.模型
$users = AppUser::paginate(15);
$users = User::where('votes', '>', 100)->paginate(15);
$users = User::where('votes', '>', 100)->simplePaginate(15);

3.手动创建分页器
使用LengthAwarePaginator
LengthAwarePaginator 接收参数和Paginator 几乎一样,只是,它要求传入结果集的总数。
换句话说, Paginator 对应simplePaginate 方法,而LengthAwarePaginator 对应paginate 方法。
当手动创建分页器实例的时候,应该手动对传递到分页器的结果集进行“切片”,如果你不确定怎么做,查看 PHP 函数 array_slice。

4.在视图中显示分页结果
<div class="container">
@foreach ($users as $user)
{{ $user->name }}
@endforeach
</div>
{!! $users->render() !!}

render 方法将会将结果集中的其它页面链接渲染出来。每个链接已经包含了?page 查询字符串变量。记住, r
ender 方法生成的 HTML 兼容 Bootstrap CSS 框架。

5.自定义分页参数
a.路由或控制器中
$users = AppUser::paginate(15);
$users->setPath('custom/url');

b.模板中
{!! $users->appends(['sort' => 'votes'])->render() !!}
添加一个命名锚记
{!! $users->fragment('foo')->render() !!}

6.转为json
return AppUser::paginate();

免责声明:文章转载自《Laravel之哈希/常用函数/分页》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇google maps layer图层Linux内核分析总结下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

哈希爆破神器Hashcat的用法

目录 HashCat HshCat的使用 使用Hashcat生成字典 使用Hashcat破解NTLMv2 HashCat HashCat系列软件在硬件上支持使用CPU、NVIDIA GPU、ATI GPU来进行密码破解。在操作系统上支持Windows、Linux平台,并且需要安装官方指定版本的显卡驱动程序,如果驱动程序版本不对,可能导致程序无法运行。 H...

SQL性能调优

部分转自:http://www.cnblogs.com/luckybird/archive/2012/06/11/2544753.html 及http://www.cnblogs.com/kissdodog/p/3160560.html 着色部分为实际解决问题的过程 最常见的索引问题查找: 1、检查实际执行计划,使用图形化或者在执行语句前增加  set s...

分布式算法(一致性Hash算法)

转载:https://www.cnblogs.com/moonandstar08/p/5405991.html 一、分布式算法     在做服务器负载均衡时候可供选择的负载均衡的算法有很多,包括: 轮循算法(Round Robin)、哈希算法(HASH)、最少连接算法(Least Connection)、响应速度算法(Response Time)、加权法(...

Redis缓存篇(四)缓存异常

这一节,我们来学习一下缓存异常。缓存异常有四种类型,分别是缓存和数据库的数据不一致、缓存雪崩、缓存击穿和缓存穿透。 下面通过了解这四种缓存异常的原理和应对方法。 缓存和数据库的数据不一致 缓存和数据库的数据一致性包含两种情况: 缓存中有数据,缓存的数据值需要和数据库中的值相同; 缓存中没有数据,数据库中的值必须是最新值。 数据不一致是如何发生的? 在第...

中间件集群的3大策略

中间件集群的3大策略 1)动态负载均衡策略,一般会搜集多个进程的服务状态,然后挑选一个负载最轻的进程来分发服务,这种策略对于比较同质化的进程是比较合适的。 2)读写分离策略则是关注对持久化数据的性能,比如对数据库的操作,我们会提供一批进程专门用于提供读数据的服务,而另外一个(或多个)进程用于写数据的服务,这些写数据的进程都会每次写多份拷贝到“读服务进程”的...

浅谈SQL Server中的三种物理连接操作

本文转自:https://msdn.microsoft.com/zh-cn/library/dn144699.aspx 感觉写的很好,特此收录,以备自己和需要的朋友查看 简介 在SQL Server中,我们所常见的表与表之间的Inner Join,Outer Join都会被执行引擎根据所选的列,数据上是否有索引,所选数据的选择性转化为Loop Join,M...