基础环境搭建
安装Go语言环境(版本1.20+),配置GOPATH与GOROOT。推荐使用Go Modules管理依赖:
go mod init your_project_namehttps://www.zhihu.com/zvideo/1993915883156956317/
https://www.zhihu.com/zvideo/1993915883156956317
https://www.zhihu.com/zvideo/1993915881256935985/
https://www.zhihu.com/zvideo/1993915881256935985
https://www.zhihu.com/zvideo/1993915876177634322/
https://www.zhihu.com/zvideo/1993915876177634322
https://www.zhihu.com/zvideo/1993915873099015560/
https://www.zhihu.com/zvideo/1993915873099015560
https://www.zhihu.com/zvideo/1993915867969376574/
https://www.zhihu.com/zvideo/1993915867969376574
https://www.zhihu.com/zvideo/1993915865301799892/
https://www.zhihu.com/zvideo/1993915865301799892
https://www.zhihu.com/zvideo/1993915857672352769/
https://www.zhihu.com/zvideo/1993915857672352769
https://www.zhihu.com/zvideo/1993915856653133036/
https://www.zhihu.com/zvideo/1993915856653133036
https://www.zhihu.com/zvideo/1993915849761920389/
https://www.zhihu.com/zvideo/1993915849761920389
https://www.zhihu.com/zvideo/1993915845928317914/
https://www.zhihu.com/zvideo/1993915845928317914
https://www.zhihu.com/zvideo/1993915831676055629/
https://www.zhihu.com/zvideo/1993915831676055629
https://www.zhihu.com/zvideo/1993915825330074345/
https://www.zhihu.com/zvideo/1993915825330074345
HTTP服务器实现
基于net/http包创建基础HTTP服务,支持路由与中间件:
package main import ( "fmt" "net/http" ) func homeHandler(w http.ResponseWriter, r *http.Request) { fmt.Fprintf(w, "Welcome to Go Backend!") } func main() { http.HandleFunc("/", homeHandler) http.ListenAndServe(":8080", nil) }RESTful API设计
使用gorilla/mux实现资源路由与JSON响应:
package main import ( "encoding/json" "github.com/gorilla/mux" "net/http" ) type User struct { ID string `json:"id"` Name string `json:"name"` } var users = []User{{ID: "1", Name: "Alice"}} func GetUsers(w http.ResponseWriter, r *http.Request) { w.Header().Set("Content-Type", "application/json") json.NewEncoder(w).Encode(users) } func main() { r := mux.NewRouter() r.HandleFunc("/users", GetUsers).Methods("GET") http.ListenAndServe(":8080", r) }数据库集成
通过gorm连接PostgreSQL并实现CRUD操作:
package main import ( "gorm.io/driver/postgres" "gorm.io/gorm" ) type Product struct { gorm.Model Code string Price uint } func main() { dsn := "host=localhost user=gorm password=gorm dbname=gorm port=9920 sslmode=disable" db, err := gorm.Open(postgres.Open(dsn), &gorm.Config{}) if err != nil { panic("failed to connect database") } db.AutoMigrate(&Product{}) db.Create(&Product{Code: "D42", Price: 100}) }认证与授权
使用jwt-go实现JWT令牌验证:
package main import ( "github.com/dgrijalva/jwt-go" "time" ) func GenerateJWT(userID string) (string, error) { token := jwt.NewWithClaims(jwt.SigningMethodHS256, jwt.MapClaims{ "user_id": userID, "exp": time.Now().Add(time.Hour * 24).Unix(), }) return token.SignedString([]byte("your_secret_key")) }单元测试
针对HTTP处理器编写测试用例:
package main import ( "net/http" "net/http/httptest" "testing" ) func TestHomeHandler(t *testing.T) { req := httptest.NewRequest("GET", "/", nil) w := httptest.NewRecorder() homeHandler(w, req) if w.Code != http.StatusOK { t.Errorf("Expected status 200, got %d", w.Code) } }部署与优化
使用Docker容器化部署,配置多阶段构建:
FROM golang:1.20 as builder WORKDIR /app COPY go.mod go.sum ./ RUN go mod download COPY . . RUN CGO_ENABLED=0 GOOS=linux go build -o backend FROM alpine:latest COPY --from=builder /app/backend . EXPOSE 8080 CMD ["./backend"]