真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

nodepuppeteer如何實(shí)現(xiàn)網(wǎng)站登錄-創(chuàng)新互聯(lián)

這篇文章主要為大家展示了“node puppeteer如何實(shí)現(xiàn)網(wǎng)站登錄”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“node puppeteer如何實(shí)現(xiàn)網(wǎng)站登錄”這篇文章吧。

十載專注成都網(wǎng)站制作,企業(yè)網(wǎng)站建設(shè),個(gè)人網(wǎng)站制作服務(wù),為大家分享網(wǎng)站制作知識(shí)、方案,網(wǎng)站設(shè)計(jì)流程、步驟,成功服務(wù)上千家企業(yè)。為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁設(shè)計(jì)及定制高端網(wǎng)站建設(shè)服務(wù),專注于企業(yè)網(wǎng)站建設(shè),高端網(wǎng)頁制作,對主動(dòng)防護(hù)網(wǎng)等多個(gè)領(lǐng)域,擁有多年建站經(jīng)驗(yàn)。

puppeteer簡介

puppeteer是Chrome團(tuán)隊(duì)開發(fā)的一個(gè)node庫,可以通過api來控制瀏覽器的行為,比如點(diǎn)擊,跳轉(zhuǎn),刷新,在控制臺(tái)執(zhí)行js腳本等等。有了這個(gè)神器,寫個(gè)爬蟲,自動(dòng)簽到,網(wǎng)頁截圖,生成pdf,自動(dòng)化測試什么的,都不在話下。

puppeteer的簡單例子

代碼來自官網(wǎng):

const puppeteer = require('puppeteer');
 
(async () => {
 const browser = await puppeteer.launch();//打開瀏覽器
 const page = await browser.newPage();//打開一個(gè)空白頁
 await page.goto('https://example.com');//在地址欄輸入網(wǎng)址并等待加載
 await page.screenshot({path: 'example.png'});//截個(gè)圖
 
 await browser.close();//關(guān)掉瀏覽器
})();

閱讀上述代碼,我們可以發(fā)現(xiàn),1,代碼中每一步都是異步操作,2,每一步操作都對應(yīng)實(shí)際使用瀏覽器的一個(gè)行為。理解這兩點(diǎn)對使用這個(gè)庫有很大幫助。另外,比較常用的兩個(gè)對象就是browser和page對象,對象上有一堆用來操作兩個(gè)對象的方法。接下來,我們就寫一個(gè)登錄網(wǎng)站的小demo。

沒有驗(yàn)證碼的網(wǎng)站

對于沒有驗(yàn)證碼的網(wǎng)站,基本上就是輸入賬號(hào),輸入密碼,點(diǎn)擊登錄這三步,需要用到page對象的兩個(gè)方法:type用來在輸入框中輸入信息,click用來點(diǎn)擊登錄。下面以登錄豆瓣為例來舉個(gè)例子:

const puppeteer = require('puppeteer');
const account = `123456@qq.com`;
const password = `123456`;
(async () => {
 const browser = await puppeteer.launch();//打開瀏覽器
 const page = await browser.newPage();//打開一個(gè)空白頁
 await page.goto('https://www.douban.com/');//打開豆瓣網(wǎng)站
 await page.type('#form_email', account);  
 await page.type('#form_password', password);
 await page.click('.bn-submit');
 await page.waitForNavigation({
  waitUntil: 'load'
 });//等待頁面加載出來,等同于window.onload
 await page.screenshot({path: 'example.png'});//截個(gè)圖
 await browser.close();//關(guān)掉瀏覽器
})();

有人說,我怎么知道到底有沒有登錄成功呢,一種調(diào)試的辦法就是使用screenshot,如果你看到的是一個(gè)驗(yàn)證碼頁面,說明沒有登錄成功,還有一種辦法像下面這樣:

const browser = await puppeteer.launch({headless: false});//打開有界面的瀏覽器

傳入headless:false后會(huì)真的打開一個(gè)瀏覽器的界面,這樣你就可以實(shí)時(shí)看到代碼執(zhí)行到什么地方了。接下來我們說說碰到驗(yàn)證碼時(shí)怎么辦。

有驗(yàn)證碼的網(wǎng)站

node puppeteer如何實(shí)現(xiàn)網(wǎng)站登錄

碰到有驗(yàn)證碼的網(wǎng)站,可以將headless設(shè)成false,借助界面輸入驗(yàn)證碼,同時(shí)監(jiān)聽頁面加載事件,實(shí)現(xiàn)登錄,代碼如下:

...

 await page.waitForNavigation({
  waitUntil: 'load'
 });//等待頁面加載出來,等同于window.onload


//代碼中監(jiān)聽跳轉(zhuǎn)事件
if(page.url() === 'https://www.douban.com/accounts/login'){ 
   //登錄不成功
  console.log('需要輸入驗(yàn)證碼');
  //等待再一次跳轉(zhuǎn)
  while(true){
    await page.waitForNavigation({
      waitUntil: 'load'
    })
    console.log(page.url())
    if(page.url() === 'https://www.douban.com/'){
      console.log('登錄成功');
      break;
    }
  }
 }

整體思路就是寫也個(gè)循環(huán),不斷監(jiān)聽頁面跳轉(zhuǎn),直到瀏覽器登錄成功后跳轉(zhuǎn)到首頁為止。

以上是“node puppeteer如何實(shí)現(xiàn)網(wǎng)站登錄”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


文章名稱:nodepuppeteer如何實(shí)現(xiàn)網(wǎng)站登錄-創(chuàng)新互聯(lián)
分享鏈接:http://weahome.cn/article/dgjsep.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部