15.4 写一个简单的网页应用

下边的程序在端口 8088 上启动了一个网页服务器;SimpleServer() 会处理 url/test1 使它在浏览器输出 hello worldFormServer 会处理 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

  1. package main
  2. import (
  3. "io"
  4. "net/http"
  5. )
  6. const form = `
  7. <html><body>
  8. <form action="#" method="post" name="bar">
  9. <input type="text" name="in" />
  10. <input type="submit" value="submit"/>
  11. </form>
  12. </body></html>
  13. `
  14. /* handle a simple get request */
  15. func SimpleServer(w http.ResponseWriter, request *http.Request) {
  16. io.WriteString(w, "<h1>hello, world</h1>")
  17. }
  18. func FormServer(w http.ResponseWriter, request *http.Request) {
  19. w.Header().Set("Content-Type", "text/html")
  20. switch request.Method {
  21. case "GET":
  22. /* display the form to the user */
  23. io.WriteString(w, form)
  24. case "POST":
  25. /* handle the form data, note that ParseForm must
  26. be called before we can extract form data */
  27. //request.ParseForm();
  28. //io.WriteString(w, request.Form["in"][0])
  29. io.WriteString(w, request.FormValue("in"))
  30. }
  31. }
  32. func main() {
  33. http.HandleFunc("/test1", SimpleServer)
  34. http.HandleFunc("/test2", FormServer)
  35. if err := http.ListenAndServe(":8088", nil); err != nil {
  36. panic(err)
  37. }
  38. }

注:当使用字符串常量表示 html 文本的时候,包含 <html><body>...</body></html> 对于让浏览器将它识别为 html 文档非常重要。

更安全的做法是在处理函数中,在写入返回内容之前将头部的 content-type 设置为 text/htmlw.Header().Set("Content-Type", "text/html")

"Content-Type" 会让浏览器认为它可以使用函数 http.DetectContentType([]byte(form)) 来处理收到的数据。

练习 15.6 statistics.go

编写一个网页程序,可以让用户输入一连串的数字。计算出这些数字的均值和中值,并且打印出来,就像下边这张截图一样:

15.4 写一个简单的网页应用 - 图1

链接