需求場景php
發送「驗證碼」或者「消息通知」,可發送到手機或郵箱中。html
完成git
首先,在 Laravel 中的規範就是使用 Laravel 的「消息通知」,這裏基於場景爲「驗證碼」。這個需求幾乎全部軟件系統都有使用到。github
建立通知場景併發
而後建立一個驗證碼數據模型和數據表遷移,可使用 php artisan make:model \"VerificationCode\" -m 直接快速建立數據模型和遷移。composer
第二步,打開數據模型類,在裏面添加 Illuminate\Notifications\Notifiable 性狀:函數
打開 database/factories/ModelFactory.php 在裏面添加一個關於通知數據模型的工廠定義:
這樣,咱們就能夠經過 factory(\Zhiyi\Plus\Models\VerificationCode::class) 工廠函數快捷的建立驗證碼併發送通知。
這是Laravel官方文檔原話,意思就是Illuminate\Notifications\Notifiable不單單是用在 User 模型上。
因此咱們在驗證碼模型中添加 Illuminate\Notifications\Notifiable 是徹底符合Laravel通知的正確使用的。
首先,在數據表遷移中存在一個字段 channel 也就是通知頻道標識,咱們可根據這個值來決定用什麼方式發送驗證碼,而這個操做在通知類的 via 中實現的:
咱們選擇方式就是直接返回 channel 值,這個值能夠是任何值,只要咱們實現了這個通知頻道,均可以發送,而Laravel已經內置和一些發送頻道 database、mail 和 nexmo
其實,這個步驟咱們要作的事情已經不多了,生產通知類的時候,已經完成了 toMail 方法,因此,咱們直接修改其消息內容便可。
短信發送咱們採用 overtrue/easy-sms 包,這是安正超開發的一個短信發送客戶端,已經內置了不少短信平臺,實現也很優秀。(吐槽:雖然有些細節有問題,例如不按照契約調用方法傳遞網關)
我門增長了一個 channel 配置,用於不一樣場景,例如驗證碼場景 code 以方便消息器讀取配置。
而後打開 AppServiceProvider.php 在 register 中增長以下:
至此 EasySms 在 Laravel 中的集成已經完成,可是尚未開發實際功能,咱們接着往下看。
這部分徹底屬於 easy-sms 使用開發,咱們新建一個 VerificationCodeMessage.php ,內容以下:
而後咱們回到 VerificationCode 驗證碼通知類中,增長 toSms 方法,個人代碼以下:
場景配置,例如驗證碼不一樣頻道的 template 等,這樣消息器就能夠根據發送網關來判斷使用場景的配置是什麼。
再次吐槽,easy-sms 的契約設計也應該是這個思想,可是 getContent/getTemplate/getData 在實際網關調用的時候根本沒有傳遞網關過來。。。
在建立驗證碼數據模型的時候就已經添加到「工廠」中,因此咱們能夠直接使用 factory 函數了,發送演示:
上面代碼都是來自於 ThinkSNS Plus ,看完整的開發代碼能夠看倉庫:
GitHub: https://github.com/slimkit/thinksns-plus
我有幾張阿里雲幸運券分享給你,用券購買或者升級阿里雲相應產品會有特惠驚喜哦!把想要買的產品的幸運券都領走吧!快下手,立刻就要搶光。