」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何使用 GopherLight 像專業人士一樣在 Go 中編寫 API

如何使用 GopherLight 像專業人士一樣在 Go 中編寫 API

發佈於2024-11-18
瀏覽:928

How to Write APIs Like a Pro in Go with GopherLight

文档

GopherLight

嘿伙计们,首先我要感谢您选择使用我们的项目。尽管他很小,但我们却以极大的热情做到了!要开始使用它,您首先必须安装 go,我们假设您已经安装了它。然后安装框架的主要模块,分别是req和router

go get github.com/BrunoCiccarino/GopherLight/router
go get github.com/BrunoCiccarino/GopherLight/req

已经下载了?唷!现在我们可以制作我们的第一个hello world。

package main

import (
    "fmt"
    "github.com/BrunoCiccarino/GopherLight/router"
    "github.com/BrunoCiccarino/GopherLight/req"
)


func main() {
    app := router.NewApp()

    // Define a route that responds to a GET request at "/hello".
    app.Get("/hello", func(r *req.Request, w *req.Response) {
        w.Send("Hello, World!")
    })

    fmt.Println("Server listening on port 3333")
    app.Listen(":3333")
}

很简单,对吧?我们还可以利用 GopherLight 做更多事情。继续阅读 HTTP 方法以及我们的请求和响应工具的完整细分。

支持的 HTTP 方法
以下是您可以与 router.App 一起使用的 HTTP 方法的列表。其中每一个都允许您设置路由来处理不同类型的请求。让我们开始吧!

得到

  • 用法:app.Get(路径,处理程序)

检索数据而不修改任何内容。
示例:获取项目列表或读取用户详细信息。

邮政

  • 用法:app.Post(路径,处理程序)

发送数据以创建新资源。
示例:提交表单或向列表添加新项目。

用法:app.Put(path, handler)

更新或替换资源。这是一个“覆盖”操作。
示例:更新完整的用户配置文件。

删除

用法:app.Delete(path, handler)

删除资源。
示例:删除用户或删除帖子。

修补

用法:app.Patch(path, handler)

部分更新资源而不替换所有内容。
示例:仅更新用户个人资料中的电子邮件。

选项

用法:app.Options(path, handler)

返回 URL 允许的 HTTP 方法,主要用于 CORS 预检请求。

用法:app.Head(path, handler)

与 GET 类似,但没有响应正文。用它来检查资源是否存在。

连接和追踪

用法:app.Connect(path, handler), app.Trace(path, handler)

高级方法:CONNECT建立隧道(用于SSL),TRACE用于调试,回显请求。

使用 req.Request 和 req.Response

现在您已经了解了路由,让我们来谈谈请求和响应对象,它们是处理传入请求和发送响应的首选助手。

要求

每个请求处理程序都会获取一个请求对象,其中加载了传入请求的信息。您可以使用它执行以下操作:

  • 查询参数:通过.QueryParam("key").
  • 获取查询参数
  • 标头:使用 .Header("key").
  • 访问标头
  • Body as String:使用 .BodyAsString().
  • 获取请求正文

例子:

app.Get("/greet", func(r *req.Request, w *req.Response) {
    name := r.QueryParam("name")
    if name == "" {
        name = "stranger"
    }
    w.Send("Hello, "   name   "!")
})

回复

Response 对象帮助您将回复发送回客户端。您可以执行以下操作:

  • 发送文本:.Send(数据字符串)写回纯文本。
  • 设置状态:.Status(code) 设置 HTTP 状态。
  • 发送 JSON:.JSON(data) 将 Go 对象序列化为 JSON 并发送。
  • 处理错误:.JSONError(message) 发送 JSON 格式的错误响应。

例子:

app.Get("/user", func(r *req.Request, w *req.Response) {
    user := map[string]string{"name": "Gopher", "language": "Go"}
    w.JSON(user)
})

中间件

我们已经准备好了一批中间件,供您为您的 Go Web 应用程序添加一些重要的功能。这些中间件中的每一个都有自己的魔力——安全性、日志记录、超时等等!让我们一一分解。 ?

身份验证中间件 (JWT)

我们的 AuthMiddleware 使用 JSON Web 令牌 (JWT) 帮助保护您的路由。它很灵活,允许您自定义密钥、错误处理和令牌提取方法。

设置
首先,使用 JWTConfig 配置 JWT 设置:

  • SecretKey:签署 JWT 的密钥。
  • SigningMethod:JWT 签名算法。
  • ErrorHandler:用于处理身份验证错误的自定义错误处理程序(可选)。
  • TokenExtractor:从请求标头中提取令牌(可选)。

例子

import (
    "github.com/BrunoCiccarino/GopherLight/middleware"
)

config := middleware.JWTConfig{
    SecretKey: []byte("your_secret_key"),
}
app.Use(middleware.NewAuthMiddleware(config))

CORS中间件

需要允许跨域请求?没问题!我们的 COSM 中间件配置跨源资源共享 (CORS) 设置,以使您的 API 可从其他域访问。

配置选项

  • AllowOrigin:设置为“*”以允许任何来源或指定域(例如“http://example.com”)。
  • AllowMethods:允许哪些 HTTP 方法?常见的选择包括“GET”、“POST”等
  • AllowHeaders:指定客户端可以使用哪些标头。
  • AllowCredentials:如果您希望包含 cookie 或 HTTP 身份验证,请设置为 true。
  • ExposeHeaders:让客户端从响应中读取特定标头。
  • MaxAge:预检请求的缓存时间(以秒为单位)。

例子

corsOptions := middleware.CORSOptions{
    AllowOrigin: "*",
    AllowMethods: []string{"GET", "POST"},
}
app.Use(middleware.CORSMiddleware(corsOptions))

CSRF中间件

我们的 CSRFMiddleware 通过验证随每个请求发送的 CSRF 令牌来防止跨站点请求伪造。使用GenerateCSRFToken() 创建安全令牌,然后使用您自己的isValidToken 函数对其进行验证。

例子

app.Use(middleware.CSRFMiddleware(func(token string) bool {
    return token == "your_valid_token"
}))

并且不要忘记使用以下方式生成令牌:

csrfToken := middleware.GenerateCSRFToken()

日志中间件

想要跟踪服务器上发生的情况吗? LoggingMiddleware 记录每个请求,包括方法、路径和所用时间。这是了解应用程序性能和任何异常活动的好方法。

例子

app.Use(middleware.LoggingMiddleware)

每个请求都会像这样记录:

  • 开始:记录请求开始时间。
  • Completed:请求完成时记录,包括持续时间。

超时中间件

通过使用 TimeoutMiddleware 设置请求处理的时间限制来避免无休止的等待。如果请求未及时完成,该中间件将取消请求,并向客户端发送 504 Gateway Timeout 状态。

例子

import (
    "time"
    "github.com/BrunoCiccarino/GopherLight/middleware"
)

timeout := 2 * time.Second
app.Use(middleware.TimeoutMiddleware(timeout))

插件接口

插件界面超级简单但功能超级强大。它为您提供了一个方法:注册。这使您可以连接到应用程序的路由系统来添加您需要的任何路由 - 无论是新的 API 端点、Webhook 还是您可以想象的任何其他内容。

注册方法
这是插件界面的神奇部分:

type Plugin interface {
    Register(route func(method, path string, handler func(req *req.Request, res *req.Response)))
}

Register 方法接受一个路由函数,允许您通过指定在插件中定义新路由:

  • method:HTTP 方法(例如“GET”、“POST”等)
  • path:路由路径(例如“/my-plugin-route”)
  • handler:命中路由时执行的函数。该函数接收:
    • req:可以访问查询参数、标头和正文的请求对象。
    • res:将数据发送回客户端的响应对象。

示例插件

假设您想要创建一个插件,在 /hello-plugin 处添加一个简单的端点来欢迎用户。该插件如下所示:

package main

import (
    "github.com/BrunoCiccarino/GopherLight/plugins"
    "github.com/BrunoCiccarino/GopherLight/req"
)

type HelloPlugin struct{}

// Register adds a new route for the HelloPlugin.
func (p *HelloPlugin) Register(route func(method, path string, handler func(req *req.Request, res *req.Response))) {
    route("GET", "/hello-plugin", func(req *req.Request, res *req.Response) {
        res.Send("Hello from the HelloPlugin!")
    })
}

将插件添加到您的应用程序

要加载插件,只需创建一个实例并在主应用程序设置中调用 Register:

package main

import (
    "github.com/BrunoCiccarino/GopherLight/router"
)

func main() {
    app := router.NewApp()
    helloPlugin := &HelloPlugin{}
    helloPlugin.Register(app.Route)

    app.Listen(":3333")
}

定制您的插件

每个插件可以根据需要添加任意数量的路由。只需在 Register 函数中多次调用路由即可定义其他端点。使用不同的 HTTP 方法、路径和处理程序来根据需要塑造插件的功能。

版本聲明 本文轉載於:https://dev.to/gopherlight/how-to-write-apis-like-a-pro-in-go-with-gopherlight-3b97?1如有侵犯,請洽[email protected]刪除
最新教學 更多>
  • 儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    解決PHP 中的POST 請求故障在提供的程式碼片段中:action=''而不是:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"檢查$_POST數組:表單提交後使用var_dump檢查$_POST 陣列的內容。...
    程式設計 發佈於2024-11-18
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-18
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1 和 $array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建...
    程式設計 發佈於2024-11-18
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-18
  • 如何從針對 Go 二進位檔案的整合測試中擷取程式碼覆蓋率?
    如何從針對 Go 二進位檔案的整合測試中擷取程式碼覆蓋率?
    從 Go 二進位檔案擷取程式碼覆蓋率執行單元測試時,擷取程式碼覆蓋率非常簡單。然而,在針對二進位檔案本身的整合測試期間收集覆蓋率指標可能具有挑戰性。有沒有辦法克服這個障礙? 整合測試覆蓋率的需求整合測試提供了比單獨的單元測試更全面的程式碼覆蓋率視圖。透過針對真實世界的輸入運行二進位文件,我們可以評估...
    程式設計 發佈於2024-11-18
  • 如何從終端機將資料庫匯入MySQL?
    如何從終端機將資料庫匯入MySQL?
    從終端導入MySQL資料庫使用終端將資料庫導入MySQL可以提供一種便捷的資料管理方式。要有效地執行此任務,請按照下列步驟操作:使用命令列,您可以存取 MySQL 提示符。這樣做的語法是:mysql -u username -p database_name輸入您的使用者名稱、密碼和目標資料庫名稱來取...
    程式設計 發佈於2024-11-18
  • 如何使用“index”函數迭代 HTML 模板中的平行數組?
    如何使用“index”函數迭代 HTML 模板中的平行數組?
    如何使用索引迭代HTML 模板中的平行數組本文解決了迭代並行數組(大小相等)的困難在HTML 模板中。具體來說,如何利用範圍區塊內的索引函數來實現此目的。 索引函數是預先定義的全域範本函數,它根據提供的索引從映射、切片或陣列中檢索項目。此函數允許在模板內的資料結構內進行複雜的導航。 在迭代並行數組的...
    程式設計 發佈於2024-11-18
  • 迭代 Python 列表時,為什麼應該避免刪除項目?
    迭代 Python 列表時,為什麼應該避免刪除項目?
    Python 列表:迭代期間刪除項目的陷阱迭代 Python 列表,同時刪除項目可能會導致意外行為。一個值得注意的例子如下:letters = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l'] for i in letters:...
    程式設計 發佈於2024-11-18
  • 如何消除 CSS 中的雙邊框:輪廓與負邊距?
    如何消除 CSS 中的雙邊框:輪廓與負邊距?
    防止 CSS 中的雙邊框許多 Web 開發人員在將元素與邊框並排設定樣式時遇到一個常見問題。由於邊框的性質,每個元素都有自己的邊框,因此元素相交處可能會出現雙邊框。這可能不雅觀並且會幹擾所需的設計。 要解決此問題,有兩種常見的解決方案:使用輪廓而不是邊框,或應用負邊距。 使用輪廓輪廓與邊框類似,但僅...
    程式設計 發佈於2024-11-18
  • 如何僅使用 CSS 將圖片嵌入 Div 元素內?
    如何僅使用 CSS 將圖片嵌入 Div 元素內?
    使用CSS 將影像整合到Div 中:有效的解決方案在Web 開發中,通常需要將影像放置在div 元素中。雖然使用背景圖像是一種常見的方法,但它限制了 div 符合圖像大小的能力。這就提出了一個問題:我們要如何使用 CSS 來建立與 HTML 結構 等效的內容? 為了實現這一點,我們利用內容屬性將圖...
    程式設計 發佈於2024-11-18
  • 如何傳遞可變數量的參數給 JavaScript 函數?
    如何傳遞可變數量的參數給 JavaScript 函數?
    向JavaScript 函數傳遞可變數量的參數JavaScript 在向函數傳遞參數方面提供了靈活性,包括從數組發送可變數量的參數的能力。 透過參數實作變數 Arity與 Python 一樣,JavaScript 有一個特殊的參數對象,它表示傳遞給函數的所有參數。該物件包含每個參數作為可索引屬性。例...
    程式設計 發佈於2024-11-18
  • 為什麼我無法使用擴充內容腳本將 CSS 注入網頁?
    為什麼我無法使用擴充內容腳本將 CSS 注入網頁?
    擴展內容腳本中的CSS 注入問題儘管在清單中定義了CSS 注入,您的CSS 文件在網頁中仍然不存在。以下是可能的原因和解決方案:原因: CSS 規則衝突樣式表已註入,但由於其他樣式覆蓋其規則而未應用。 解決方案:增加CSS特異性: 為您的 CSS 規則添加更具體的選擇器。 使用 "!im...
    程式設計 發佈於2024-11-18
  • 釋放你的 Python 能力:一個對獨特字元進行排序的項目
    釋放你的 Python 能力:一個對獨特字元進行排序的項目
    您準備好踏上迷人的 Python 程式設計之旅了嗎? LabEx.io「專案:刪除重複項」課程就是您的最佳選擇,您將在其中深入了解資料清理和預處理的世界。這種基於專案的學習體驗將使您具備從給定字串中刪除重複字元並按升序輸出處理後的字串的技能- 對於任何有抱負的Python 開發人員來說,這都是一項寶...
    程式設計 發佈於2024-11-18
  • 揭開謎底:如何解碼 java.lang.reflect.InvocatTargetException 之謎?
    揭開謎底:如何解碼 java.lang.reflect.InvocatTargetException 之謎?
    揭開java.lang.reflect.InitationTargetException 之謎在錯綜複雜的Java 程式設計世界中,人們可能會遇到以下令人困惑的問題: java.lang.reflect.InitationTargetException。這種異常在利用反射時經常遇到,可能會讓開發人員...
    程式設計 發佈於2024-11-18
  • 什麼是互斥鎖以及它在多執行緒環境中如何運作?
    什麼是互斥鎖以及它在多執行緒環境中如何運作?
    互斥體範例和說明互斥體或互斥物件提供了一種在多執行緒環境中控制對共享資源的訪問的機制。理解它們的操作可能具有挑戰性,因為它們的語法乍一看可能違反直覺。 互斥體語法pthread_mutex_lock(&mutex1) 的語法顯示互斥體本身正在被鎖定。然而,被鎖定的不是互斥鎖,而是受其保護的程式碼區域...
    程式設計 發佈於2024-11-18

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3