laravel框架各文件作用是什么?之间什么关系?

laravel框架各文件作用是什么?之间什么关系?,第1张

文件的文件夹

作用

/app/config/

配置应用程序的运行时规则、 数据库、 session等等。包含大量的用来更改框架的各个方面的配置文件。大部分的配置文件中返回的选项关联PHP数组。

/app/config/app.php

各种应用程序级设置,即时区、 区域设置(语言环境)、 调试模式和独特的加密密钥。

/app/config/auth.php

控制在应用程序中如何进行身份验证,即身份验证驱动程序。

/app/config/cache.php

如果应用程序利用缓存来加快响应时间,要在此配置该功能。

/app/config/compile.php

在此处可以指定一些额外类,去包含由‘artisan optimize’命令声称的编译文件。这些应该是被包括在基本上每个请求到应用程序中的类。

/app/config/database.php

包含数据库的相关配置信息,即默认数据库引擎和连接信息。

/app/config/mail.php

为电子邮件发件引擎的配置文件,即 SMTP 服务器,From:标头

/app/config/session.php

控制Laravel怎样管理用户sessions,即session driver, session lifetime。

/app/config/view.php

模板系统的杂项配置。

/app/controllers

包含用于提供基本的逻辑、 数据模型交互以及加载应用程序的视图文件的控制器类。

/app/database/migrations/

包含一些 PHP 类,允许 Laravel更新当前数据库的架构并同时保持所有版本的数据库的同步。迁移文件是使用Artisan工具生成的。

/app/database/seeds/

包含允许Artisan工具用关系数据来填充数据库表的 PHP 文件。

/app/lang/

PHP 文件,其中包含使应用程序易于本地化的字符串的数组。默认情况下目录包含英语语言的分页和表单验证的语言行。

/app/models/

模型是代表应用程序的信息(数据)和 *** 作数据的规则的一些类。在大多数情况下,数据库中的每个表将对应应用中的一个模型。应用程序业务逻辑的大部分将集中在模型中。

/app/start/

包含与Artisan工具以及全球和本地上下文相关的自定义设置。

/app/storage/

该目录存储Laravel各种服务的临时文件,如session, cache, compiled view templates。这个目录在web服务器上必须是可以写入的。该目录由Laravel维护,我们可以不关心。

/app/tests/

该文件夹给你提供了一个方便的位置,用来做单元测试。如果你使用PHPUnit,你可以使用Artisan工具一次执行所有的测试。

/app/views/

该文件夹包含了控制器或者路由使用的HTML模版。请注意,这个文件夹下你只能放置模版文件。其他的静态资源文件如css, javascript和images文件应该放在/public文件夹下。

/app/routes.php

这是您的应用程序的路由文件,其中包含路由规则,告诉 Laravel 如何将传入的请求连接到路由处理的闭包函数、 控制器和 *** 作。该文件还包含几个事件声明,包括错误页的,可以用于定义视图的composers。

/app/filters.php

此文件包含各种应用程序和路由筛选方法,用来改变您的应用程序的结果。Laravel 具有访问控制和 XSS 保护的一些预定义筛选器。

花了很多心思在建立和命名文件夹上,得到的就是一个具有良好的文件系统的应用程序。

在这里你得到了什么:MVC

一、读/写连接

有时您可能希望使用一个SELECT语句的数据库连接,,另一个用于插入、更新和删除语句。Laravel使这微风,将始终使用正确的连接是否使用原始查询,查询生成器或雄辩的ORM。

如何读/写连接应该配置,让我们看看这个例子:

复制代码 代码如下:

'mysql' =>array('read' =>array('host' =>'192.168.1.1'),'write' =>array('host' =>'196.168.1.2'),'driver' =>'mysql','database' =>'database','username' =>'root','password' =>'','charset' =>'utf8','collation' =>'utf8_unicode_ci','prefix' =>'')

注意,两个键添加到配置阵列:读和写。这两个键有数组值包含一个关键:主机。其余的读写数据库选项从主mysql连接将合并后的数组。所以,我们只需要将物品放入读取和写入数组如果我们希望覆盖主要数组中的值。所以,在这种情况下,192.168.1.1将被用作“读”连接,while192.168.1.2将被用作“写”连接。数据库凭证、前缀、字符集和所有其他选项在主mysql数组将跨两个共享连接。

二、运行查询

一旦你已经配置了数据库连接,你可以使用DB运行查询类。

运行一个Select查询

复制代码 代码如下:

$results = DB::select('select * from users where id = ?', array(1))

结果的选择方法总是返回一个数组。

运行一个Insert语句

复制代码 代码如下:

DB::insert('insert into users (id, name) values (?, ?)', array(1, 'Dayle'))

运行一个更新语句

复制代码 代码如下:

DB::update('update users set votes = 100 where name = ?', array('John'))

运行一个Delete语句

复制代码 代码如下:

DB::delete('delete from users')

注意:update和delete语句返回的行数的影响 *** 作。

运行一个通用声明

复制代码 代码如下:

DB::statement('drop table users')

查询事件监听

你可以查询事件监听使用DB::听方法:

复制代码 代码如下:

DB::listen(function($sql, $bindings, $time){ //})

三、数据库事务

运行在一个数据库事务的一组 *** 作,您可以使用事务方法:

复制代码 代码如下:

DB::transaction(function(){ DB::table('users')->update(array('votes'

=>1))DB::table('posts')->delete()})

注意:在事务抛出的任何异常关闭将导致自动事务将回滚

有时你可能需要开始一个事务:

复制代码 代码如下:

DB::beginTransaction()

你可以通过回滚事务回滚方法:

复制代码 代码如下:

DB::rollback()

最后,您可以通过提交方法:提交一个事务

复制代码 代码如下:

DB::commit()

四、访问连接

当使用多个连接,你可以访问它们通过DB::连接方法:

复制代码 代码如下:

$users = DB::connection('foo')->select(...)

你也可以访问原始的、潜在的PDO实例:

复制代码 代码如下:

$pdo = DB::connection()->getPdo()

有时你可能需要重新连接到一个给定的数据库:

复制代码 代码如下:

DB::reconnect('foo')

如果你需要断开从给定的数据库将超过底层PDO实例'smax_connections限制,使用断开连接方法:

复制代码 代码如下:

DB::disconnect('foo')

五、查询日志

默认情况下,Laravel日志保存在内存的所有查询运行当前的请求。然而,在某些情况下,例如当插入的行数,这可能会导致应用程序使用多余的内存。禁用日志,你可以使用disableQueryLog方法:

复制代码 代码如下:

DB::connection()->disableQueryLog()

o得到一组执行的查询,您可以使用getQueryLog方法:

复制代码 代码如下:

$queries = DB::getQueryLog()

$users = User::where('id', 1)

         ->get()

         

if(count($users)>0){

  $user = $users[0]

  $user->username = 'bcoder'

  $user->save()

}

给你一个例子,User类是一个users表对应的model           


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/10081024.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存