golang語言chromedp包介紹以及如何彈出瀏覽器進行調試
背景
想要做一個定時自動發送微博的程序,微博API提供了一個接口statuses/share,但是該接口需要注冊微博開發者並審核通過(需要有app或者網站)微博應用審核產品指南。因此通過搜索引擎了解到可以通過程序控制chrome瀏覽器來實現,在GitHub上找到了chromedp
這個包,但是相關文檔比較少。這里把我了解和學習這個包,並實現自動化發送微博的過程記錄並分享出來。
關於chromedp
GitHub地址:https://github.com/chromedp/chromedp
安裝chromedp
go get -u github.com/chromedp/chromedp
使用例子
關於如何使用官方還有一個項目專門來寫了幾個例子來幫助大家入門,第一次接觸可以先用官方的例子試一下。但是這里要注意官方的例子中使用的好多都是在國內被屏蔽的網站,地址:https://github.com/chromedp/examples
chrome普通模式與chrome headless模式的區別
普通模式
普通模式會在電腦上彈出瀏覽器窗口,可以在瀏覽器中看到代碼執行的效果,調用完成之后需要關閉掉瀏覽器。
chrome headless模式
chrome headless模式不會彈出瀏覽器窗口,並且你多次go run main.go
的時候, go 代碼運行中斷導致后台chrome headless不能退出,導致第二次本地調試失敗, 此時解決方案就是自己手動結束chrome進程。
因此在調試go代碼的時候不建議使用chrome headless模式。
如何使用chrome普通模式
chromedp
包默認情況下使用chrome headless模式,所以需要在禁用該模式才會彈出你本地的chrome瀏覽器。
// Command click is a chromedp example demonstrating how to use a selector to
// click on an element.
package main
import (
"context"
"log"
"time"
"github.com/chromedp/chromedp"
)
func main() {
// 禁用chrome headless
opts := append(chromedp.DefaultExecAllocatorOptions[:],
chromedp.Flag("headless", false),
)
allocCtx, cancel := chromedp.NewExecAllocator(context.Background(), opts...)
defer cancel()
// create chrome instance
ctx, cancel := chromedp.NewContext(
allocCtx,
chromedp.WithLogf(log.Printf),
)
defer cancel()
// create a timeout
ctx, cancel = context.WithTimeout(ctx, 15*time.Second)
defer cancel()
// navigate to a page, wait for an element, click
var example string
err := chromedp.Run(ctx,
chromedp.Navigate(`https://golang.org/pkg/time/`),
// wait for footer element is visible (ie, page is loaded)
chromedp.WaitVisible(`body > footer`),
// find and click "Expand All" link
chromedp.Click(`#pkg-examples > div`, chromedp.NodeVisible),
// retrieve the value of the textarea
chromedp.Value(`#example_After .play .input textarea`, &example),
)
if err != nil {
log.Fatal(err)
}
log.Printf("Go's time.After example:\n%s", example)
}