博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用Golang搭建web服务
阅读量:4677 次
发布时间:2019-06-09

本文共 2843 字,大约阅读时间需要 9 分钟。

如何用golang搭建一个web服务呢?菜鸟官网的go web编程教程已经介绍了web服务器的工作原理,这里就不赘述了。

我们先看个例子:http.go

package mainimport (    "fmt"    "io"    "log"    "net/http")func main() {    http.HandleFunc("/test", doRequest)      //   设置访问路由    err := http.ListenAndServe(":8000", nil) //设置监听的端口    if err != nil {        log.Fatal("ListenAndServe: ", err)    }}func doRequest(w http.ResponseWriter, r *http.Request) {    r.ParseForm()       //解析url传递的参数,对于POST则解析响应包的主体(request body)    //fmt.Println(r.Form) //这些信息是输出到服务器端的打印信息    //fmt.Println("path", r.URL.Path)    //fmt.Println("scheme", r.URL.Scheme)    //for k, v := range r.Form {    //    fmt.Println("key:", k)    //    fmt.Println("value:", strings.Join(v, ""))    //}    fmt.Fprintf(w, "service start...") //这个写入到w的是输出到客户端的 也可以用下面的 io.WriteString对象    //注意:如果没有调用ParseForm方法,下面无法获取表单的数据    //query := r.URL.Query()    var uid string // 初始化定义变量    if r.Method == "GET" {        uid = r.FormValue("uid")    } else if r.Method == "POST" {        uid = r.PostFormValue("uid")    }    io.WriteString(w, "uid = "+uid)}

go run http.go命令运行程序。

之后在浏览器中输入地址: http://127.0.0.1:8000/test?uid=10086,看下结果。

  在main函数中,我们从net/http包中调用了一个http.HandleFucn函数来注册一个处理函数

这个函数接受两个参数。第一个是字符串,这个就是进行路由匹配,我这里是/test路由。第二个参数是一个func (ResponseWriter, Request)的签名。

我们的doRequest函数就是这样的签名。下一行中的http.ListenAndServe(":8000", nil),表示监听localhost的8000端口,暂时忽略掉nil。

   在doRequest函数中我们有两个参数,一个是http.ResponseWriter类型的。它类似响应流,实际上是一个接口类型。

第二个是http.Request类型,类似于HTTP 请求。我们不必使用所有的参数,如果只是简单的输出,那么我们只需要使用http.ResponseWriter,io.WriteString,将会把输出流写入数据。

我们再稍微改下,大家请注意修改的部分(这里我们只调整 main函数部分代码)

func main() {    mux := http.NewServeMux()    mux.HandleFunc("/test", doRequest)    err :=  http.ListenAndServe(":8000", mux) //设置监听的端口    if err != nil {        log.Fatal("ListenAndServe: ", err)    }}

这个例子中,我们不再在函数http.ListenAndServe使用nil了。这个例子跟上面的例子其实是一样的。使用http注册hanlder 函数模式就是用的ServeMux。

我们再调整下看下更复杂的例子:

package mainimport (    "fmt"    "io"    "log"    "net/http")var mux map[string]func(http.ResponseWriter, *http.Request)func main() {    server := http.Server{        Addr:    ":8000",        Handler: &doHandler{},    }    mux = make(map[string]func(http.ResponseWriter, *http.Request))    mux["/test"] = doRequest    err := server.ListenAndServe()    if err != nil {        log.Fatal("ListenAndServe: ", err)    }}type doHandler struct{}func (*doHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {    if res, ok := mux[r.URL.String()]; ok {        res(w, r)        return    }    io.WriteString(w, "url params: "+r.URL.String())}func doRequest(w http.ResponseWriter, r *http.Request) {    r.ParseForm()                      //解析url传递的参数,对于POST则解析响应包的主体(request body)    fmt.Fprintf(w, "service start...") //这个写入到w的是输出到客户端的 也可以用下面的 io.WriteString对象}

这个例子我们没有定义ServeMux,而是使用了http.Server。都是用net/http包运行了服务器。

转载于:https://www.cnblogs.com/phpper/p/10408206.html

你可能感兴趣的文章
egret 取消自动连接github
查看>>
libusb开发指南
查看>>
SAS基础 -- 逻辑库不存在问题解决
查看>>
Servlet监听器统计在线人数
查看>>
第2章 数字之魅——寻找发帖“水王”
查看>>
spring5.0新特性
查看>>
ivy 入门
查看>>
eclipse jsp html 格式化 format
查看>>
关于手机端IOS系统微信中虚拟键盘遮挡input输入框问题的解决方案 草稿
查看>>
css3背景、边框、和补丁相关属性 (二)
查看>>
Python--小功能应用
查看>>
codves:最优布线问题
查看>>
别做操之过急的”无效将军”,做实实在在的”日拱一卒”
查看>>
CLS(公共语言规范)的CLSCompliant(跨语言调用)
查看>>
[YTU]_2384 ( 矩形类中运算符重载【C++】)
查看>>
分层抽样(Stratified sampling)
查看>>
从 dig(nslookup) bind —— windows 下的域名解析服务器信息的查看
查看>>
线性滤波器(linear filter)与非线性滤波器(non-linear filter)
查看>>
DTFT、DFT、FFT
查看>>
剪枝法观点下的旅行商问题(TSP)
查看>>