欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Go语言做爬虫状态码返回418的问题解决

程序员文章站 2022-03-04 14:56:09
目录背景原因分析代码部分背景 在使用go语言做爬虫时,使用http.get(url)去获取网页内容,状态码返回404,body体为空。原因分析 http.get(url)是不需要设置header属性的...

背景

 在使用go语言做爬虫时,使用http.get(url)去获取网页内容,状态码返回404,body体为空。

Go语言做爬虫状态码返回418的问题解决

原因分析

http.get(url)是不需要设置header属性的http请求,比较简单快捷,但状态码返回418,表明我们需要设置其header属性,那么我们可以使用http.newrequest,在设置其header属性即可~

代码部分

func main7()  {
	client := &http.client{}
	url := "https://movie.douban.com/top250?start=0&filter="
	reqest, err := http.newrequest("get", url, nil)
	//设置header属性
	reqest.header.add("user-agent", "mozilla/5.0 (windows nt 10.0; win64; x64) applewebkit/537.36 (khtml, like gecko) chrome/79.0.3945.130 safari/537.36 opr/66.0.3515.115")
	if err!=nil {
		fmt.println(err)
		return
	}
	response, _ := client.do(reqest)
	defer response.body.close()
	buf := make([]byte,4096)
	var result string
	for  {
		n,err:=response.body.read(buf)
		if n == 0 {
			fmt.println("读取网页完成")
			break
		}
		if err!=nil && err!=io.eof {
			fmt.println("resp body err",err)
			return
		}
		result += string(buf[:n])
		//打印读取的网页
		fmt.println(result)
	}
}

到此这篇关于go语言做爬虫状态码返回418的问题解决的文章就介绍到这了,更多相关go语言爬虫返回418内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!