from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains
import time
import requests
import json
def base64_api(img,typeid,uname='18720180853', pwd='20010119yx'):
# with open(img, 'rb') as f:
# base64_data = base64.b64encode(f.read())
# b64 = base64_data.decode()
data = {"username": uname, "password": pwd, "typeid": typeid, "image": img}
result = json.loads(requests.post("http://api.ttshitu.com/predict", json=data).text)
if result['success']:
return result["data"]["result"]
else:
#!!!!!!!注意:返回 人工不足等 错误情况 请加逻辑处理防止脚本卡死 继续重新 识别
return result["message"]
return ""
path = 'chromedriver.exe'
browser = webdriver.Chrome(path)
browser.get('https://id.hqu.edu.cn/authserver/login?service=http%3A%2F%2Fehall.hqu.edu.cn%2Flogin%3Fservice%3Dhttp%3A%2F%2Fehall.hqu.edu.cn%2Fnew%2Findex.html')
time.sleep(3)
browser.find_element_by_xpath('//*[@id="username"]').send_keys(user)
browser.find_element_by_xpath('//*[@id="password"]').send_keys(password)
browser.find_element_by_xpath('//*[@id="login_submit"]').click()
time.sleep(2)
verify_code = browser.find_element_by_xpath('//*[@id="sliderDiv"]/canvas[2]')#定位验证码图片
tu = verify_code.screenshot_as_base64 # 获取验证码bs4格式
verify_code.screenshot('tu.png') # 获取验证码的图
x = base64_api(tu,33)
time.sleep(1)
spider = browser.find_element_by_xpath('//*[@id="sliderDiv"]/div/div[2]/div')
action = webdriver.ActionChains(browser) # 启动动作链
action.click_and_hold(spider).perform() # 按住滑块不松开
action.move_by_offset(x,0) # 开始滑动
action.release().perform() # 释放滑块
验证码类型:
总结:
1.学习到了selenium中的动作链模块。
首先 from selenium.webdriver.common.action_chains import ActionChains导入包
使用方法:
首先启动动作链:action = webdriver.ActionChains(browser)
action.click_and_hold(定位滑块的位置).perform() # 按住滑块
action.move_by_offset(x坐标,y坐标)? # 移动滑块到指定位置
action.release().perform() # 释放滑块
注意每一条语句都要加.perform()表示执行。