Rumah pembangunan bahagian belakang Tutorial Python Bagaimana untuk menggunakan Mozilla Firefox dalam Scrapy untuk menyelesaikan masalah mengimbas kod QR untuk log masuk?

Bagaimana untuk menggunakan Mozilla Firefox dalam Scrapy untuk menyelesaikan masalah mengimbas kod QR untuk log masuk?

Jun 22, 2023 pm 09:50 PM
firefox scrapy Imbas kod untuk log masuk

Bagi perangkak merangkak tapak web yang memerlukan log masuk, kod pengesahan atau log masuk kod imbasan adalah masalah yang sangat menyusahkan. Scrapy ialah rangka kerja perangkak yang sangat mudah digunakan dalam Python, tetapi apabila memproses kod pengesahan atau mengimbas kod QR untuk log masuk, beberapa langkah khas perlu diambil. Sebagai pelayar biasa, Mozilla Firefox menyediakan penyelesaian yang boleh membantu kami menyelesaikan masalah ini.

Modul teras Scrapy dipintal, yang hanya menyokong permintaan tak segerak, tetapi sesetengah tapak web perlu menggunakan kuki dan sesi untuk kekal log masuk, jadi kami perlu menggunakan Mozilla Firefox untuk menangani masalah ini.

Pertama, kita perlu memasang pelayar Mozilla Firefox dan pemacu Firefox yang sepadan untuk menggunakannya dalam Python. Arahan pemasangan adalah seperti berikut:

pip install selenium
Salin selepas log masuk

Kemudian, kita perlu menambah beberapa tetapan pada fail settings.py crawler untuk menggunakan pelayar Firefox untuk mengimbas kod QR untuk log masuk. Berikut ialah tetapan sampel:

DOWNLOADER_MIDDLEWARES = {
'scrapy.downloadermiddlewares.cookies.CookiesMiddleware':700,
'scrapy_selenium.SeleniumMiddleware':800,
}

SELENIUM_DRIVER_NAME = 'firefox'
SELENIUM_DRIVER_EXECUTABLE_PATH = which('geckodriver')
SELENIUM_BROWSER_EXECUTABLE_PATH = '/usr/bin/firefox'
Salin selepas log masuk

Kami boleh menetapkannya mengikut sistem pengendalian kami sendiri dan laluan pemasangan Firefox.

Seterusnya, kita perlu mencipta kelas Scrapy Spider tersuai untuk menggunakan penyemak imbas Firefox. Dalam kelas ini, kita perlu menetapkan beberapa pilihan untuk pelayar Firefox seperti yang ditunjukkan di bawah:

from selenium import webdriver
from scrapy.selector import Selector
from scrapy.spiders import CrawlSpider
from scrapy.http import Request

class MySpider(CrawlSpider):
   name = 'myspider'

   def __init__(self):
      self.driver = webdriver.Firefox(executable_path='geckodriver', firefox_binary='/usr/bin/firefox')
      self.driver.set_window_size(1400, 700)
      self.driver.set_page_load_timeout(30)
      self.driver.set_script_timeout(30)

   def parse(self, response):
      # 网站首页处理代码
      pass
Salin selepas log masuk

Dalam kelas Spider tersuai ini, kami telah menggunakan kelas selenium.webdriver.Firefox untuk mencipta objek peranti kawalan pelayar Firefox. Objek pengawal pelayar Firefox digunakan untuk membuka halaman utama tapak web dan juga boleh melakukan operasi lain seperti yang diperlukan.

Untuk tapak web yang memerlukan pengimbasan kod QR untuk log masuk, kami boleh menggunakan penyemak imbas Firefox untuk mengenal pasti kod QR pada halaman dan menunggu hasil pengimbasan kod QR. Kita boleh menggunakan Selenium untuk mensimulasikan tingkah laku pengguna dalam Python untuk mengimbas kod QR dan log masuk ke tapak web. Kod log masuk pengimbasan kod lengkap adalah seperti berikut:

def parse(self, response):
   self.driver.get(response.url)
   # 等待页面加载完成
   time.sleep(5)
   # 寻找二维码及其位置
   frame = self.driver.find_element_by_xpath('//*[@class="login-qr-code iframe-wrap"]//iframe')
   self.driver.switch_to.frame(frame)
   qr_code = self.driver.find_element_by_xpath('//*[@id="login-qr-code"]/img')
   position = qr_code.location
   size = qr_code.size

   while True:
      # 判断是否已经扫描了二维码,
      # 如果扫描了,登录,并跳出循环
      try:
         result = self.driver.find_element_by_xpath('//*[@class="login-qr-code-close"]')
         result.click()
         break
      except:
         pass

      # 如果没有扫描,等待并继续寻找
      time.sleep(5)


   # 登录后处理的代码
   pass
Salin selepas log masuk

Dalam kod di atas, kami mula-mula menggunakan kaedah self.driver.get() untuk membuka halaman utama tapak web, dan kemudian gunakan kaedah find_element_by_xpath() untuk mencari elemen kod QR Dapatkan kedudukan dan saiznya. Kemudian gunakan gelung sementara untuk menunggu hasil pengimbasan kod QR Jika ia telah diimbas, klik butang tutup pada kod QR dan lompat keluar dari gelung. Jika tiada imbasan, tunggu 5 saat dan teruskan mencari.

Apabila hasil pengimbasan kod QR tersedia, kami boleh melaksanakan logik log masuk kami sendiri Kaedah pemprosesan khusus bergantung pada situasi sebenar tapak web.

Ringkasnya, apabila menggunakan Scrapy untuk pembangunan crawler, jika kami menemui tapak web yang memerlukan log masuk, dan tapak web tersebut menggunakan kod pengesahan atau kod imbasan untuk log masuk, kami boleh menggunakan kaedah di atas untuk menyelesaikan masalah ini. Menggunakan penyemak imbas Selenium dan Firefox, kami boleh mensimulasikan operasi pengguna, mengendalikan isu log masuk kod QR dan mendapatkan data yang diperlukan.

Atas ialah kandungan terperinci Bagaimana untuk menggunakan Mozilla Firefox dalam Scrapy untuk menyelesaikan masalah mengimbas kod QR untuk log masuk?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk mengimbas kod QR untuk log masuk ke APP Douyin Bagaimana untuk mengimbas kod QR untuk log masuk? Bagaimana untuk mengimbas kod QR untuk log masuk ke APP Douyin Bagaimana untuk mengimbas kod QR untuk log masuk? Mar 13, 2024 pm 03:16 PM

Semua orang boleh menggunakan APP Douyin untuk menonton pelbagai video pendek setiap hari Dengan menonton video ini, anda boleh melegakan kebimbangan anda dan meluangkan masa Ia adalah pilihan yang sangat baik untuk sesiapa sahaja terdapat beberapa video baharu setiap hari yang boleh dihantar kepada anda untuk memenuhi keperluan tontonan pengguna yang berbeza Banyak kali, semua orang perlu menggunakan fungsi imbasan pada platform Fungsi pengimbasan memerlukan keizinan untuk log masuk pada platform lain kod QR untuk log masuk seperti ini boleh membuatkan semua orang berasa lebih senang, tetapi kebanyakan rakan saya masih tidak tahu cara mengimbas kod QR Log masuk, jadi editor laman web ini sangat bertimbang rasa dan membawakan anda beberapa imbasan khusus kod.

Scrapy melaksanakan rangkak dan analisis artikel akaun awam WeChat Scrapy melaksanakan rangkak dan analisis artikel akaun awam WeChat Jun 22, 2023 am 09:41 AM

Scrapy melaksanakan rangkak artikel dan analisis akaun awam WeChat WeChat ialah aplikasi media sosial yang popular dalam beberapa tahun kebelakangan ini, dan akaun awam yang dikendalikan di dalamnya juga memainkan peranan yang sangat penting. Seperti yang kita sedia maklum, akaun awam WeChat adalah lautan maklumat dan pengetahuan, kerana setiap akaun awam boleh menerbitkan artikel, mesej grafik dan maklumat lain. Maklumat ini boleh digunakan secara meluas dalam banyak bidang, seperti laporan media, penyelidikan akademik, dsb. Jadi, artikel ini akan memperkenalkan cara menggunakan rangka kerja Scrapy untuk merangkak dan menganalisis artikel akaun awam WeChat. Scr

Bagaimana untuk mengalih keluar Firefox Snap dalam Ubuntu Linux? Bagaimana untuk mengalih keluar Firefox Snap dalam Ubuntu Linux? Feb 21, 2024 pm 07:00 PM

Untuk mengalih keluar FirefoxSnap dalam Ubuntu Linux, anda boleh mengikuti langkah berikut: Buka terminal dan log masuk ke sistem Ubuntu anda sebagai pentadbir. Jalankan arahan berikut untuk menyahpasang FirefoxSnap: sudosnapremovefirefox Anda akan digesa untuk kata laluan pentadbir anda. Masukkan kata laluan anda dan tekan Enter untuk mengesahkan. Tunggu pelaksanaan arahan selesai. Setelah selesai, FirefoxSnap akan dialih keluar sepenuhnya. Ambil perhatian bahawa ini akan mengalih keluar versi Firefox yang dipasang melalui pengurus pakej Snap. Jika anda memasang versi Firefox yang lain melalui cara lain (seperti pengurus pakej APT), anda tidak akan terjejas. Pergi melalui langkah-langkah di atas

Kaedah pelaksanaan pemuatan asynchronous Scrapy berdasarkan Ajax Kaedah pelaksanaan pemuatan asynchronous Scrapy berdasarkan Ajax Jun 22, 2023 pm 11:09 PM

Scrapy ialah rangka kerja perangkak Python sumber terbuka yang boleh mendapatkan data daripada tapak web dengan cepat dan cekap. Walau bagaimanapun, banyak tapak web menggunakan teknologi pemuatan tak segerak Ajax, menjadikannya mustahil untuk Scrapy mendapatkan data secara langsung. Artikel ini akan memperkenalkan kaedah pelaksanaan Scrapy berdasarkan pemuatan tak segerak Ajax. 1. Prinsip pemuatan tak segerak Ajax Pemuatan tak segerak Ajax: Dalam kaedah pemuatan halaman tradisional, selepas pelayar menghantar permintaan kepada pelayan, ia mesti menunggu pelayan mengembalikan respons dan memuatkan keseluruhan halaman sebelum meneruskan ke langkah seterusnya.

Analisis kes buruk: Cara merangkak maklumat syarikat di LinkedIn Analisis kes buruk: Cara merangkak maklumat syarikat di LinkedIn Jun 23, 2023 am 10:04 AM

Scrapy ialah rangka kerja perangkak berasaskan Python yang boleh mendapatkan maklumat berkaitan dengan cepat dan mudah di Internet. Dalam artikel ini, kami akan menggunakan kes Scrapy untuk menganalisis secara terperinci cara merangkak maklumat syarikat di LinkedIn. Tentukan URL sasaran Mula-mula, kita perlu menjelaskan dengan jelas bahawa sasaran kita ialah maklumat syarikat di LinkedIn. Oleh itu, kita perlu mencari URL halaman maklumat syarikat LinkedIn. Buka laman web LinkedIn, masukkan nama syarikat dalam kotak carian, dan

Bagaimana untuk mengimbas kod QR untuk log masuk ke Mango TV? Langkah log masuk kod imbasan TV Mango Bagaimana untuk mengimbas kod QR untuk log masuk ke Mango TV? Langkah log masuk kod imbasan TV Mango Mar 15, 2024 pm 07:22 PM

Mango TV ialah platform yang mudah digunakan untuk menonton drama Ia adalah artifak menonton drama yang dicipta khas untuk TV Satelit Hunan Ia memuaskan hati rakan-rakan yang ingin menonton drama. Terdapat banyak sumber filem dan televisyen yang kaya di sini, termasuk filem terkini, siri TV popular, dsb., anda boleh menontonnya dengan mudah. Jadi adakah anda tahu bagaimana untuk mengimbas kod QR untuk log masuk ke Mango TV Langkah-langkah terperinci untuk mengimbas kod QR untuk log masuk ke Mango TV: 1. Cari pelayar dan masuk ke laman web Mango TV. 2. Selepas mengklik pada sudut kanan atas halaman untuk log masuk, klik pada ikon kod QR. Kelebihan perisian 1. Definisi tinggi dan lancar: sumber video berkualiti tinggi, teras main balik baharu 2. Fungsi tontonan sejarah: cepat cari program yang terakhir ditonton untuk terus dimainkan 3. Sokongan sempurna untuk main balik atas permintaan dan tempatan dalam talian 4. Keserasian format : serasi sepenuhnya dengan format media arus perdana

Petua pengoptimuman buruk: Cara mengurangkan rangkak URL pendua dan meningkatkan kecekapan Petua pengoptimuman buruk: Cara mengurangkan rangkak URL pendua dan meningkatkan kecekapan Jun 22, 2023 pm 01:57 PM

Scrapy ialah rangka kerja perangkak Python yang berkuasa yang boleh digunakan untuk mendapatkan sejumlah besar data daripada Internet. Walau bagaimanapun, apabila membangunkan Scrapy, kami sering menghadapi masalah merangkak URL pendua, yang membuang banyak masa dan sumber serta menjejaskan kecekapan. Artikel ini akan memperkenalkan beberapa teknik pengoptimuman Scrapy untuk mengurangkan rangkak URL pendua dan meningkatkan kecekapan perangkak Scrapy. 1. Gunakan atribut start_urls dan allowed_domains dalam perangkak Scrapy untuk

Menggunakan Selenium dan PhantomJS dalam perangkak Scrapy Menggunakan Selenium dan PhantomJS dalam perangkak Scrapy Jun 22, 2023 pm 06:03 PM

Menggunakan Selenium dan PhantomJSScrapy dalam perangkak Scrapy Scrapy ialah rangka kerja perangkak web yang sangat baik di bawah Python dan telah digunakan secara meluas dalam pengumpulan dan pemprosesan data dalam pelbagai bidang. Dalam pelaksanaan perangkak, kadangkala perlu untuk mensimulasikan operasi penyemak imbas untuk mendapatkan kandungan yang dibentangkan oleh tapak web tertentu Dalam kes ini, Selenium dan PhantomJS diperlukan. Selenium mensimulasikan operasi manusia pada penyemak imbas, membolehkan kami mengautomasikan ujian aplikasi web

See all articles