访问并读取页面数据
Last updated
Was this helpful?
Last updated
Was this helpful?
在下边这个程序中,数组中的 url 都将被访问:会发送一个简单的 http.Head()
请求查看返回值;它的声明如下:func Head(url string) (r *Response, err error)
返回的响应 Response
其状态码会被打印出来。
示例 15.7 :
输出为:
译者注 由于国内的网络环境现状,很有可能见到如下超时错误提示:
Error: http://www.google.com/ Head http://www.google.com/: dial tcp 216.58.221.100:80: connectex: A connection attempt failed because the connected party did not properly respond after a period of time, or established connection failed because connected host has failed to respond.
在下边的程序中我们使用 http.Get()
获取并显示网页内容;Get()
返回值中的 Body
属性包含了网页内容,然后我们用 ioutil.ReadAll()
把它读出来:
当访问不存在的网站时,这里有一个 checkError
输出错误的例子:
译者注 和上一个例子相似,你可以把 google.com 更换为一个国内可以顺畅访问的网址进行测试
在下边的程序中,我们获取一个 Twitter 用户的状态,通过 xml
包将这个状态解析成为一个结构:
输出:
译者注 和上边的示例相似,你可能无法获取到 xml 数据,另外由于 Go 版本的更新,xml.Unmarshal()
函数的第一个参数必需是 []byte
类型,而无法传入 Body
。
http.Redirect(w ResponseWriter, r *Request, url string, code int)
:这个函数会让浏览器重定向到 url
(可以是基于请求 url 的相对路径),同时指定状态码。
http.NotFound(w ResponseWriter, r *Request)
:这个函数将返回网页没有找到,HTTP 404 错误。
http.Error(w ResponseWriter, error string, code int)
:这个函数返回特定的错误信息和 HTTP 代码。
另一个 http.Request
对象 req
的重要属性:req.Method
,这是一个包含 GET
或 POST
字符串,用来描述网页是以何种方式被请求的。
Go 为所有的 HTTP 状态码定义了常量,比如:
你可以使用 w.header().Set("Content-Type", "../..")
设置头信息。
比如在网页应用发送 html 字符串的时候,在输出之前执行 w.Header().Set("Content-Type", "text/html")
(通常不是必要的)。
示例 15.8 :
示例 15.9
我们会在 中用到 http
包中的其他重要的函数:
练习 15.4:扩展 http_fetch.go 使之可以从控制台读取 url,使用 学到的接收控制台输入的方法 ()
练习 15.5:获取 json 格式的推特状态,就像示例 15.9 ()
上一节:
下一节: