golang net/http模块

golang net/http模块

搭建网站的欢迎页面

http.HandleFunc()用于给HTTP服务注册请求处理程序;它接收两个参数,一个是要匹配pattern(通常是uri),一个是用于处理的函数。

func HandleFunc(pattern string, handler func(ResponseWriter, *Request))

func (w http.ResponseWriter, r *http.Request)接收两个参数,http.ResponseWriter,可以把响应写入其中,http.Request包含请求的所有信息,比如请求uri、请求头等。

package main

import (
    "fmt"
    "net/http"
)

// 使用golang 的net/http模块创建简易的网站
func main() {
    // HandleFunc用于注册请求处理函数
    // 接收一个匿名函数作为参数,处理请求和响应
    http.HandleFunc("/hello", func(writer http.ResponseWriter, request *http.Request) {
        fmt.Fprintf(writer, "Hello, welcome to access my website: %s. \n", request.URL.Path)
    })

    // 监听端口,把请求传递给请求处理程序
    http.ListenAndServe(":8080", nil)
}

上面的请求就搭建了一个网站的欢迎页面,在浏览器中访问http://localhost:8080/hello时,请求处理程序会把欢迎的语句打印到响应页面中。

图片.png

HTTP Server的基本能力

一个基本的http server需要以下几个功能:

  • 处理动态请求:用户浏览网站时发起的各种请求,如登录、下载图片

  • 静态资源服务:向浏览器提供静态的 JavaScript、 CSS 和图像服务,为用户创建动态体验

  • 接收连接:http server必须要监听在某一个端口上,接收所有发起请求的连接

处理动态请求

第一节中欢迎页面的示例其实就属于动态的请求,用户访问指定的uri,http server作出相应的相应。此外由于请求处理函数接收的`http.Requset`参数包含所有请求的所有信息,http server也可以处理请求中的相关参数。

例如我在第一节中的代码新注册一个整型数字加法的功能,通过`r.URL.Query().Get("param")`可以获取GET请求URL中的参数。
http.HandleFunc("/calc", func(w http.ResponseWriter, r *http.Request) {
        a := r.URL.Query().Get("a")
        b := r.URL.Query().Get("b")
        inta, err := strconv.Atoi(a)
        if err != nil {
            fmt.Fprintf(w, "param a is not a int number!\n")
            panic(err)
        }
        intb, err := strconv.Atoi(b)
        if err != nil {
            fmt.Fprintf(w, "param b is not a int number!\n")
            panic(err)
        }
        fmt.Fprintf(w, "plus two integer:\n")
        fmt.Fprintf(w, "a + b = %v \n", inta+intb)
    })
2022-08-13-13-53-01-image.png

静态资源服务

静态资源通常是html、css、js、图片等文件。它们通常存放在web服务的某一个目录,一般叫/public或/static。net/http模块内置的http.FileServer()方法可以指定FileSystem的路径作为请求目录的根路径并返回一个处理程序。http.Dir()把指定的路径封装成FileSytem对象并传入http.FileServer()

在main.go的同级目录下创建一个web文件夹,用于存放各类静态资源,在web目录下创建一个public文件夹存放html资源,目录结构如下:

-main.go
-web
-public
-index.html

注册静态资源服务的处理程序,并构造一个index.html页面:

    // 为js、css、html、图片等静态资源服务
    welcomepage := http.FileServer(http.Dir("path/web/public/"))
    http.Handle("/", welcomepage)
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>htmlAsset</title>
</head>
<body>
    <h2>welcome to the html page.</h2>
    <p>this is a static asset.</p>
</body>
</html>

重启http server后在浏览器中访问http://localhost:8080/index.html,用户即可与静态资源交互。

2022-08-13-14-51-32-image.png

当然js等静态资源同样能访问,创建一个calculator.html:

<!DOCTYPE html>
<html lang="en" xmlns="http://www.w3.org/1999/html">
<head>
    <meta charset="UTF-8">
    <title>myCalculator</title>
</head>
<style>
    .box {
        width: 400px;
        height: 100px;
        background: #00ffff;
        position: absolute;
        left: 50%;
        margin-left: -100px;
    }
</style>
<body>
<div class="box">
    <input type="text" id="inta" value=""/>
    +
    <input type="text" id="intb" value="" />
    =
    <input type="text" id="plus" value="">
    </br>
    <input type="button" name="calc-plus" value=" 计算 " onclick="calc()" >
</div>
</body>
<script type="text/javascript">
    function calc() {
        var num1 = parseInt(document.getElementById("inta").value);
        var num2 = parseInt(document.getElementById("intb").value);
        document.getElementById("plus").value = num1+num2;
    }
</script>
</html>
2022-08-13-15-24-09-image.png

接收连接

完成简易http server的最后一步就是监听端口接受所有来自互联网上的连接(请求)。当然也如前面的示例一样,通过http.ListenAndServe实现。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 210,914评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 89,935评论 2 383
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,531评论 0 345
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,309评论 1 282
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,381评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,730评论 1 289
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,882评论 3 404
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,643评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,095评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,448评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,566评论 1 339
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,253评论 4 328
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,829评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,715评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,945评论 1 264
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,248评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,440评论 2 348

推荐阅读更多精彩内容

  • http http/cgi http/cookiejar http/fcgi http/httptest http...
    DevilRoshan阅读 1,122评论 0 0
  • 输入与输出-fmt包 时间与日期-time包 命令行参数解析-flag包 日志-log包 IO操作-os包 IO操...
    思考的山羊阅读 6,192评论 0 5
  • Hello World 开始使用Go编写Web服务器的典型方法是使用标准库中的net/http模块。 如下代码是最...
    asdzxc阅读 1,610评论 0 0
  • Golang作为一门新的编程语言,它借鉴了现有语言的思想但拥有着不同寻常的特性,使得有效的Go程序在性质上不同于其...
    云时代的运维开发阅读 887评论 0 0
  • # 云计算实验 如果说亚马逊的AWS(Amazon Web Service)是一个IaaS平台,为用户提供计算服务...
    哟桑_6481阅读 587评论 0 0