首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Laravel代码简洁之道和性能优化

经过一番调研之后发现了一个堪称神器的扩展:laravel-upsert 这个 Laravel 扩展为查询构建器和 Eloquent 添加了对 INSERT & UPDATE (UPSERT) 和 INSERT...扩展的特性 安装 composer require staudenmeir/laravel-upsert:"^1.0" 用法 插入和更新 (UPSERT) 考虑这个users具有唯一username...username' )-> unique (); $ table -> boolean ( ' active' ); $ table ->时间戳(); }); 使用upsert()插入一个新的用户或更新现有的一个...在此示例中,将重新激活非活动用户并updated_at更新时间戳: DB :: table ( 'users' )-> upsert ( [ 'username' => 'foo' , 'active...); 插入忽略 您还可以在忽略重复键错误的同时插入记录: Schema :: create ( 'users' , function ( Blueprint $ table ) { $

5.7K20
您找到你想要的搜索结果了吗?
是的
没有找到

Laravel 5.0 之 表单验证类 (Form Requests)

. ---- 让人头痛的表单验证 只要你曾经在使用 Laravel 框架的过程中试图找到有关用户输入验证的最佳实践, 你就应该了解这是一个争论最多并且几乎没有达成共识的话题....Laravel 5.0 新引入的表单请求 (Form Request) 特性提供了规范性 (差不多就是 "最佳实践" 的意思) 和便捷性 (这是比之前任何一种选择都更强大也更便捷的方式) 于一体的,...Laravel 会在解析 POST 路由之前自动把用户输入的信息传递给相应的表单请求, 因此我们的所有验证逻辑都可以移到独立于控制器和模型之外的 FormRequest 对象中....; } $thingBeingEdited = Thing::find(Input::get('thingId')); // 如果是编辑操作, 或者当前用户不是对象创建者...= Auth::id()) { return false; } return true; } } 自定义校验 除了上面的方式, 如果需要对验证逻辑进行更深入的控制

3.8K50

具有嵌套关系的可重用API资源——Laravel5.5

在 database/factories 目录下的 PostFactory.php 文件中,你会定义创建posts模型时所用的数据格式和规则。...· 用户拥有posts的关系app/User.phppublic function posts(){return $this->hasMany(Post::class);}这是在用户模型(User)中定义与...也就是在 app 目录下的 User.php 文件中,你会定义用户和posts之间的关联关系,比如一对多关系(一个用户有多个posts)或其他关系。· 避免批量赋值app/Post.php<?...能够在资源类中进行关系的转换,但是有条件:如果数据是可用的(已经预加载),就可以进行转换;如果数据尚未加载,可以选择忽略这个转换。...如果关联数据不可用,资源类会忽略它;反之,如果可用,资源类会将其包含在返回的数据中。 7. Posts Resource<?

10610

为你的 Laravel 验证器加上多验证场景的实现

前言 在我们使用 laravel 框架的验证器,有的时候需要对表单等进行数据验证,当然 laravel 也为我们提供了 Illuminate\Http\Request 对象提供的 validate...如果验证失败,就会生成一个让用户返回到先前的位置的重定向响应。这些错误也会被闪存到 Session 中,以便这些错误都可以在页面中显示出来。...如果传入的请求是 AJAX,会向用户返回具有 422 状态代码和验证错误信息的 JSON 数据的 HTTP 响应。...namespace App\Validate; use Illuminate\Support\Facades\Validator; /** * 扩展验证器 */ class BaseValidate { /** * 当前验证规则...Laravel 验证器加上多验证场景的实现的文章就介绍到这了,更多相关Laravel 验证器内容请搜索ZaLou.Cn以前的文章或继续浏览下面的相关文章希望大家以后多多支持ZaLou.Cn!

2.8K10

laravel框架创建授权策略实例分析

分享给大家供大家参考,具体如下: 用户只能编辑自己的资料 在完成对未登录用户的限制之后,接下来我们要限制的是已登录用户的操作,当 id 为 1 的用户去尝试更新 id 为 2 的用户信息时,我们应该返回一个...update方法接收两个参数,第一个参数默认为当前登录用户实例,第二个参数则为要进行授权的用户实例。当两个 id 相同时,则代表两个用户是相同用户用户通过授权,可以接着进行下一个操作。...未登录用户,框架会自动为其所有权限返回false; 调用时,默认情况下,我们不需要传递当前登录用户至该方法内,因为框架会自动加载当前登录用户(接着看下去,后面有例子)。 2....自动授权默认会假设 Model 模型文件直接存放在app目录下,鉴于我们已将模型存放目录修改为app/Models,接下来还需自定义自动授权注册的规则,修改boot()方法: app/Providers...正如上面定义update授权方法时候提起的,调用时,默认情况下,我们不需要传递第一个参数,也就是当前登录用户至该方法内,因为框架会自动加载当前登录用户

2.2K61

为什么 Laravel 这么优秀?

Artisan 是一个 SHELL 脚本,是通过命令行操作 Laravel唯一入口。...会自动同步所有的数据库迁移文件并按照 Laravel Factory 定义的规则生成一个关系完备的测试数据。...Laravel 用一个数组保存你注册过的所有路由;在进行路由匹配时,Laravel 会用你当前请求的 pathinfo 来匹配已经注册的所有路由;当你的路由数量超级多时,最坏情况下你需要 O(n) 次才能找出匹配的路由...不过这点复杂度比起注册路由&启动服务的开销几乎可以忽略不计,并且一个应用也不会有数量过多的路由,加之 Laravel 还单独提供了 artisnan route:cache 命令来缓存路由的注册和匹配。...而 Laravel 提供的 FormRequest 就可以非常方便的做到这一点;你可以在 FormRequest 中定义前端传入的每一个字段的验证规则

14310

Laravel学习记录--数据库迁移

laravel 数据库迁移 数据迁移文件存放在database/migrations 特点:可进行版本回退,便于团队开发 通过数据迁移文件创建表 1 创建数据库 配置.env文件选择数据库 DB_CONNECTION...//$table->increments() } 数据库结构生成器常用命令 $table->engine = 'InnoDB' 指定表引擎 ->charset = 'utf8' 指定数据表默认字符...->collation = 'utf8_general_ci' 指定数据表默认排序规则 ->temporary() 创建临时表 重命名数据表 Schema::table('from','to') 删除数据表...renameColumn('from','to') 删除字段 dropCloumn('字段名') dropCloumn(['字段名','字段2']) 外键约束 $table->foreign('当前表从表字段...可用索引命令 $table->primary('id') //添加主键 $table->primary(['id','cid'])// 复合主键 $table->unique('email') //创建唯一索引

1K20

Laravel5.7 数据库操作迁移的实现方法

Laravel 的 Schema 门面提供了与数据库系统无关的创建和操纵表的支持,在 Laravel 所支持的所有数据库系统中提供一致的、优雅的、流式的 API。...创建一个虚拟生成列(MySQL) 修改数据列 先决条件 在修改列之前,确保已经将 doctrine/dbal 依赖添加到 composer.json 文件,Doctrine DBAL 库用于判断列的当前状态并创建对列进行指定调整所需的...索引长度 & MySQL / MariaDB Laravel 默认使用 utf8mb4 字符,支持在数据库中存储 emoji 表情。...重命名索引 要重命名一个索引,可以使用 renameIndex 方法,这个方法接收当前索引名作为第一个参数以及修改后的索引名作为第二个参数: $table- renameIndex('from', '...外键约束和索引使用同样的命名规则 —— 连接表名、外键名然后加上“_foreign”后缀: $table- dropForeign('posts_user_id_foreign'); 或者,你还可以传递在删除时会自动使用基于惯例的约束名数值数组

3.7K31

3分钟短文 | Laravel 表单验证数组的数据

三个字段的验证需求如下: name字段,必填,每个元素唯一,且至少有3个元素 amount字段,必填,元素要求都是整数,且最少有1个元素 description字段,必填,元素可有可无,且元素都是字符串...明确了需求,我们发现上述的验证,laravel内置的规则基本可以解决。只是对于字段是数组,且数组长度满足某些条件的要求,有些苛刻。具体如何实现呢?...laravel表单验证规则中,使用星号,可以匹配数组的元素。...*" => "required|string|distinct|min:3", ]); 第一步验证name必填,必须为数组,且至少有3个元素;第二步,使用星号匹配所有的数组元素, 必填,字符串类型,唯一性...那么在laravel的验证器中,应该如何写呢? 这与指定了字段名的数组不同,这个数组的键是自动编排的数字,所以,我们需要通配键名。

3.4K10

Laravel 控制器:从 MVC 模式聊起

将所有业务逻辑一股脑放到控制器听起来挺不错,但是控制器更适合承担的角色其实是负责对 HTTP 请求进行路由,因为还有很多其他访问应用的方式,比如 Artisan 命令、队列、调度任务等等,控制器并非唯一入口...:我们将用户提交数据收集起来,保存到 Task 模型类,然后将用户重定向到显示所有任务的页面。...4、依赖注入 正如前面介绍的 Input 门面一样,Laravel 中的门面为 Laravel 代码库中的大部分类提供了简单的接口调用,通过门面你可以轻松从当前获取各种请求数据,比如用户输入、Session...、Cookie 等,但不是所有的类都有对应的门面(当前的映射关系可以查看门面列表),对于这些类提供的方法我们可以通过更底层的依赖注入来调用,本质上来看,门面仅仅是一种设计模式,是对底层复杂 API 的上层静态代理...5、资源控制器 有时候在编写控制器时命名方法名称可能是最困难的,好在 Laravel 为常见的 REST/CRUD 控制器(在 Laravel 中称之为「资源控制器」)提供了一套约定规则,并为此提供了相应的

11.2K51

基于 Redis 实现 Laravel 广播功能(下):在私有频道和存在频道发布和接收消息

false : true; }); 先模拟一个微信群与用户表的映射关系,然后根据传入的用户 ID 和群 ID 判断群 ID 是否有效,以及用户是否在这个群里作为授权是否通过的依据。...,或者给当前在线用户发送提醒信息,这样类比下,是不是更好理解一些?...定义存在频道广播事件类 我们以统计当前微信群在线用户数为例进行演示,每当有新用户进入时,更新在线用户数并广播这个事件消息,为此我们需要创建一个标识用户进入微信群的广播事件类: php artisan make...event 调整为了 broadcast,这是一个专门用于分发广播事件的辅助函数,可以在分发事件返回实例上调用 toOthers 方法告知系统将这个事件消息广播给排除当前用户的所有其他在线用户。...另外,这个功能还依赖于客户端请求头包含 X-Socket-IDLaravel Echo 初始化时会为每个连接分配一个唯一的 Socket ID,用于标识不同的 Websocket 客户端),如果你在

3K30

详解laravel中blade模板带条件分页

Laravel 的分页器与查询构建器和 Eloquent ORM 集成在一起,并开箱提供方便的、易于使用的、基于数据库结果的分页。分页器生成的 HTML 兼容 Bootstrap CSS 框架。...该方法基于当前用户查看页自动设置合适的偏移(offset)和限制(limit),直白点说就是页码和每页显示数量。默认情况下,当前页通过 HTTP 请求查询字符串参数 page 的值判断。...在本例中,传递给 paginate 的唯一参数就是你每页想要显示的数目,这里我们指定每页显示 15 个: <?...DB; use App\Http\Controllers\Controller; class UserController extends Controller { /** * 显示应用中的所有用户...这些对象提供相关方法描述这些结果,除了这些辅助函数外,分页器实例本身就是迭代器,可以像数组一样对其进行循环调用。

7.2K30

推荐 Laravel API 项目必须使用的 8 个扩展包

Zizaco/entrust ACL(访问控制列表)是一个集合操作,它告诉系统每个用户的访问权限。ACL包含用于管理特定用户的访问的角色和权限。Laravel与缺省的ACL命名为Gate。...Fractal 就为你提供了一个很棒的解决方案,它为那些复杂的数据输出提供了演示和转换的规则。 ...Webpatser/laravel-uuid UUID (通用唯一识别码) 是一组 128 bits 的字符,包含字母和数字,每一组是唯一的, 空间和时间保证唯一性,你可以在 这里 了解更多。...当用户访问数据时 UUID 可以保护系统。 Webpatser/laravel-uuid 是一个 Laravel 第三方包,根据 RFC 4122 标准生成 UUID, 你可以在 这里 找到它。...Davibennun/laravel-push-notification Davibennun/laravel-push-notification 是直接发送到用户移动显示屏幕的即时文本消息。

2.7K10

Laravel API教程:如何构建和测试RESTful API

401:未经授权 用户需要进行身份验证。 403:禁止 用户已通过身份验证,但没有执行操作的权限。 404: 未找到。当没有找到资源时,这将由Laravel自动返回。 500: 内部服务器错误。...注销 使用我们当前的策略,如果令牌错误或丢失,用户应该收到未经身份验证的响应(我们将在下一节中实现)。因此,对于一个简单的注销端点,我们将发送令牌,它将在数据库上删除。...Request $request) { return $request->user(); }); 我们可以使用该$request->user()方法或通过Auth Facade 访问当前用户...这意味着当我们打到认证中间件时,它将当前用户保存在 TokenGuard 实例中,以避免再次触发数据库。...如果您正在设计一个公共API,请参阅“Great Web API设计黄金规则”。

20.2K20

Laravel 控制器中进行表单请求字段验证

在 Web 应用中,用户提交的数据往往是不可预测的,因此一个非常常见的需求是对用户提交的表单请求进行验证,以确保用户输入的是我们所期望的数据格式。...很多 Web 框架都对此功能专门提供了工具Laravel 也不例外,而且这个工具异常丰富,基本上涵盖了目前主流的所有验证规则,即使是一些非常个性化的验证,也可以基于 Laravel 验证类的扩展功能来自定义验证规则...接下来,我们就一起来看看如何在 Laravel 中对表单请求进行验证。...作为一个灵活的框架,Laravel 提供了多种方式对表单请求进行验证,你可以在控制器中通过 $this->validate() 方法验证用户请求,也可以通过单独的表单验证类定义验证规则,再将其注入到相应的控制器方法...通过 Validator::make 方法进行验证 如果你使用过 Laravel 自带脚手架代码实现登录认证的话,你可能会留意到 RegisterController 中对用户注册请求进行验证的时候,使用的是这样的验证代码

5.7K10
领券