本期詳細介紹了通過 Twilio 實現(xiàn) OTP 傳送、使用 goroutine 優(yōu)化 OTP 異步發(fā)送,以及建立強大的基于令牌的身份驗證系統(tǒng)。
使用 Twilio 發(fā)送 OTP
使用 Twilio 消息 API 發(fā)送 OTP 的核心功能如下所示:
func (app *application) sendOTPViaTwilio(otp, phoneNumber string) error { client := twilio.NewRestClientWithParams(twilio.ClientParams{ Username: os.Getenv("TWILIO_SID"), Password: os.Getenv("TWILIO_API_KEY"), }) params := &api.CreateMessageParams{} params.SetBody(fmt.Sprintf( "Thank you for choosing Cheershare! Your one-time password is %v.", otp, )) params.SetFrom(os.Getenv("TWILIO_PHONE_NUMBER")) params.SetTo(fmt.Sprintf("+91%v", phoneNumber)) const maxRetries = 3 var lastErr error for attempt := 1; attempt <= maxRetries; attempt++ { resp, err := client.SendSms(params) if err == nil { app.logger.Printf("Message SID: %s", resp.Sid) return nil } lastErr = err time.Sleep(time.Duration(attempt) * 100 * time.Millisecond) } return fmt.Errorf("failed to send OTP after %d retries: %w", maxRetries, lastErr) }
該函數(shù)利用 Twilio 的 Go SDK 發(fā)送消息。 from
號碼是預先配置的 Twilio 號碼。 包含重試機制以確??煽啃浴?/p>
使用 Goroutine 進行異步 OTP 發(fā)送
順序 OTP 發(fā)送會影響服務器性能。 該解決方案涉及利用 goroutine 來同時處理 OTP 傳遞。 application
結構已更新:
type application struct { wg sync.WaitGroup config config models data.Models logger *log.Logger cache *redis.Client }
輔助函數(shù)有助于后臺任務執(zhí)行:
func (app *application) background(fn func()) { app.wg.Add(1) go func() { defer app.wg.Done() defer func() { if err := recover(); err != nil { app.logger.Printf("Error in background function: %v\n", err) } }() fn() }() }
這使用 sync.WaitGroup
來管理 goroutine,確保在關閉之前完成。
數(shù)據(jù)庫令牌表
創(chuàng)建一個新的數(shù)據(jù)庫表來存儲用戶令牌:
-- 000002_create-token.up.sql CREATE TABLE IF NOT EXISTS tokens ( hash bytea PRIMARY KEY, user_id bigint NOT NULL REFERENCES users ON DELETE CASCADE, expiry timestamp(0) with time zone NOT NULL, scope text NOT NULL ); -- 000002_create-token.down.sql DROP TABLE IF EXISTS tokens;
該表存儲哈希令牌、用戶 ID、到期時間和令牌范圍。 數(shù)據(jù)庫遷移是使用migrate
.
代幣模型和功能
data/models.go
文件包含用于令牌生成、插入和檢索的函數(shù):
// ... (other imports) ... package data // ... (other code) ... func generateToken(userId int64, ttl time.Duration, scope string) (*Token, error) { // ... (token generation logic) ... } func (m TokenModel) Insert(token *Token) error { // ... (database insertion logic) ... } func (m TokenModel) DeleteAllForUser(scope string, userID int64) error { // ... (database deletion logic) ... } func (m TokenModel) New(userId int64, ttl time.Duration, scope string) (*Token, error) { // ... (token creation and insertion logic) ... }
此代碼處理令牌創(chuàng)建、散列和數(shù)據(jù)庫交互。 New
函數(shù)創(chuàng)建并存儲新令牌。
注冊處理程序更新
cmd/api/user.go
文件的注冊處理程序已修改為在成功 OTP 驗證后頒發(fā)令牌:
// ... (other functions) ... func (app *application) handleUserSignupAndVerification(w http.ResponseWriter, r *http.Request) { // ... (input parsing and validation) ... // ... (OTP generation and sending logic) ... // ... (OTP verification logic) ... // ... (user creation or retrieval) ... token, err := app.generateTokenForUser(user.ID) if err != nil { // ... (error handling) ... } // ... (success response with token) ... }
這將令牌生成集成到注冊流程中。
中間件層
三個中間件層增強了安全性和請求處理:recoverPanic
、authenticate
和 requireAuthenticatedUser
。 這些已實現(xiàn)并應用于路由,如原文所示。 上下文管理函數(shù)(contextSetUser
和 contextGetUser
)用于在請求上下文中存儲和檢索用戶數(shù)據(jù)。
服務器配置集成了這些中間件,示例展示了如何使用requireAuthenticatedUser
保護路由。 未來的增強功能包括文件上傳、正常關閉和指標集成。 完整的代碼可以在 GitHub 上找到。
以上是使用 Go 構建基于 OTP 的身份驗證服務器:第 3 部分的詳細內容。更多信息請關注PHP中文網(wǎng)其他相關文章!

熱AI工具

Undress AI Tool
免費脫衣服圖片

Undresser.AI Undress
人工智能驅動的應用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover
用于從照片中去除衣服的在線人工智能工具。

Clothoff.io
AI脫衣機

Video Face Swap
使用我們完全免費的人工智能換臉工具輕松在任何視頻中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的代碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
功能強大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6
視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版
神級代碼編輯軟件(SublimeText3)

Golang主要用于后端開發(fā),但也能在前端領域間接發(fā)揮作用。其設計目標聚焦高性能、并發(fā)處理和系統(tǒng)級編程,適合構建API服務器、微服務、分布式系統(tǒng)、數(shù)據(jù)庫操作及CLI工具等后端應用。雖然Golang不是網(wǎng)頁前端的主流語言,但可通過GopherJS編譯成JavaScript、通過TinyGo運行于WebAssembly,或搭配模板引擎生成HTML頁面來參與前端開發(fā)。然而,現(xiàn)代前端開發(fā)仍需依賴JavaScript/TypeScript及其生態(tài)。因此,Golang更適合以高性能后端為核心的技術棧選擇。

要構建一個GraphQLAPI在Go語言中,推薦使用gqlgen庫以提高開發(fā)效率。1.首先選擇合適的庫,如gqlgen,它支持根據(jù)schema自動生成代碼;2.接著定義GraphQLschema,描述API的結構和查詢入口,如定義Post類型和查詢方法;3.然后初始化項目并生成基礎代碼,實現(xiàn)resolver中的業(yè)務邏輯;4.最后將GraphQLhandler接入HTTPserver,通過內置Playground測試API。注意事項包括字段命名規(guī)范、錯誤處理、性能優(yōu)化及安全設置等,確保項目可維護性

安裝Go的關鍵在于選擇正確版本、配置環(huán)境變量并驗證安裝。1.前往官網(wǎng)下載對應系統(tǒng)的安裝包,Windows使用.msi文件,macOS使用.pkg文件,Linux使用.tar.gz文件并解壓至/usr/local目錄;2.配置環(huán)境變量,在Linux/macOS中編輯~/.bashrc或~/.zshrc添加PATH和GOPATH,Windows則在系統(tǒng)屬性中設置PATH為Go的安裝路徑;3.使用goversion命令驗證安裝,并運行測試程序hello.go確認編譯執(zhí)行正常。整個流程中PATH設置和環(huán)

sync.WaitGroup用于等待一組goroutine完成任務,其核心是通過Add、Done、Wait三個方法協(xié)同工作。1.Add(n)設置需等待的goroutine數(shù)量;2.Done()在每個goroutine結束時調用,計數(shù)減一;3.Wait()阻塞主協(xié)程直到所有任務完成。使用時需注意:Add應在goroutine外調用、避免重復Wait、務必確保Done被調用,推薦配合defer使用。常見于并發(fā)抓取網(wǎng)頁、批量數(shù)據(jù)處理等場景,能有效控制并發(fā)流程。

使用Go的embed包可以方便地將靜態(tài)資源嵌入二進制,適合Web服務打包HTML、CSS、圖片等文件。1.聲明嵌入資源需在變量前加//go:embed注釋,如嵌入單個文件hello.txt;2.可嵌入整個目錄如static/*,通過embed.FS實現(xiàn)多文件打包;3.開發(fā)時建議通過buildtag或環(huán)境變量切換磁盤加載模式以提高效率;4.注意路徑正確性、文件大小限制及嵌入資源的只讀特性。合理使用embed能簡化部署并優(yōu)化項目結構。

音視頻處理的核心在于理解基本流程與優(yōu)化方法。1.其基本流程包括采集、編碼、傳輸、解碼和播放,每個環(huán)節(jié)均有技術難點;2.常見問題如音畫不同步、卡頓延遲、聲音噪音、畫面模糊等,可通過同步調整、編碼優(yōu)化、降噪模塊、參數(shù)調節(jié)等方式解決;3.推薦使用FFmpeg、OpenCV、WebRTC、GStreamer等工具實現(xiàn)功能;4.性能管理方面應注重硬件加速、合理設置分辨率幀率、控制并發(fā)及內存泄漏問題。掌握這些關鍵點有助于提升開發(fā)效率和用戶體驗。

搭建一個用Go編寫的Web服務器并不難,核心在于利用net/http包實現(xiàn)基礎服務。1.使用net/http啟動最簡服務器:通過幾行代碼注冊處理函數(shù)并監(jiān)聽端口;2.路由管理:使用ServeMux組織多個接口路徑,便于結構化管理;3.常見做法:按功能模塊分組路由,并可用第三方庫支持復雜匹配;4.靜態(tài)文件服務:通過http.FileServer提供HTML、CSS和JS文件;5.性能與安全:啟用HTTPS、限制請求體大小、設置超時時間以提升安全性與性能。掌握這些要點后,擴展功能將更加容易。

select加default的作用是讓select在沒有其他分支就緒時執(zhí)行默認行為,避免程序阻塞。1.非阻塞地從channel接收數(shù)據(jù)時,若channel為空,會直接進入default分支;2.結合time.After或ticker定時嘗試發(fā)送數(shù)據(jù),若channel滿則不阻塞而跳過;3.防止死鎖,在不確定channel是否被關閉時避免程序卡??;使用時需注意default分支會立即執(zhí)行,不能濫用,且default與case互斥,不會同時執(zhí)行。
