大体思路:
- 控制浏览器模拟点击
- 利用漏洞拿到正确答案
- 填入答案
需要导入的模块
- from selenium import webdriver 控制浏览器用
-
- selenium下载地址
-
- chrome浏览器下载地址
-
- chromedrive
-
- 火狐drive
-
- edge_drive
-
- 推荐篇配置教程
- import time 控制程序暂停防止网络延迟出现错误
-
- py3内置模块不用下载
- 这些可以不用直接用input也行主要识别验证码
-
- from PIL import ImageGrab#截图用的
-
- import pytesseract #识别图片用的
-
- from PIL import Image
正文
导入模块
1 2 3 4 5 6 | from selenium import webdriver #控制浏览器用 import time #控制延时的 """识图不想用下面不用导入 可以用input""" from PIL import ImageGrab#截图用的 import pytesseract #识别图片用的 from PIL import Image |
定义几个变量为了代码的整洁
1 2 3 4 5 6 7 | """先定义几个变量为了代码的整洁""" name = '123456789@suibian.com' #这里填入你的账户 password = '123' #这里填入你的密码 """还要再填入一个账户因为这个是利用的漏洞 后面会说什么漏洞""" ///还写过一个完美的不用漏洞版本,以后有心情会发出来,也欢迎交流指点/// name1 = '0987654321@suibian.com' #填入另一个账户 password = '不知道' #填入另一个密码 |
用selenium控制浏览器
1 2 3 | dr = webdriver.Chrome() #打开谷歌浏览器 dr.get('http://s./login') #get方法打开指定网页 dr.maximize_window() #全屏打开 |
- 效果图
定义用户名 密码 并输入
1 2 | dr.find_element_by_id("LoginForm_username").send_keys(name) #用户名输入框 dr.find_element_by_id("LoginForm_password").send_keys(password) #密码输入框 |
- 效果图
找到验证码 位置输入 和点击登录按钮
1 2 3 4 5 6 7 8 9 10 11 12 | """识图部分""" img = ImageGrab.grab(bbox=(1468, 605, 1604, 660))#截取验证码的位置 img.save('111.png')#保存截取的图片 pytesseract.pytesseract.tesseract_cmd = '这里放tesseract的位置' w_input = pytesseract.image_to_string(Image.open('111.png'))#识别验证码并保存在w_input里 """或者用input""" w_input = input(请输入验证码: ) """定位验证位置同上""" dr.find_element_by_id("LoginForm_verifyCode").send_keys(w_input) #输入验证码 """定位登录按钮位置并点击""" dr.find_element_by_id("login").click() #点击登录按钮 time.sleep(1) #给一秒时间根据你的网络好坏定 |
- 效果图(按input的方式演示 //截图不懂也可以问我)
现在进入题库
选择课程点击云题库
1 2 | dr.find_element_by_xpath('/html/body/div[2]/div/div/div/div/div/div/form/ul/li[2]/a').click()#选择课程 dr.find_element_by_xpath('/html/body/div/div/ul/li[4]').click()#进入题库 |
- 效果
将话柄定位到最新的位置
1 2 | windows = dr.window_handles # 获取当前会话所有句柄 dr.switch_to.window(windows[-1]) #-1就是最新的标签 |
- 效果(两个标签所以要获取新话柄)
点击课程复习并进入试卷
1 2 3 4 | dr.find_element_by_xpath("/html/body/div[3]/div[1]/div/div[2]/div/div[2]/span[4]/a").click() #定位课程复习并点击 dr.find_element_by_xpath("/html/body/div[11]/div[2]/div/div/ul/li[1]/a").click() #点击第一个 如果点击第二个改一下定位 |
- 效果
这时候就要简单的提提那个漏洞了
- 账号1解析到交卷地址后在账号2上交卷
- 拿到答案再回到账号1填
- 账号2不会计入任何记录
- 账号1只会计入本日答题 全国排行和本班本校排行不会计入
完美的版本以后有心情在发 至于有多完美 哈哈哈
下面很多地方可以换一种方法解决为了照顾新手就只用selenium完成但还是简单提一下可以用什么:
- 弄交卷地址 和选项可以用正则表达式
- 点击选项可以用列表推导式 或者哈希公式
- 这是常用的还有好多细节懒得提///想要细的找我要
进入试卷后分析交卷地址
1 2 | o = dr.find_element_by_xpath("/html/body/div[2]/div/div/div[1]/div/a[2]") #定位到交卷地址 o = o.get_attribute("data") #提取出来 |
- 效果
下面不想写太详细了发生了点事情没心情
想听具体思路加我吧 等有心情讲给你
用小号打开
1 2 3 4 5 6 7 8 9 10 11 12 13 | """注意dr和drs""" drs= webdriver.Chrome()#用来打开小号的 drs.maximize_window() # 全屏 drs.get("http://s./login")#打开网页 drs.find_element_by_id("LoginForm_username").send_keys(name1) #用户名 drs.find_element_by_id("LoginForm_password").send_keys(password1)#密码 wa_input = input("密码") drs.find_element_by_id('LoginForm_verifyCode').send_keys(wa_input)#验证码 drs.find_element_by_id('login').click() #点登陆 find_element_by_xpath('//*[@id="choose-course-form"]/ul/li[2]/a').click()#新界面 就是点进题库去 drs.find_element_by_xpath("/html/body/div[1]/div/ul/li[4]/a").click() #点击云题库 drs.switch_to.window(driver.window_handles[-1])#获取新话柄 """重复内容不再细说""" |
** 和账号一登录过程是一样的不在放图**
小号打开交卷地址并交卷
1 2 3 4 5 6 7 | time.sleep(2) #加个延时给反应时间用样按你的网速定 driver.get(o)#打开账号1的交卷地址 time.sleep(1)#延时 """这三步是提取文字 先弄成列表 再用切片 再弄回来 .join()方法 可以用正则一步就行""" a = driver.execute_script("return document.documentElement.outerHTML") b = a[126:166] c = ("".join(b)) |
- 图就不弄了因为是漏洞明放出不好 看不懂代码问我
账号2进入错题界面
1 2 3 4 | #可以在这里加个延时 drs.get("http://tiku."+c)#进入错题界面 time.sleep(1) drs.find_element_by_xpath("/html/body/div[2]/div/div[2]/div/div[2]/div[2]/div[2]/ul/li[1]/a").click() #点击查看解析 #到这里就是错题界面了 |
不上图了太麻烦 最后直接一个效果图
- 效果
拿到正确答案
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | aa = []#创建一个空列表用于放答案 """下面内容可以改用正则 用正则的话一行完事 为了照顾新手我用本方法想看正则写法找我要""" #共20道题 每道题爬获取所有答案的文本格式 位置是从2往下延伸,2是第一题一直的到20题是21 for里到22的目的是为了执行下面except: for f in range(2, 23): try: if f <= 22: #把答案爬下来 并且把生成的列表格式化为1234类型 xx =drs.find_element_by_xpath("/html/body/div[2]/div/div[2]/div["+str(f)+"]/div[3]/label/em").text #循环f用2开始(xpath2是第一道题3是第二道以次类推)每次循环都拿到正确答案存入aa列表中 if xx=="A": aa.append("1") elif xx=="B": aa.append("2") elif xx=="C": aa.append("3") elif xx=="D": aa.append("4") elif xx=="A,B": aa.append("1,2") elif xx=="C,D": aa.append("3,4") elif xx=="A,C": aa.append("1,3") elif xx=="A,D": aa.append("1,4") elif xx=="B,C": aa.append("2,3") elif xx=="B,D": aa.append("2,4") |
回到账号1将爬取的到正确答案选上
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | except: #回到原有账号这里 开始答题 for F in range(2, 22): # 把所有可能性加进去 XX = F - 2 #因为列表索引是从0开始所以要减2 print("第" + str(XX) + "题答案获取中") FF = aa[XX] if F <= 22: """下面的就是千篇一律将正确答案在账号1以上选上 注意dr和drs 可以用正则表达式拿到全部选项位置用列表推导式点上""" if FF == "1,2": dr.find_element_by_xpath("/html/body/div[2]/div/div/div[2]/div[" + str(F) + "]/ul/li[1]/pre/input").click() dr.find_element_by_xpath("/html/body/div[2]/div/div/div[2]/div[" + str(F) + "]/ul/li[2]/pre/input").click() elif FF == "3,4": dr.find_element_by_xpath("/html/body/div[2]/div/div/div[2]/div[" + str(F) + "]/ul/li[3]/pre/input").click() dr.find_element_by_xpath("/html/body/div[2]/div/div/div[2]/div[" + str(F) + "]/ul/li[4]/pre/input").click() elif FF == "1,3": dr.find_element_by_xpath("/html/body/div[2]/div/div/div[2]/div[" + str(F) + "]/ul/li[1]/pre/input").click() dr.find_element_by_xpath("/html/body/div[2]/div/div/div[2]/div[" + str(F) + "]/ul/li[3]/pre/input").click() elif FF == "1,4": """千篇一律,不全弄了自己写所有可能性""" |