赞
踩
这是操作完毕后的完整文件结构树状图,接下来将带大家一步一步完成它
特别注意!入口文件 main.go
和 go.mod
在同一目录下!这一点必须要保证!
└─gindemo.com
│ go.mod
│ go.sum
│ main.go
│
├─.idea
│ .gitignore
│ gindemo.com.iml
│ modules.xml
│ workspace.xml
│
└─src
└─Chapter1
C1.go
该项目创建使用goland2020
任选一个文件夹创建目录,注意项目的名字最好依照这个格式: xxx.xxx
点号的后缀随便写,只要保证上面这样的格式就好了
我们新建一个项目 gindemo.com
此时打开 goland 的设置页面,设置好 GOROOT
GOPATH
设置过程请参考 gin 相关文章!
新建文件 main.go (和 go.mod 同目录)
// 入口点入口点!!!必须要main!!!别忘了求求你了
package main
import (
"github.com/gin-gonic/gin"
"net/http"
)
func main() {
app := gin.Default()
app.GET("/shit", func(context *gin.Context) {
context.JSON(http.StatusOK, gin.H{
"error": "shit",
})
})
app.Run(":10086")
}
这是一个最简单的 gin 后端,因为我们之前配置好了 GOPATH
,所以这里 goland 会为我们自动导包,故不会出现飘红现象!
但实际上 go.mod
内部依然没有配置依赖,我们需要在项目目录下打开命令行,输入 go mod tidy
为我们自动处理好依赖关系;
此时配置好运行参数直接运行 main 方法就可以开启我们的后端服务了
新建文件(大小写不是必要的) src/Chapter1/C1.go
代码不是重点,我们要做的是在 main.go
里面使用该文件的 BindDemo
方法
方法名需要大写开头!
package Chapter1
import (
"fmt"
"github.com/gin-gonic/gin"
"net/http"
)
...
func BindDemo(c *gin.Context) {
...
}
来到我们的 go.mod
来分析一下最关键的三行内容
module gindemo.com
go 1.19
require github.com/gin-gonic/gin v1.8.2
此时记下我们 go.mod
管理的包名叫做: gindemo.com
(其实就是咱们的项目名)
打开 main.go 修改代码为
package main
import (
// 这表示取别名,用小写字母c代表后面导入的内容
c "gindemo.com/src/Chapter1"
"github.com/gin-gonic/gin"
"net/http"
)
func main() {
app := gin.Default()
app.GET("/shit", func(context *gin.Context) {
context.JSON(http.StatusOK, gin.H{
"error": "shit",
})
})
// 在这里调用 C1.go 文件内的方法
app.GET("/c1",c.BindDemo)
app.Run(":10086")
}
我们来分析一下 import 里面这行代码的含义:c "gindemo.com/src/Chapter1"
此时你发现 goland 直接飘红,但这不是我们的问题!直接运行是可以跑起来的!
由于我们直接导入 Chapter1 整个包,所以按照我们定的别名 c ,直接调用方法即可使用!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。