Laravel5.2目录结构及composer.json文件解析

目录或文件

|– app 包含Controller、Model、路由等在内的应用目录,大部分业务将在该目录下进行

|  |– Console 命令行程序目录

|  |  |– Commands 包含了用于命令行执行的类,可在该目录下自定义类

|  |  |– Kernel.php 命令调用内核文件,包含commands变量(命令清单,自定义的命令需加入到这里)和schedule方法(用于任务调度,即定时任务)

|  |– Events 事件目录

|  |– Exceptions 包含了自定义错误和异常处理类

|  |– Http HTTP传输层相关的类目录

|  |  |– Controllers 控制器目录

|  |  |– Middleware 中间件目录

|  |  |– Requests 请求类目录

|  |  |– Kernel.php 包含http中间件和路由中间件的内核文件

|  |  |– routes.php 强大的路由

|  |– Jobs 该目录下包含队列的任务类

|  |– Listeners 监听器目录

|  |– Providers 服务提供者目录

|  |– User.php 自带的模型实例,我们新建的Model默认也存储在该目录

|– bootstrap 框架启动载入目录

|  |– app.php 创建框架应用实例

|  |– autoload.php 自动加载

|  |– cache 存放框架启动缓存,web服务器需要有该目录的写入权限

|– config 各种配置文件的目录

|  |– app.php 系统级配置文件

|  |– auth.php 用户身份认证配置文件,指定好table和model就可以很方便地用身份认证功能了

|  |– broadcasting.php 事件广播配置文件

|  |– cache.php 缓存配置文件

|  |– compile.php 编译额外文件和类需要的配置文件,一般用户很少用到

|  |– database.php 数据库配置文件

|  |– filesystems.php 文件系统配置文件,这里可以配置云存储参数

|  |– mail.php 电子邮件配置文件

|  |– queue.php 消息队列配置文件

|  |– services.php 可存放第三方服务的配置信息

|  |– session.php 配置session的存储方式、生命周期等信息

|  |– view.php 模板文件配置文件,包含模板目录和编译目录等

|– database 数据库相关目录

|  |– factories 5.1以上版本的新特性,工厂类目录,也是用于数据填充

|  |  |– ModelFactory.php 在该文件可定义不同Model所需填充的数据类型

|  |– migrations 存储数据库迁移文件

|  |– seeds 存放数据填充类的目录

|     |– DatabaseSeeder.php 执行php artisan db:seed命令将会调用该类的run方法。该方法可调用执行该目录下其他Seeder类,也可调用factories方法生成ModelFactory里定义的数据模型

|– public 网站入口,应当将ip或域名指向该目录而不是根目录。可供外部访问的css、js和图片等资源皆放置于此

|  |– index.php 入口文件

|  |– .htaccess Apache服务器用该文件重写URL

|  |– web.config IIS服务器用该文件重写URL

|– resources 资源文件目录

|  |– assets 可存放包含LESS、SASS、CoffeeScript在内的原始资源文件

|  |– lang 本地化文件目录

|  |– views 视图文件就放在这啦

|– storage 存储目录。web服务器需要有该目录及所有子目录的写入权限

|  |– app 可用于存储应用程序所需的一些文件

|  |– framework 该目录下包括缓存、sessions和编译后的视图文件

|  |– logs 日志目录

|– tests 测试目录

|– vendor 该目录下包含Laravel源代码和第三方依赖包

|– .env 环境配置文件。config目录下的配置文件会使用该文件里面的参数,不同生产环境使用不同的.env文件即可。

|– artisan 强大的命令行接口,你可以在app/Console/Commands下编写自定义命令

|– composer.json 存放依赖关系的文件

|– composer.lock 锁文件,存放安装时依赖包的真实版本

|– gulpfile.js gulp(一种前端构建工具)配置文件

|– package.json gulp配置文件

|– phpspec.yml phpspec(一种PHP测试框架)配置文件

|– phpunit.xml phpunit(一种PHP测试框架)配置文件

|– server.php PHP内置的Web服务器将把这个文件作为入口。以public/index.php为入口的可以忽略掉该文件

composer.json文件


{

    "name": "laravel/laravel",  //项目名称

    "description": "The Laravel Framework.",    //描述

    "keywords": ["framework", "laravel"],   //关键词

    "license": "MIT",   //许可协议

    "type": "project",  //类型

    "require": {

        "php": ">=5.5.9",   //PHP版本

        "laravel/framework": "5.2.*"    //框架版本

    },

    "require-dev": {    //依赖包

        "fzaninotto/faker": "~1.4",

        "mockery/mockery": "0.9.*",

        "phpunit/phpunit": "~4.0",

        "symfony/css-selector": "2.8.*|3.0.*",

        "symfony/dom-crawler": "2.8.*|3.0.*"

    },

    "autoload": {   //自动加载

        "classmap": [

            "database"

        ],

        "psr-4": {  //一种自动加载的规范

            "App\\": "app/"

        }

    },

    "autoload-dev": {   //加载测试

        "classmap": [

            "tests/TestCase.php"

        ]

    },

    "scripts": {    //执行脚本

        "post-root-package-install": [

            "php -r \"copy('.env.example', '.env');\""

        ],

        "post-create-project-cmd": [

            "php artisan key:generate"

        ],

        "post-install-cmd": [

            "php artisan clear-compiled",

            "php artisan optimize"

        ],

        "post-update-cmd": [

            "php artisan clear-compiled",

            "php artisan optimize"

        ]

    },

    "config": { //配置项

        "preferred-install": "dist" //优先安装压缩版

    },

    "repositories": {   //配置composer镜像

        "packagist": {

            "type": "composer",

            "url": "https://packagist.phpcomposer.com"

        }

    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值