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

【Laravel系列4.1】连接数据库与原生查询

连接数据库配置 首先我们可以看下配置文件,在 Laravel 程序的 config 目录下,有一个 database.php 文件,其中有关于数据库的连接配置信息。...从 options 这个参数里面,我们可以看出,Laravel 默认使用的是 PDO 连接的数据库,我也没有研究在 Laravel 中如何使用 mysqli 进行连接,因为 PDO 确实已经是事实的连库标准了...比如现在在我的本地测试环境中,连接数据库就是使用 .env 中如下的配置: // ……………… // ……………… DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT...通过上面两步,我们的配置就完成了,是不是非常简单,接下来就是在代码中如何使用。...当然,这也是为了框架的通用性,因为 PDO 也是通用的,在工厂中,我们可以看到 Postgres、SQLite、SQLServer 的连接器,如果使用 MySQLi 的话,可就没办法支持这些数据库了哦。

3.2K50

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

在本文中,我们将探讨如何构建和测试使用Laravel进行身份验证的强大API。我们将使用Laravel 5.4,所有的代码都可以在GitHub上参考。...当您localhost:8000在浏览器上打开时,应该会看到这个示例页面。...注销 使用我们当前的策略,如果令牌错误或丢失,用户应该收到未经身份验证的响应(我们将在下一节中实现)。因此,对于一个简单的注销端点,我们将发送令牌,它将在数据库上删除。...对于列表端点,例如,我们可以运行几个工厂,并声明响应包含这些资源。 要开始使用,我们需要调整一些设置来使用内存中的SQLite数据库。...绝对有改进的空间 - 您可以使用Passport软件包实现OAuth2 ,集成分页和转换层(我推荐使用Fractal),但是我想通过在Laravel中创建和测试API的基础知识外部包装。

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

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

    本文内容主要围绕在 Laravel 5.5 中使用 API 开发的重要步骤,着重介绍如何利用 Laravel 的 API 资源(Resource)和控制器(Controller)进行多因素身份验证(MFA...注:本文受到Laravel创始人Taylor Otwell介绍使用 Laravel5.5 开发API时如何替换 Fractal 的启发。 1....这个文件包含了使用 Laravel 的迁移(Migration)功能创建数据库表的代码。· posts工厂database/factories/PostFactory.php的操作,可以使用 Laravel 的 Seeder 来填充数据库表,确保数据库中有一些初始数据可用于开发和测试。 3....这样做有利于避免 N+1 查询问题(在获取关联数据时出现的效率问题),同时可以使用单个资源类处理不同的情况。如果关联数据不可用,资源类会忽略它;反之,如果可用,资源类会将其包含在返回的数据中。

    15810

    Laravel 5.0 之云存储驱动

    本文译自 Matt Stauffer 的系列文章. ---- 在 Laravel 5.0 版本中, FileSystem 类不再只是与本地文件系统进行交互, 而是可以用于 S3 和 Rackspace...$filename, $thing); } 在 Laravel 5.0 中, 可以随时通过修改生产环境下的应用配置文件, 无缝切换到外部的云存储服务(目前仅支持 S3 和 Rackspace, 本文以...常规默认值 Filesystem 的配置中有两组默认值: 文件系统默认值(当你用 Illuminate\Contracts\Filesystem\Filesystem 来做类型约束时注入)会同时绑定到一个名为...这样你可以给任何特定的环境都指定默认的本地配置及默认的云存储配置. 假如使用 facade 的话, 默认会返回 default 默认值, 而不是 cloud 默认值....Jeffrey Way 演示了如何在代码中而不是配置文件中指定要注入 Filesystem 工厂使用的驱动, 但我并没有详细了解这个技巧.

    1.2K50

    Laravel给数据库造假竟成工具链

    引言 上一章我们了解了使用laravel迁移功能创建数据库表,把DBA的工作挪到开发端,这样把岗位都省出来了。 但是只有光秃秃的数据库表,有个壳子没有数据确实没啥用。...本文为大家讲讲laravel怎么给数据库造假数据,堂而皇之地假装生产。 本文使用的构建方式都是写脏数据,乱数据,无实质意义的数据,只对应用程序和数据库有用,别的嘛用没有!...类不类,方法不方法,函数不函数的!没错,就是一个代码片段,laravel约定的东西, 你这么写,在执行数据填充和测试的时候,它就起作用!就这么神奇。 那如何控制填充条数呢?...写在最后 本文介绍了使用laravel的Seeder进行数据填充,为了高效填充,我们介绍了工厂模式,这个高级玩意儿,确实用法有点偏,本不在五行八卦之列。希望大家用的开心。...Happy coding :-) 我是@程序员小助手,专注编程知识,圈子动态的IT领域原创作者

    1.2K00

    Laravel给数据库造假竟成工具链

    引言 上一章我们了解了使用laravel迁移功能创建数据库表,把DBA的工作挪到开发端,这样把岗位都省出来了。 但是只有光秃秃的数据库表,有个壳子没有数据确实没啥用。...本文为大家讲讲laravel怎么给数据库造假数据,堂而皇之地假装生产。 本文使用的构建方式都是写脏数据,乱数据,无实质意义的数据,只对应用程序和数据库有用,别的嘛用没有!...类不类,方法不方法,函数不函数的!没错,就是一个代码片段,laravel约定的东西, 你这么写,在执行数据填充和测试的时候,它就起作用!就这么神奇。 那如何控制填充条数呢?...写在最后 本文介绍了使用laravel的Seeder进行数据填充,为了高效填充,我们介绍了工厂模式,这个高级玩意儿,确实用法有点偏,本不在五行八卦之列。希望大家用的开心。...Happy coding :-) 我是@程序员小助手,专注编程知识,圈子动态的IT领域原创作者

    1.1K20

    Laravel 单元测试:使用phpunit进行测试

    本文将深入探讨 Laravel 单元测试的各个方面,包括它的重要性、如何设置测试环境、编写和运行测试,以及一些实用的最佳实践。为什么选择 Laravel 进行单元测试?...Laravel 内置了 PHPUnit,这是一个广泛使用的 PHP 单元测试框架。它允许开发者通过编写测试用例来验证代码中的每个组件都能正常运行。...我们期望当输入 2 和 3 时,结果应该是 5。测试 Laravel 模型模型是 Laravel 应用程序中的核心组件,它们代表了数据库中的表。测试模型确保了数据层的正确性。...我们使用了 Laravel 的模型工厂(Model Factories)来创建一个角色为 admin 的用户,并测试了 isAdmin 方法的行为。...注意事项为了确保你的 Laravel 单元测试既有效又高效,以下是一些注意事项:保持测试的独立性:每个测试应该是独立的,不依赖于其他测试的结果。

    8211

    为什么 Laravel 这么优秀?

    这篇文章中我使用的 Demo 是最新版的 Laravel 10.x 以及 PHP 8.2。...因为我们已经完成了数据表中字段的定义、表与表的关系、以及最重要的一步:如何将数据及数据之间的关系写入数据库中,下面简单的来介绍下在 Laravel 是如何完成的。...不过我不建议大家在生产环境这样做;生产环境的数据库迁移应该始终保持向前滚动,而不应该含有向后 Rollback 的操作。...我们还使用了 Laravel Resource 来格式化最终的输出格式,这样做的原因是很多情况下我们不希望直接将数据库的字段暴露出去,你甚至还能在 Laravel Resource 中按不同的角色显示不同的字段...;如 CacheServiceProvider 会向容器中注册 Cache 对象,后续在使用 Cache::get 时就使用的是这里注册的 Cache 对象,在注册阶段不应该向容器中获取值,因为此时服务可能还没有

    26710

    laravel与thinkphp之间的区别与优缺点

    3、Laravel框架提供了大量的闭包 作为菜鸟的我目前只使用了use方法,即如何在函数内部使用外层变量。...7、加密方式 在TP框架中,我们对用户名密码进行加密时使用md5();的方式进行加密。...我想这可能是它牢牢占据NO.1的一大亮点,在ThinkPHP中则需要我们借助SQL语句或者建表工具去逐步完善数据。 8.1、首先我们需要建立模型:我用的是gitbash。...无须担心,从github中pull下项目后在数据表里直接修改,只需要用: php artisan migrate:refresh 9、ORM 在介绍建表时已经使用了创建模型的命令: php artisan...');//设定一个默认值,当指定键名不存在便返回默认值 $request->session()->all();//返回所有数据 session(‘k'=>$v);//写入session保存数据 以及闪存数据

    5.7K20

    通过填充器快速填充 Laravel 测试数据

    在 Laravel 框架中,如果想要快速填充测试数据到数据库,可以借助框架提供的填充器功能,通过填充器,我们可以非常方便地为不同数据表快速填充测试数据。...这就是 Laravel 自带的一个填充器示例文件,该填充器类提供了一个 run 方法,当我们运行填充命令时,就会调用该方法执行数据库填充。...填充器的运行 Laravel 提供了两种方式来运行填充器:一种是独立的填充命令,另一种是在运行迁移命令时通过指定标识选项在创建数据表时填充。...现在,我们先抛开测试不谈,赶紧来看下如何在 Laravel 中定义模型工厂。...,Faker 类库提供了丰富的字段规则帮助我们生成伪造字段值,这些规则可以在官方文档中查看,这里,我们使用 调用模型工厂 在调用这些模型工厂的时候,需要借助 Laravel 提供的全局辅助函数 factory

    10.1K20

    Laravel和Thinkphp有什么区别,哪个框架好用

    3、Laravel框架提供了大量的闭包 作为菜鸟的我目前只使用了use方法,即如何在函数内部使用外层变量。...7、加密方式 在TP框架中,我们对用户名密码进行加密时使用md5();的方式进行加密。...我想这可能是它牢牢占据NO.1的一大亮点,在ThinkPHP中则需要我们借助SQL语句或者建表工具去逐步完善数据。 8.1、首先我们需要建立模型:我用的是gitbash。...无须担心,从github中pull下项目后在数据表里直接修改,只需要用: php artisan migrate:refresh 9、ORM 在介绍建表时已经使用了创建模型的命令: php artisan...’);//设定一个默认值,当指定键名不存在便返回默认值 $request->session()->all();//返回所有数据 session(‘k’=>$v);//写入session保存数据 以及闪存数据

    6.1K20

    通过 Laravel 创建一个 Vue 单页面应用(三)

    我们将通过演示在 vue-router 进入一个路由之前,如何异步加载数据来继续使用 Laravel 构建我们的 Vue SPA。...这篇教程,我们将把模拟的 /users 返回替换为真正的由数据库支撑的。我习惯使用 MySQL,但是你可以使用任何你想用的数据库驱动!...配置数据库 是时候给我们的 Vue SPA Laravel 应用连接一个真实的数据库了。你可以通过使用类似 TablePlus 的GUI工具来使用 SQLite 或者 MySQL。...就像这样;你应该有一个包含50个用户的数据库,我们可以通过api查询和返回。...UsersIndex.vue 组件后显示出的 SPA 结果: 下一步是什么 我们现在有一个有效的 API,可以从数据库中获取真实数据,还有一个简单的分页组件,该组件在后端使用 Laravel 的 API

    5.2K10

    浅析 Laravel 底层原理:契约(Contracts)「建议收藏」

    大家好,又见面了,我是全栈君。 简介 Laravel 中的契约是指框架提供的一系列定义核心服务的接口(interface)。...Facades Laravel Facades 和辅助函数提供了一种使用 Laravel 服务的简单方法,即不需要通过类型提示并从服务容器中解析契约。...而 repository 类不应该了解太多关于谁提供了这些数据或是如何提供的等等。 比起上面的做法,我们可以使用一个简单的、与扩展包无关的接口来改进我们的代码: <?...简单性 当所有 Laravel 的服务都使用简洁的接口定义,就很容易判断给定服务提供的功能。可以将契约视为说明框架功能的简洁文档。 除此之外,当依赖的接口足够简洁时,代码的可读性和可维护性会大大提高。...如何使用契约 Laravel 中的许多类型的类都是通过 服务容器 解析出来的,包括控制器、事件监听器、中间件、任务队列,甚至路由闭包。

    1K10

    30分钟用Laravel实现一个博客

    本教程的目的完全为向各位 phper 以及对 laravel 有兴趣的小伙伴推荐这款我相信是未来主流的php框架。...---- 使用模型工厂 Factory 来插入虚构的数据 在日常的开发中,我们需要很多模拟的数据进行测试,模型工厂的作用就是帮我们快速的,随机的生成这些数据。...tinker 模式调试代码 进入 “修补匠模式” php artisan tinker , 当命令提示符变为 ">>>" 时,你就处于tinker模式下了,此时你可以输入php代码,或者调用laravel...') }} => 我的博客 //注意这里有一个 config('app.name') 该函数其实是读取的 /.env 里的 APP_NAME 值,且默认值为 'Laravel' ,也就是说,你改 APP_NAME...当然,我们还有 Request 请求认证 Policy 策略控制等等一些列的特性没有学习,我们也只使用了一次composer,其实在开发Laravel时,我们还可以使用非常多的,支持Laravel的,完善的轮子可以利用

    7.4K00

    在Swoole上使用双容器策略实现请求隔离的依赖注入

    请求中生成的单例, 挂载到容器的动态属性上. 持有”进程级容器”, 当绑定不存在时, 到”进程级容器” 上查找之....所谓容器, 相当于一个全局的工厂. 可以在这里 “注册” 各种服务的工厂方法, 再使用容器统一地获取....所以直接使用了 Laravel 的 Application 做 “进程级容器”, 确保自己请求中用到的核心业务逻辑都不注册到 laravel中, 避免污染....就我发现, 最容易导致内存泄露的两种情况: 某个闭包在每次请求时生成一个闭包实例, 被每个容器持有 容器生成的某个服务是匿名类, 导致相互持有 简单来说, 就是定义闭包和匿名类时, 慎重考虑内存泄露的可能性就行...2791,"memory":10485760} Swoole 除了免去了每次请求启动系统的开销之外, 还带来了额外的性能提升: 由于大量使用 PHP 的反射特性来实现复杂的依赖注入, 所以反射本应该是性能开销的大头

    1.5K30

    laravel 学习之路 配置config

    'name' => env('APP_NAME', 'Laravel') 到这里这句代码的意思就很明显了,从 .env 获取 APP_NAME 的值,如果 .env 中不存在 APP_NAME 那就取默认值...Laravel 在 config/database.php 文件中我们可看到数据库的配置 ?...其中有一行写了 .env ,它的作用就是告诉 git 忽略 .env 文件,所以如果你去 github 上看别的 laravel 项目的时候你会发现并没有 .env 文件....APP_URL 是需要该的,他就是项目的域名,我是在本地开发的 http://study.laraveltest.com/ DB_开头的这一堆配置也都要改成本地数据库。 ?.../config 目录下的数据库的配置 laravel 5.4 以后默认使用 utf8mb4 字符集,utf8mb4 主要是用来支持 emoji 表情的,如果你的本地环境的mysql 低于5.7.7,为了防止在以后使用的过程中报如下错误

    2.1K10

    通过 Laravel 创建一个 Vue 单页面应用(五)

    我们在 第4部分 完成了编辑用户的功能,并且学习了如何使用 v-model 来监听视图组件中用户信息的更改。现在我们可以开始构思删除用户功能,以及删除操作成功后如何处理 UI 变化。...如何对成功删除用户作出相应的反馈 与更新一个用户不同的一点是,一旦我们成功删除了一个用户记录,那么数据库中就没有这个用户的记录了。在传统的网页应用中,我们会删除那条用户记录,然后重定向返回用户列表。...我们可以使用一个专门的弹窗/通知机制来通知用户。抛砖引玉,我会提供给你一个粗略版本的代码,但是这只是我针对这个问题的一个基本的想法。... 因为在后端的Laravel程序中存在一个万能路由, 这意味着前端也需要这么一个万能路由,当访问路径与已经定义的路由不匹配时以一个404页面作为响应。...API客户端选项 尽管我们奉献的 users.js 在小型应用程序中,HTTP 客户端可能被认为是有点小题大做了,我认为分离已经为我们提供了很好的服务,因为我们在多个组件中使用了 API 模块。

    4.4K20

    通过 Laravel 创建一个 Vue 单页面应用(二)

    在这个教程中,我们通过学习怎样从 Vue 组件中的 Laravel API 加载异步数据,来继续在 Laravel 中创建一个 Vue 单页应用(SPA)。...我们也会看看相关的错误处理,比如当 API 返回错误,接口如何响应。 如果你没有学习 第一部分,我们通过 Vue Router 和 Laravel 后端组建的 Vue 单页应用(SPA)。...如果你想继续跟着学习的话,你应该先去完整地学习一下第一部分! 保持服务端数据简单,我们的 API 将返回假数据。在第三部分,我们将让 API 通过控制器从数据库中返回测试数据。...', 10)->make(); }); 我们的临时路由采用 模型工厂 来创建一个还没有保存到数据库的 Eloquent 模型集合。...使用 make() 方法, 不会将测试数据存入数据库,反而它会返回一个新的还没有存入数据库的 App\User 实例。

    3.4K30

    Laravel 6.10 版本发布,支持 PHPUnit 9,为 PHP 8 留下后手

    第一部分:重要新特性介绍 下面,我们一起来看下几个重要的新特性: Laravel Mix 测试辅助函数 在新版本中,可以通过 withoutMix() 和 withMix() 测试辅助函数启用或禁用异常处理...Redis 连接类支持定义宏方法 和 Laravel 框架中其他支持 macro 方法的类一样,现在可以在 Redis Connection 上调用 macro 定义宏方法: use Illuminate.../testbench-core 扩展包的依赖 从容器中解析 Faker\Generator 问题修复 修复 Blueprint 中 float 数据库字段类型 修复依赖 getenv() 的代码 防止在重连时进行实际的...PSR 工厂修复 #31027 在数据库验证器中默认使用模型连接 代码优化 优化服务提供者注册 优化 runningInConsole 方法 延迟翻译器和视图工厂的实例化 废弃代码 废弃 PendingMail...::sendNow() 并移除不必要的检查 还原代码 还原 TransactionCommitted 事件不包含我期望的事物级别 重构代码 重构 BladeCompiler::compileString

    2.5K30

    orm 系列 之 Eloquent演化历程2

    来实现,最终是通过将执行记录以log的形式插入到数据库中。...当访问 commentable 关联时,ORM 根据commentable_type 字段来判断所属模型的类型并返回相应模型实例。...让我们跟着git继续追踪吧_ 新纪元 为了解决PHP组件管理及散步的问题,2009年的php|tek大会上成立了PHP-FIG组织,目的在于透过三个方式来制定PHP社群在开发组件时的规范,laravel...*版本的时候,laravel/framework还采用的psr-0规范,所有其目录层级还是src/Illuminate/Database,在这个版本中有个新的目录Capsule,其下面是一个Manager...此处为什么会出现Manager,当项目变复杂后,我们很难简单的和Eloquent的内部的组件进行有效的功能了,这个时候需要一个项目的门面,帮助我们和外界沟通,让外界尽可能简单的使用Eloquent,于是就出现了

    2.4K30
    领券