溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Python破解BiliBili滑塊驗證碼的思路詳解(完美避開人機(jī)識別)

發(fā)布時間:2020-09-12 04:38:17 來源:腳本之家 閱讀:332 作者:Mingyueyixi 欄目:開發(fā)技術(shù)

準(zhǔn)備工作

B站登錄頁 https://passport.bilibili.com/login
python3
pip install selenium (webdriver框架)
pip install PIL (圖片處理)
chrome driver:http://chromedriver.storage.googleapis.com/index.html
firefox driver:https://github.com/mozilla/geckodriver/releases

Python破解BiliBili滑塊驗證碼的思路詳解(完美避開人機(jī)識別)

B站的滑塊驗證碼如上。

這類驗證碼可以使用 selenium 操作瀏覽器拖拽滑塊來進(jìn)行破解,難點(diǎn)兩個,一個如何確定拖拽到的位置,另一個是避開人機(jī)識別(反爬蟲)。

確定滑塊驗證碼需要拖拽的位移距離

有三種方式

  • 人工智能機(jī)器學(xué)習(xí),確定滑塊位置
  • 通過完整圖片與缺失滑塊的圖片進(jìn)行像素對比,確定滑塊位置
  • 邊緣檢測算法,確定位置

各有優(yōu)缺點(diǎn)。人工智能機(jī)器學(xué)習(xí),確定滑塊位置,需要進(jìn)行訓(xùn)練,比較麻煩,也可以看是否存在在線api可以調(diào)用。以下介紹其他兩種方式。

對比完整圖片與缺失滑塊的圖片

| 僅介紹,本文不進(jìn)行實現(xiàn)。對于B站來說,是準(zhǔn)確率最高的方式(100%),但不能保證未來B站的滑塊驗證升級,導(dǎo)致不可用。

B站的滑塊驗證模塊,一共有三張圖片:

完整圖、缺失滑塊圖、滑塊圖,都是由畫布繪制出的。類似于:

完整圖:


Python破解BiliBili滑塊驗證碼的思路詳解(完美避開人機(jī)識別)

缺失滑塊圖:


Python破解BiliBili滑塊驗證碼的思路詳解(完美避開人機(jī)識別)

滑塊圖:


Python破解BiliBili滑塊驗證碼的思路詳解(完美避開人機(jī)識別)

HTML代碼類似于:

<div class="geetest_canvas_img geetest_absolute" >
<div class="geetest_slicebg geetest_absolute">
	<canvas class="geetest_canvas_bg geetest_absolute" height="160" width="260"></canvas>
	<canvas class="geetest_canvas_slice geetest_absolute" width="260" height="160"></canvas>
</div>
<canvas class="geetest_canvas_fullbg geetest_fade geetest_absolute" height="160" width="260" ></canvas>
</div>

只需要通過selenium獲取畫布元素,執(zhí)行js拿到畫布像素,遍歷完整圖和缺失滑塊圖的像素,一旦獲取到差異(需要允許少許像素誤差),像素矩陣x軸方向即是滑塊位置。
另外由于滑塊圖距離畫布坐標(biāo)原點(diǎn)有距離,還需要減去這部分距離。
最后使用 selenium 拖拽即可。

邊緣檢測算法,確定位置

| 滑塊基本上是個方形,通過算法確定方形起始位置即可。

Python破解BiliBili滑塊驗證碼的思路詳解(完美避開人機(jī)識別)

介紹兩種方式

  • 滑塊是方形的,存在垂直的邊,該邊在缺失滑塊圖中基本都是灰黑的。遍歷像素找到基本都是灰黑的邊即可。
  • 缺失滑塊圖中滑塊位置是灰黑封閉的。通過算法可以找到封閉區(qū)域,大小與滑塊相近,即是滑塊需要拖拽到的位置。

第二種實現(xiàn)起來有些復(fù)雜,不進(jìn)行實現(xiàn)了。

下面是第一種實現(xiàn)方式,會存在檢測不出或錯誤的情況,使用時需要換一張驗證碼。也可能存在檢測出的邊是另一條(因為B站的滑塊不是長方形,存在弧形邊),那么需要減去滑塊寬度

class VeriImageUtil():

 def __init__(self):
  self.defaultConfig = {
   "grayOffset": 20,
   "opaque": 1,
   "minVerticalLineCount": 30
  }
  self.config = copy.deepcopy(self.defaultConfig)

 def updateConfig(self, config):
  # temp = copy.deepcopy(config)
  for k in self.config:
   if k in config.keys():
    self.config[k] = config[k]

 def getMaxOffset(self, *args):
  # 計算偏移平均值最大的數(shù)
  av = sum(args) / len(args)

  maxOffset = 0
  for a in args:
   offset = abs(av - a)
   if offset > maxOffset:
    maxOffset = offset
  return maxOffset

 def isGrayPx(self, r, g, b):
  # 是否是灰度像素點(diǎn),允許波動offset
  return self.getMaxOffset(r, g, b) < self.config["grayOffset"]

 def isDarkStyle(self, r, g, b):
  # 灰暗風(fēng)格
  return r < 128 and g < 128 and b < 128

 def isOpaque(self, px):
  # 不透明
  return px[3] >= 255 * self.config["opaque"]

 def getVerticalLineOffsetX(self, bgImage):
  # bgImage = Image.open("./image/bg.png")
  # bgImage.im.mode = 'RGBA'
  bgBytes = bgImage.load()

  x = 0
  while x < bgImage.size[0]:
   y = 0
   # 點(diǎn)》》線,灰度線條數(shù)量
   verticalLineCount = 0
   if x == 258:
    print(y)
   while y < bgImage.size[1]:
    px = bgBytes[x, y]
    r = px[0]
    g = px[1]
    b = px[2]
    # alph = px[3]
    # print(px)
    if self.isDarkStyle(r, g, b) and self.isGrayPx(r, g, b) and self.isOpaque(px):
     verticalLineCount += 1
    else:
     verticalLineCount = 0
     y += 1
     continue

    if verticalLineCount >= self.config["minVerticalLineCount"]:
     # 連續(xù)多個像素都是灰度像素,直線
     # print(x, y)
     return x

    y += 1

   x += 1
  pass


if __name__ == '__main__':
 bgImage = Image.open("./image/bg.png")
 veriImageUtil = VeriImageUtil()

 # veriImageUtil.updateConfig({
 #  "grayOffset": 20,
 #  "opaque": 0.6,
 #  "minVerticalLineCount": 10
 # })
  bgOffsetX = veriImageUtil.getVerticalLineOffsetX(bgImage)
 print("bgOffsetX:{} ".format(bgOffsetX))

總結(jié)

以上所述是小編給大家介紹的Python破解BiliBili滑塊驗證碼的思路詳解(完美避開人機(jī)識別),希望對大家有所幫助!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI