[Laravel] 09 - Functional models

Laravel框架下的若干經常使用功能實現。php

  • 文件上傳
  • 郵件發送
  • 緩存使用
  • 錯誤日誌
  • 隊列應用

 

 

文件上傳


1、配置文件

  • 功能

 

  • 配置

[config/filesystems.php]html

    'disks' => [

        'local' => [
            'driver' => 'local',
            'root' => storage_path('app'),
        ],

        'public' => [
            'driver' => 'local',
            'root' => storage_path('app/public'),
            'visibility' => 'public',
        ],

        's3' => [
            'driver' => 's3',
            'key' => 'your-key',
            'secret' => 'your-secret',
            'region' => 'your-region',
            'bucket' => 'your-bucket',
        ],

    ],

新添加插入其中:數據庫

        'uploads' => [
            'driver' => 'local',
            'root' => storage_path('app/uploads'),
        ],

 

 

2、畫個視圖 

  • 添加布局

 

  • 修改佈局

 

  • 路由 --> 控制器 --> 視圖 

[1] 路由數組

Route::any('upload', 'StudentController@upload'); 

[2] 控制器:獲取 字段 爲 "source」 的表單。緩存

if ($request->isMethod('POST') ) {

  $file = $request->file('source');

  if ($file->isValid() ) {

    // 原文件名
    $originalName = $file->getClientOrignalNam();

    // 擴展名
    $ext = $file->getClientOriginalExtension();

    // MimeType
    $type = $file->getClientMineType();

    // 臨時絕對路徑
    $realPath = $file->getRealPath();

    $filename = date('Y-m-d-H-i-s) . '-' . uniqid() . '.' . $ext;    

     $bool = Storage::disk('uploads')->put($filename, file_get_content($realPath));
    var_dump(bool);
  }
  exit;
}

[3] 文件上傳位置app

表單內容打印出來瞧瞧:【圖片信息】框架

 

 

 

郵件發送


1、配置文件 

  • 功能

 

  • 配置

[config/mail.php]ide

smtp默認佈局

'from' => ['address' => null, 'name' => null],
'username' => env('MAIL_USERNAME'),
'password' => env('MAIL_PASSWORD'),

[.env]測試

 

 

2、控制器 - 發送郵件

use Mail;
class
StudentController extends Controller {   public function mail()   {     Mail::raw('郵件內容’, function($message) {              
    }
  
    --------------------------------------------------------------------
    Mail::send('student.mail', ['name' => 'sean', 'age' => 18], function($message) {
      $message->to('.......@qq.com');
    });
  }
}

 

[student/mail.blade.php]

新建並設計一個Html模板。

 

 

 

緩存使用


1、主要方法以及配置文件

put(), add(), forever(), has(), get(), pull(), forget()

配置文件:[config/cache.php]

 

 

2、控制器

  •  Cache::put - 添加後讀取緩存
public function cache1()
{
  // put()
  Cache::put('key1', 'val1', 10);    #10min
}

public function cache2()
{
  // get()
  $val = Cache::get('key1'); 
}

 

  • Cache::add - 添加後讀取緩存
public function cache1()
{
  // add()
  $bool = Cache::add('key1', 'val1', 10);    #key1存在則不能添加
}

public function cache2()
{
  // get()
  $val = Cache::get('key1'); 
}

 

  • Cache::forever - 添加後讀取緩存
public function cache1()
{
  // add()
  $bool = Cache::forever('key3', 'val3');
}

 

public function cache2()
{
  // get()
  $val = Cache::get('key1'); 
}

  

  • Cache::has - 鍵值存在否
public function cache1()
{
  if (Cache::has('key1')) {
    $val = Cache::get('key');
    var_dump($val);
  } else {
    echo 'No';
  }
} public function cache2() {   // get()   $val = Cache::get('key1'); }

 

  • Cache::pull - 取走數據
public function cache2()
{
  // pull()
  $val = Cache::pull('key1');   # 取走後值就沒了
}

 

  • Cache::forget - 緩存中刪除對象
public function cache2()
{
  // forget()
  $bool = Cache::forget('key1');   # 取走後值就沒了 }

 

  • 緩存文件的具體位置

 

 

 

 

錯誤與日誌


1、知識點

Debug模式,HTTP異常,日誌。

 

 

2、Debug模式

  • 簡介

    • 配置 [.env]
APP_DEBUG=true
    • 設置 [config/app.php]

 

  • 路由 --> 控制器
Route::any('error', 'StudentController@error');

APP_DEBUG=true後,控制器內代碼有問題,會出現相對友好不易被攻擊的提示信息。

 

 

3、HTTP異常

  • 簡介 

其實就是,控制器調用abort,直接返回error.blade的視圖。

 

  • 視圖
<!DOCTYPE html>
<html>
    <head>
        <title>Be right back.</title>

        

        <style>
            html, body {
                height: 100%;
            }

            body {
                margin: 0;
                padding: 0;
                width: 100%;
                color: #B0BEC5;
                display: table;
                font-weight: 100;
                font-family: 'Lato';
            }

            .container {
                text-align: center;
                display: table-cell;
                vertical-align: middle;
            }

            .content {
                text-align: center;
                display: inline-block;
            }

            .title {
                font-size: 72px;
                margin-bottom: 40px;
            }
        </style>
    </head>
    <body>
        <div class="container">
            <div class="content">
                <div class="title">Be right back.</div>
            </div>
        </div>
    </body>
</html>
http error 503

 

  • 調用視圖:abort()

 

 

 

4、日誌

  • 簡介

 

  • 設置與配置
    /*
    |--------------------------------------------------------------------------
    | Logging Configuration
    |--------------------------------------------------------------------------
    |
    | Here you may configure the log settings for your application. Out of
    | the box, Laravel uses the Monolog PHP logging library. This gives
    | you a variety of powerful log handlers / formatters to utilize.
    |
    | Available Settings:"single", "daily", "syslog", "errorlog"
    |
    */

    'log' => env('APP_LOG', 'single'),

 

  • 生成日誌
public function error()
{
  Log::info('這是一個info級別的日誌');
}

日誌文件

日誌內容

數組形式

Log::error('這是一個數組’,['name' => 'sean', 'age' => 18]); 

 

  • daily日誌

生成帶日期標示的日誌。

 

 

 

隊列


1、簡介

配置文件:[config/queue.php]

 

 

2、遷移隊列須要的數據表

  • 設置 QUEUE_DRIVER

 

  • 建立遷移文件

$ php artisan queue:table

有了 <time>_create_jobs_table.php 文件

 

  • 執行遷移

$ php artisan migrate

多了一個jobs表。

 

 

3、建立任務類

  • 建立 SendEmail.php 
$ php artisan make:job SendEmail 

文件自動有了類的框架,以下:

 

  • 任務加入隊列

經過路由執行:route --> queue(),推送到隊列中。

use Mail

public function queue()
{
  dispatch(new SendEmail('xxxx@qq.com'));
}

 

  • 運行隊列 listener

運行:$ php artisan queue:listen

public function handle()
{
  Mail::raw('隊列測試‘, function($message) {
    $message->to($this->email);
  });

Log::info('Email sent.'); }

 

 

4、處理失敗任務

  • 創建失敗表的遷移文件

$ php artisan queue:failed-table 

 

  • 執行遷移

$ php artisan migrate

遷移成功,數據庫中可見到新表。

 

  • 失敗了會有記錄在數據庫中

 

  • 從新執行失敗隊列

列出失敗隊列:$ php artisan queue:failed

 

  • 完全刪掉失敗隊列

列出失敗隊列:$ php artisan queue:forget 4 

列出失敗全部隊列:$ php artisan queue:flush

相關文章
相關標籤/搜索