某天,有個需求,能否自動匯出資料到google sheet,
當然是沒問題~
先看看google官方的文件… 似乎有點麻煩呀,
那就看看laravel有沒有package了…
當然是有的,而且省去了官方文件上一連串登入的動作,
本文所採用的環境
- Max OSX 10.15
- Docker version 19.03.5
Google Sheets API v4 for Laravel
這package的存去方式是透過在google apis中,
開啟 google sheet 和 雲端硬碟 的api使用權限,
並建立一個虛擬帳戶,供程式使用該帳戶登入並存取api,
所以我們先到google apis中建立專案,
data:image/s3,"s3://crabby-images/9805f/9805fd06743813e0b2a3f7a8786d187b82f93bdf" alt="api1 api1"
建立完專案後,啟動api服務,
data:image/s3,"s3://crabby-images/a86a1/a86a115bafd221e93ee35d60d9c17f2ce132460c" alt="api2 api2"
本次要起動 sheet 和 drive 這兩項服務,
data:image/s3,"s3://crabby-images/40a60/40a60d16eb02f2b1b1d27dbfb20d2c1a306c6e88" alt="api3 api3"
data:image/s3,"s3://crabby-images/5237e/5237eadb34185f8bdf7873bd938f58aca6a603dd" alt="api4 api4"
點下啟用後就完成了!((drive也是如此方式啟動
接著就是建立一個虛擬帳戶,來供程式存取,
依稀還記得以前都是直接開一個google帳號用來登入,
現在可以透過虛擬帳戶,真的是比較方便,又不用怕密碼放到程式中…
左側選單中找到api與服務,再選憑證
data:image/s3,"s3://crabby-images/b1fe5/b1fe5905b1ad21802d94bf647598d6b88b07ad25" alt="api5 api5"
進入憑證的頁面後,選擇建立憑證,
data:image/s3,"s3://crabby-images/a8df7/a8df729ff8f012447465213cbe1a41b3502a5c85" alt="api6 api6"
輸入該虛擬帳戶的名稱,
data:image/s3,"s3://crabby-images/7bb0a/7bb0a79c28c9a073ea42c6b31853b0d6a381ed50" alt="api7 api7"
幫該帳戶設定權限
data:image/s3,"s3://crabby-images/a8d41/a8d41c26a6ae9d02d79d2f77dbd8c9091f5013bd" alt="api8 api8"
幫憑證弄一組金鑰
data:image/s3,"s3://crabby-images/9520e/9520e0dc8d33498710694734b6897ee6bd0a70b3" alt="api9 api9"
右側會跳出選項,這裡我們選擇json
data:image/s3,"s3://crabby-images/bd223/bd2235c0ff8148b488e908936a339ff12c30f624" alt="api10 api10"
之後就會自動下載一個json檔,該檔案會有這個虛擬帳戶的登入資訊,請妥善保管喔!
data:image/s3,"s3://crabby-images/e1d7a/e1d7ac7edeec3efe071636af83774874d344e69a" alt="api11 api11"
開一個google sheet,並分享這個檔案給虛擬帳戶
data:image/s3,"s3://crabby-images/9a5f9/9a5f99e330f614f0657cabc8b27b302cf2f8140c" alt="api12 api12"
***
接下來回到Laravel,
先安裝這個package,並建立組態檔
1 2 3 4
| # 安裝package composer require revolution/laravel-google-sheets # 設定組態檔 php artisan vendor:publish --provider="PulkitJalan\Google\GoogleServiceProvider" --tag="config"
|
小貼士
package預設是給laravel >= 5.8的專案使用,若現在低於這個版本的話…
別擔心這邊有更新紀錄
該package還有支援到 php7 + laravel 5.5 的呦~~
當時找到這package時也忘了版本,研究好也寫個service要交給同事時,才想到自家專案是5.5阿…
差點以為要熬夜從來了,還好有來看一下,還好有支援5.5呀~~~
裝好將我們剛剛取得的json檔放到public底下,
然後到.env底下,將以下貼入
1 2 3 4 5 6 7 8 9
| GOOGLE_APPLICATION_NAME= GOOGLE_CLIENT_ID= GOOGLE_CLIENT_SECRET= GOOGLE_REDIRECT= GOOGLE_DEVELOPER_KEY= GOOGLE_SERVICE_ENABLED=true GOOGLE_SERVICE_ACCOUNT_JSON_LOCATION=剛剛取得的那個json檔 POST_SPREADSHEET_ID=google sheet的 id POST_SHEET_ID=google sheet作業簿的名字
|
POST_SPREADSHEET_ID 跟 POST_SHEET_ID 在這裡
data:image/s3,"s3://crabby-images/59727/59727a31eebfcd54e57febe45e0915d1b6676160" alt="laravel1 laravel1"
之後到congfig/google.php中貼上
1 2 3 4 5
| 'scopes' => [\Google_Service_Sheets::DRIVE, \Google_Service_Sheets::SPREADSHEETS], --- 'post_spreadsheet_id' => env('POST_SPREADSHEET_ID', ''), 'post_sheet_id' => env('POST_SHEET_ID', ''),
|
這樣就完成我們的基本設定拉~ 開始寫code摟
我們開一個叫GSheetService的檔案,
如果有在laravel做分層架構的話,就把這檔案放到你的service層 (( 商業邏輯層、共用類別… 巴拉巴拉的地方
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
| <?php
namespace App\Services;
use Sheets;
class GSheetService {
public function Sheet($sheet_id, $sheet_name) { return Sheets::spreadsheet($sheet_id)->sheet($sheet_name); }
public function Get($sheet_id, $sheet_name) { return $this->Sheet($sheet_id, $sheet_name)->get(); }
public function Append($sheet_id, $sheet_name, $data = []) { return $this->Sheet($sheet_id, $sheet_name)->append([$data]); }
public function Update($sheet_id, $sheet_name, $data = []) { return $this->Sheet($sheet_id, $sheet_name)->update([$data]); } }
|
在這個service中,我們將作者提供的功能稍微包裝成幾個package供我們的程式使用,
然後我們回到Controller中,將剛才的Service引用進去,
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
| <?php
namespace App\Http\Controllers;
use Illuminate\Http\Request; use App\Services\GSheetService;
class SheetController extends Controller { protected $gsheetservice;
public function __construct(GSheetService $gsheetservice) { $this->gsheetservice = $gsheetservice; }
public function Sheet() { $sheets = $this->gsheetservice->Get(config('google.post_spreadsheet_id'), config('google.post_sheet_id'));
dd($sheets); }
public function AddSheet() { $data = ['2020-4-19', '3000', '2000', '', 'test']; $sheets = $this->gsheetservice->Append(config('google.post_spreadsheet_id'), config('google.post_sheet_id'), $data); $sheets = $this->gsheetservice->Get(config('google.post_spreadsheet_id'), config('google.post_sheet_id')); dd($sheets); } }
|
之後就是到 web/router.php 設定一下簡單的路由
1 2
| Route::get('/sheet', 'SheetController@Sheet'); Route::get('/sheetadd', 'SheetController@AddSheet');
|
我們先測試get吧,
data:image/s3,"s3://crabby-images/308c5/308c54ceb688ef3e31b71de8417b2b3548d040c9" alt="laravel2 laravel2"
看到這個畫面就表示成功取得google sheet的資料拉~
那換測試新增看看,
data:image/s3,"s3://crabby-images/05d5e/05d5ea0f0713049680c915b6ca14ceaba1ed3a27" alt="laravel3 laravel3"
陣列長度變3,也可以看到剛剛新增的資料~~
完成拉
後記
其實google近幾年把api文件整理的比較清楚了,
但教學還是優先在oauth2登入的部分,
但我們不需要一個登入畫面給使用者登入,我們只需要一個權限去讀取檔案而已。
至於刪除~~ package似乎沒有這function,
粗步推估要get,刪除某一筆後,在update回sheet中~~
下次再做個py版的,也是有套件輔助,方便許多
Ref
Google Sheets API v4 for Laravel
CONNECTING LARAVEL TO A GOOGLE SHEET