35.用Gin完成一个简易待办事项管理后端代码(一)Gin入门

代码地址:https://gitee.com/lymgoforIT/golang-trick/tree/master/24-gin-learning

一、项目功能

  • 用户可以注册、登录和登出
  • 用户登录后可以创建、修改、查看和删除待办事项
  • 用户对待办事项的修改和查看需要进行身份验证

二、涉及知识点

  • gin:golang编写的高性能web框架
  • gorm:go语言的一款orm库,能够帮助研发方便的操作数据库
  • jwt:基于JSON的开放式标准,通常用于用户的身份验证和授权
  • gin中间件代码的编写与使用
  • golang代码的模块化
  • golang的路由分组
  • golang的设计模式:工厂模式、策略模式、装饰器模式、适配器模式等

三、循序渐进完善代码

  • gin框架简单入门
  • gin创建restful api
  • 引入gorm一级路由分组和中间件入门
  • golang二级路由分组
  • 简单的模块化
  • 添加身份验证功能
  • 代码重构增加一些相对高级的模块化
  • 引入依赖注入设计模式

四、gin框架简单入门

使用go get -u github.com/gin-gonic/gin 下载到gin包

package main

import (
	"github.com/gin-gonic/gin"
	"net/http"
)

func main() {
	r := gin.Default()

	r.GET("/ping", func(c *gin.Context) {
		c.JSON(http.StatusOK, gin.H{
			"message": "pong",
		})
	})

	r.Run(":8080")
}

启动后,浏览器访问
在这里插入图片描述

五 用gin创建restful api

进行简单的增删改查(CRUD)

package main

import (
	"github.com/gin-gonic/gin"
	"net/http"
)

func main() {
	r := gin.Default()

	r.GET("/ping", func(c *gin.Context) {
		c.JSON(http.StatusOK, gin.H{
			"message": "pong",
		})
	})

	// Get /user
	r.GET("/user", func(c *gin.Context) {
		c.JSON(http.StatusOK, gin.H{"data": "get all users"})
	})

	// Post /users
	r.POST("/users", func(c *gin.Context) {
		c.JSON(http.StatusOK, gin.H{"data": "Create user"})
	})

	// Put /users
	r.PUT("/users/:id", func(c *gin.Context) {
		id := c.Param("id")
		c.JSON(http.StatusOK, gin.H{"data": "Update user " + id})
	})

	// Delete /users
	r.DELETE("/users/:id", func(c *gin.Context) {
		id := c.Param("id")
		c.JSON(http.StatusOK, gin.H{"data": "Delete user " + id})
	})
	r.Run(":8080")
}

由于涉及到了Post,Put,Delete等请求Method,所以用PostMan测试时比较方便的
Get
在这里插入图片描述
Post
在这里插入图片描述
Put
在这里插入图片描述
Delete
在这里插入图片描述

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值