第一个go网站

第一个go网站

官网下载go的安装包

选择安装路径

由于默认的go路径,在/usr/local下, 所以用如下命令,解压创建/usr/local/go

tar -C /usr/local -xzf go1.5.1.linux-amd64.tar.gz

添加PATH环境变量

vi /etc/profile

然后加入下面这行:

export PATH=$PATH:/usr/local/go/bin

建立Go的工作空间(workspace,也就是GOPATH环境变量指向的目录)

GO代码必须在工作空间内。工作空间是一个目录,其中包含三个子目录: src ---- 里面每一个子目录,就是一个包。包内是Go的源码文件 pkg ---- 编译后生成的,包的目标文件 bin ---- 生成的可执行文件。 这里,我们在/home目录下, 建立一个名为gopath(可以不是gopath, 任意名字都可以)的文件夹, 然后再建立三个子文件夹(子文件夹名必须为src、pkg、bin)。如下图:

file

设置GOPATH环境变量

vi /etc/profile 然后加入下面这行: export GOPATH=/home/gopath 保存后,执行以下命令,使环境变量立即生效: source /etc/profile

安装gin

设置代理

go env -w GO111MODULE=on
   go env -w GOPROXY=https://goproxy.io,direct

运行: go get -u github.com/gin-gonic/gin

运行项目

src 中创建hello.go

package main

import (
    "net/http"

    "github.com/gin-gonic/gin"
)

func main() {
    // 1.创建路由
   r := gin.Default()
   // 2.绑定路由规则,执行的函数
   // gin.Context,封装了request和response
   r.GET("/", func(c *gin.Context) {
      c.String(http.StatusOK, "hello World!")
   })
   // 3.监听端口,默认在8080
   // Run("里面不指定端口号默认为8080") 
   r.Run(":8000")
}

执行:go run hello.go file 访问:http://127.0.0.1:8000 成功 file 若遇到报错

main.go:3:8: cannot find module providing package github.com/gin-gonic/gin: working directory is not part of a module

可执行:

go mod init gin
go mod edit -require github.com/gin-gonic/gin@latest

在重新执行即可

七、域名访问: 设置反向代理 file 重新执行即可 file

八、参数获取

id := c.Query("id") //查询请求URL后面的参数
page := c.DefaultQuery("page", "0") //查询请求URL后面的参数,如果没有填写默认值
name := c.PostForm("name") //从表单中查询参数

/////////////////////////////////
//POST和PUT主体参数优先于URL查询字符串值。
name := c.Request.FormValue("name") 

//返回POST并放置body参数,URL查询参数被忽略
name := c.Request.PostFormValue("name")

//从表单中查询参数,如果没有填写默认值  
message := c.DefaultPostForm("message", "aa")

假如gin定义的路由路径为:

router.POST("/post/:uuid", func(c *gin.Context){
    ...
}

则获取uuid的值方法为

uuid := c.Param("uuid") //取得URL中参数 其他:

s, _ := c.Get("current_manager") //从用户上下文读取值      

var u User

//从http.Request中读取值到User结构体中,手动确定绑定类型binding.Form
err1 := c.BindWith(&u, binding.Form) 

//从http.Request中读取值到User结构体中,根据请求方法类型和请求内容格式类型自动确定绑定类型
err2 := c.Bind(&u)

//从session中读取值
//用户上下文和session生命周期不同,每一次请求会生成一个对应的上下文,一次http请求结束,该次请求的上下文结束,一般来说session(会话)会留存一段时间
//session(会话)中一般保存用户登录状态等信息,context(上下文)主要用于在一次http请求中,在中间件(流)中进行信息传递
user := sessions.Default(c).get("user")
猜你喜欢