由于接手了一个年久失修的网站,其网页的标题,keyword,description 异常混乱,很多页面的标题都是相同的,或者非常长,填充了大量冗余的关键词。

网站的板块,独立页非常多,完全靠检查代码,或者检查页面,很难找全所有有问题的页面。

为了快速找出有问题的页面,我决定用 golang colly 写个爬虫,自动检测全站的标题等 SEO 设置。

hello world, colly

以豆瓣网站为例:

package main

import (
	"fmt"
	"github.com/gocolly/colly"
	"github.com/gocolly/colly/extensions"
)

func main() {
	c := colly.NewCollector()
	extensions.RandomUserAgent(c)
	extensions.Referer(c)

	c.OnHTML("title", func(e *colly.HTMLElement) {
		fmt.Println(e.Text)
	})

	// Find and visit all links
	c.OnHTML("a[href]", func(e *colly.HTMLElement) {
		e.Request.Visit(e.Attr("href"))
	})

	c.OnRequest(func(r *colly.Request) {
		fmt.Println("Visiting", r.URL)
	})

	//c.Visit("http://go-colly.org/")
	c.Visit("https://www.douban.com")
}

运行结果:

> go run main.go
Visiting https://www.douban.com
豆瓣
Visiting https://book.douban.com
豆瓣读书
Visiting https://accounts.douban.com/passport/login?source=book
登录豆瓣
...

但是,会发现结果中还有新浪微博的链接,需要限制访问的域名。

限制请求的域名

参考:http://go-colly.org/docs/examples/basic/

c := colly.NewCollector(
    colly.AllowedDomains("www.douban.com"),
)

如果需要精确到 URL 级别,参考 colly 的 url filter: http://go-colly.org/docs/examples/url_filter/

限速

因为是检测自己的网站,怕把自己的网站服务器爬挂掉。。。所以一定要限速。

c.Limit(&colly.LimitRule{
	DomainGlob:  "www.douban.com",
	Parallelism: 1,
	Delay:       2 * time.Second,
})

LimitRule 的详细参数参考:

type LimitRule struct {
    // DomainRegexp is a regular expression to match against domains
    DomainRegexp string
    // DomainGlob is a glob pattern to match against domains
    DomainGlob string
    // Delay is the duration to wait before creating a new request to the matching domains
    Delay time.Duration
    // RandomDelay is the extra randomized duration to wait added to Delay before creating a new request
    RandomDelay time.Duration
    // Parallelism is the number of the maximum allowed concurrent requests of the matching domains
    Parallelism int
    // contains filtered or unexported fields
}

自定义请求头

设置 PC 还是移动端请求头。

全部代码

放到 github 上了:

参考

  • colly 的官方文档:https://godoc.org/github.com/gocolly/colly
  • colly 的示例:http://go-colly.org/docs/examples/basic/

tags: golang colly

关于作者