个人技术分享

在Go语言中编写一个简单的评论接口,我们可以使用标准库net/http来创建HTTP服务器,并假设我们将评论数据存储在一个内存中的映射(map)里作为示例。这个例子将展示如何创建两个基本的HTTP端点:一个用于获取所有评论,另一个用于添加新的评论。

请注意,在生产环境中,你可能需要将数据持久化存储在数据库中,并且实现更全面的错误处理、验证、安全措施(如防止SQL注入、XSS攻击)等。

以下是示例代码:

package main

import (
	"encoding/json"
	"fmt"
	"log"
	"net/http"
	"strconv"
)

// Comment 评论结构体
type Comment struct {
	ID     int    `json:"id"`
	User   string `json:"user"`
	Text   string `json:"text"`
}

var comments = make(map[int]Comment) // 存储评论的映射,ID作为键
var commentIDCounter = 1           // 用于生成新的评论ID

// getCommentsHandler 获取所有评论的处理器
func getCommentsHandler(w http.ResponseWriter, r *http.Request) {
	w.Header().Set("Content-Type", "application/json")
	json.NewEncoder(w).Encode(comments)
}

// addCommentHandler 添加评论的处理器
func addCommentHandler(w http.ResponseWriter, r *http.Request) {
	var comment Comment
	err := json.NewDecoder(r.Body).Decode(&comment)
	if err != nil {
		http.Error(w, err.Error(), http.StatusBadRequest)
		return
	}
	comment.ID = commentIDCounter
	commentIDCounter++
	comments[comment.ID] = comment
	w.WriteHeader(http.StatusCreated)
	json.NewEncoder(w).Encode(comment)
}

func main() {
	http.HandleFunc("/comments", func(w http.ResponseWriter, r *http.Request) {
		switch r.Method {
		case http.MethodGet:
			getCommentsHandler(w, r)
		case http.MethodPost:
			addCommentHandler(w, r)
		default:
			http.Error(w, "Method Not Allowed", http.StatusMethodNotAllowed)
		}
	})

	fmt.Println("Server is running on http://localhost:8080/comments")
	log.Fatal(http.ListenAndServe(":8080", nil))
}

这段代码定义了一个简单的HTTP服务器,监听8080端口。当你访问http://localhost:8080/comments时:

  • 使用GET方法会返回当前所有评论的JSON列表。
  • 使用POST方法并提供JSON格式的评论数据(包含"user"和"text"字段)会在服务器端添加一条新评论,并返回刚创建的评论信息,同时分配一个新的ID。

请记住,这只是一个教学示例,真实应用中需要考虑数据持久化、安全性、并发访问控制等问题。

要启动上述Go语言编写的评论接口服务,你需要确保你的开发环境中已经安装了Go(Golang)并且设置好了GOPATH等环境变量。以下是启动服务的步骤:

  1. 保存代码: 首先,将上述示例代码保存到一个.go文件中,例如命名为main.go

  2. 打开终端或命令行: 打开一个命令行界面(如Terminal、CMD、PowerShell等)。

  3. 导航到代码目录: 使用cd命令切换到包含main.go文件的目录。

  4. 编译和运行: 在命令行中输入以下命令来编译并运行你的Go程序:

    go run main.go
    

    运行成功后,你会看到输出信息 "Server is running on http://localhost:8080/comments",表明服务器已经在本地的8080端口启动。

  5. 测试接口:

    • 打开浏览器或使用Postman、curl等工具,访问 http://localhost:8080/comments 来获取所有评论(由于是新启动的服务,目前应该是空的)。
    • 要添加评论,可以使用Postman或类似的API测试工具,选择POST方法,设置URL为 http://localhost:8080/comments,并在Body部分选择rawJSON格式,输入如下的JSON数据后发送请求:
      {
        "user": "张三",
        "text": "这是一条测试评论"
      }
      
      成功后,再次访问 http://localhost:8080/comments 应能看到刚刚添加的评论。

记得在实际开发和测试过程中,根据需要调整代码和处理可能出现的错误或异常情况。