第十五章修改 (#834)

Co-authored-by: Joe Chen <jc@unknwon.io>
This commit is contained in:
Haigang Zhou
2022-05-17 16:33:20 +08:00
committed by GitHub
parent 60fe3dd076
commit 72f2eccbc5
12 changed files with 102 additions and 92 deletions

View File

@@ -1,6 +1,7 @@
# 15.4 写一个简单的网页应用
下边的程序在端口 8088 上启动了一个网页服务器;`SimpleServer` 会处理 url `/test1` 使它在浏览器输出 `hello world``FormServer` 会处理 url `/test2`:如果 url 最初由浏览器请求,那么它是一个 `GET` 请求,返回一个 `form` 常量,包含了简单的 `input` 表单,这个表单里有一个文本框和一个提交按钮。当在文本框输入一些东西并点击提交按钮的时候,会发起一个 POST 请求。`FormServer` 中的代码用到了 `switch` 来区分两种情况。请求为 POST 类型时,`name` 属性 `inp` 的文本框的内容可以这样获取:`request.FormValue("inp")`。然后将其写回浏览器页面中。在控制台启动程序,然后到浏览器中打开 url `http://localhost:8088/test2` 来测试这个程序:
下边的程序在端口 `8088` 上启动了一个网页服务器;`SimpleServer()` 会处理 url/`test1` 使它在浏览器输出 `hello world``FormServer` 会处理 url/`test2`:如果 url 最初由浏览器请求,那么它是一个 `GET` 请求,返回一个 `form` 常量,包含了简单的 `input` 表单,这个表单里有一个文本框和一个提交按钮。当在文本框输入一些东西并点击提交按钮的时候,会发起一个 POST 请求。`FormServer()` 中的代码用到了 `switch` 来区分两种情况。请求为 POST 类型时,`name` 属性为 `inp` 的文本框的内容可以这样获取:`request.FormValue("inp")`。然后将其写回浏览器页面中。在控制台启动程序,然后到浏览器中打开 url `http://localhost:8088/test2` 来测试这个程序:
示例 15.10 [simple_webserver.go](examples/chapter_15/simple_webserver.go)
@@ -52,15 +53,15 @@ func main() {
注:当使用字符串常量表示 html 文本的时候,包含 `<html><body>...</body></html>` 对于让浏览器将它识别为 html 文档非常重要。
更安全的做法是在处理函数中,在写入返回内容之前将头部的 `content-type` 设置为`text/html``w.Header().Set("Content-Type", "text/html")`
更安全的做法是在处理函数中,在写入返回内容之前将头部的 `content-type` 设置为 `text/html``w.Header().Set("Content-Type", "text/html")`
`content-type` 会让浏览器认为它可以使用函数 `http.DetectContentType([]byte(form))` 来处理收到的数据。
`"Content-Type"` 会让浏览器认为它可以使用函数 `http.DetectContentType([]byte(form))` 来处理收到的数据。
练习 15.6 [statistics.go](exercises/chapter_15/statistics.go)
编写一个网页程序,可以让用户输入一连串的数字,然后将它们打印出来,计算出这些数字的均值和中值,就像下边这张截图一样:
编写一个网页程序,可以让用户输入一连串的数字计算出这些数字的均值和中值,并且打印出来,就像下边这张截图一样:
![](images/15.4_fig15.1.jpg?raw=true)
<img src="images/15.4_fig15.1.jpg?raw=true" style="zoom:80%;" />
## 链接