Laravel开发实践LaravelPHP实战

Laravel 新手入门

2019-06-27  本文已影响2人  _给我一支烟_

学习 Laravel 框架的前提必须安装和配置好php的环境,Windows上的php环境参考《Windows下用xmapp配置PHP开发环境》,Linux上的环境参考《LNMP 安装手册》

php 环境配置好后,下载 composer 工具,建议直接安装到 php.exe同目录下,或者安装完把里面的东西拷贝到 php.exe目录下,这样就可以直接执行 composer 命令了。
安装完成后,使用 git-bash 工具进入到安装目录,执行 ./composer 命令
可以看到版本表示安装成功

   ______
  / ____/___  ____ ___  ____  ____  ________  _____
 / /   / __ \/ __ `__ \/ __ \/ __ \/ ___/ _ \/ ___/
/ /___/ /_/ / / / / / / /_/ / /_/ (__  )  __/ /
\____/\____/_/ /_/ /_/ .___/\____/____/\___/_/
                    /_/
Composer version 1.8.5 2019-04-09 17:46:47

1.安装 Laravel

修改镜像,将配置信息添加到 Composer 的全局配置文件 config.json 中

cd /c/Users/Administrator/AppData/Roaming/Composer
composer config -g repo.packagist composer https://packagist.phpcomposer.com

安装laravel 方式一:(没成功)
1.通过 Composer 安装 Laravel 安装器:
composer global require "laravel/installer"
2.安装完后可通过 laravel new 项目名

安装laravel 方式二:
composer create-project --prefer -dist laravel/laravel 项目名
指定版本
composer create-project --prefer -dist laravel/laravel 项目名 5.6.39

2. 访问测试

安装完 Laravel 项目后(如安装的项目路径 F:\PHP\laravel),需要将 Web 服务器的 document/web 根目录指向 Laravel 应用的 public 目录,该目录下的 index.php 文件作为前端控制器(单一入口),所有 HTTP 请求都会通过该文件进入应用。
具体操作步骤:参考《Windows下用xmapp配置PHP开发环境》
2.1 修改 D:\xampp\apache\conf\extra\httpd-vhosts.conf 配置文件,增加一个站点

<VirtualHost *:80>
    DocumentRoot "F:/PHP/laravel/public"
    ServerName mylaravel.com
</VirtualHost>

2.2 修改 C:\Windows\System32\drivers\etc\host 文件在里面增加 一条

127.0.0.1 mylaravel.com

2.3 重启 xmapp 工具里面 apache 服务器
2.4 在浏览器中 输入 mylaravel.com 即可访问到刚刚创建的 laravel 项目了
访问的页面呈现是 resources/views/welcome.blade.php 文件

3.Laravel 框架学习

laravel 中文文档

3.1 使用 artisan 创建命令文件
php artisan make:command TestCreate

执行完该命令后会在 app/Console/Commands 目录下 创建一个 TestCreate.php 文件,创建这种文件一般都是处理定时任务的。
写完任务后,在 ../Kernel.php 文件里的 schedule 方法中增加 任务的执行

$schedule->command('TestCreate')->dailyAt('00:00'); //每天凌晨执行
$schedule->command('TestCreate')->dailyAt('00:00')->withoutOverlapping()->runInBackground();
withoutOverlapping() //当一个进程还没跑完,下个时间点到达时不会开启新的进程
runInBackground() //在后台运行,不会阻塞schedule 方法的中后面一个命令

任务执行的粒度有如下:

->everyMinute(); 每分钟运行一次任务 
->everyFiveMinutes(); 每五分钟运行一次任务 
->everyTenMinutes(); 每十分钟运行一次任务 
->everyFifteenMinutes(); 每十五分钟运行一次任务 
->everyThirtyMinutes(); 每三十分钟运行一次任务 
->hourly(); 每小时运行一次任务 
->hourlyAt(17); 每小时第十七分钟运行一次任务 
->daily(); 每天凌晨零点运行任务 
->dailyAt('13:00'); 每天13:00运行任务 
->twiceDaily(1, 13); 每天1:00 & 13:00运行任务 
->weekly(); 每周运行一次任务 
->monthly(); 每月运行一次任务 
->monthlyOn(4, '15:00'); 每月4号15:00运行一次任务 
->quarterly(); 每个季度运行一次 
->yearly(); 每年运行一次 

添加系统 crontab ,命令行输入

crontab -e

然后在最后加入

* * * * * php /path-to-your-project/artisan schedule:run >> /dev/null 2>&1
3.2 写http的接口
  1. 在 app/Http/Controllers 目录下创建接口控制文件 如 TestController.php
<?php

namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Redis;
use Illuminate\Support\Facades\DB;
use App\Http\Controllers\Controller;

class TestController extends Controller
{
    pubulic function testApi(Request $request)
    {
        // 对请求的业务处理
    }
}
  1. 在 routes/api.php 文件中,添加路由
// Route::middleware('auth:api')->get('/user', function (Request $request) {
//     return $request->user();
// });

Route::any("testApi", "TestController@testApi");
  1. 在浏览器中输入 mylaravel.com/api/testApi 即可访问该接口了
3.3 多环境下环境配置

做一个项目时,开发环境、测试环境和生产环境的配置总是有区别的,laravel 框架默认生成一个 .env.example 的环境配置文件

  1. 把 .env.example 按自己的需求拷贝出三个(可以多个)环境配置文件分别为 .env 用于生产环境,.env.test 用于测试环境, .env.local用于本地开发环境。
  2. 在项目根目录新建一个 env.php
<?php
$str = "APP_ENV=local"; // 通过这个值来控制使用哪个环境配置文件
putenv($str);

/*
$str = "APP_ENV=local";, 使用.env.local配置文件
$str = "APP_ENV=test";, 使用.env.test配置文件
$str = "APP_ENV="; 或者 $str = "APP_ENV=xxx"; 其中xxx不是 local或test,
则会使用.env配置文件,因为 app的 environmentFile默认值是 ".env"
*/
  1. 在 bootstrap/app.php 文件中 引用 env.php 文件
require_once __DIR__."/../env.php";
$app = new Illuminate\Foundation\Application(
    realpath(__DIR__.'/../')
);
  1. 根据APP_ENV值的为何能找到不同的环境配置文件,主要是因为vendor\laravel\framework\src\Illuminate\Foundation\Bootstrap\LoadEnvironmentVariables.php 文件里面的
/**
     * Detect if a custom environment file matching the APP_ENV exists.
     *
     * @param  \Illuminate\Contracts\Foundation\Application  $app
     * @return void
     */
    protected function checkForSpecificEnvironmentFile($app)
    {
        if ($app->runningInConsole() && ($input = new ArgvInput)->hasParameterOption('--env')) {
            if ($this->setEnvironmentFilePath(
                $app, $app->environmentFile().'.'.$input->getParameterOption('--env')
            )) {
                return;
            }
        }

        if (! env('APP_ENV')) {
            return;
        }
        $this->setEnvironmentFilePath(
            $app, $app->environmentFile().'.'.env('APP_ENV')
        );
    }
3.4 公共方法的创建
  1. 在 app/Http/Helpers/ 目录下建一个项目公共 common.php 文件
  2. 在项目根目录下 composer.json·中 autoload 项里面加入
"autoload": {
   "files": [
        "app/Http/Helpers/common.php"
    ]
}
  1. 用 git-bash 工具进入项目目录下执行
composer dump-autoload
上一篇下一篇

猜你喜欢

热点阅读