12306 selenium 模拟登录
# 下面是12306 实现的模拟登陆
# 解码 应用超级鹰,注册用户,左侧栏软件ID进去,开启一个新软件,拿到软件ID
# 下面测试都在jupyter里面实现
# 超级鹰类 cell
import requests
from hashlib import md5 class Chaojiying_Client(object): def __init__(self, username, password, soft_id):
self.username = username
password = password.encode('utf8')
self.password = md5(password).hexdigest()
self.soft_id = soft_id
self.base_params = {
'user': self.username,
'pass2': self.password,
'softid': self.soft_id,
}
self.headers = {
'Connection': 'Keep-Alive',
'User-Agent': 'Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0)',
} def PostPic(self, im, codetype): params = {
'codetype': codetype,
}
params.update(self.base_params)
files = {'userfile': ('ccc.jpg', im)}
r = requests.post('http://upload.chaojiying.net/Upload/Processing.php', data=params, files=files, headers=self.headers)
print(r.json()) #{'err_no': 0, 'err_str': 'OK', 'pic_id': '9067216592371000003', 'pic_str': '24,62|40,146|112,141', 'md5': 'c4ee4d4fb269521c47de228d5c6d6d3e'}
return r.json() def ReportError(self, im_id): params = {
'id': im_id,
}
params.update(self.base_params)
r = requests.post('http://upload.chaojiying.net/Upload/ReportError.php', data=params, headers=self.headers) return r.json()
# 下面是12306 页面的处理
from selenium import webdriver
import time
import requests
from lxml import etree
from urllib import request
from selenium.webdriver.common.action_chains import ActionChains
from PIL import Image
bro = webdriver.Chrome(executable_path='./chromedriver.exe')
bro.get('https://kyfw.12306.cn/otn/login/init')
# page_text = bro.page_source
# tree = etree.HTML(page_text)
# code_img_src = tree.xpath('//*[@id="loginForm"]/div/ul[2]/li[4]/div/div/div[3]/img/@src')[0]
# print(code_img_src)
# request.urlretrieve(url=code_img_src,filename='./code.jpg')
time.sleep(3) code_img_ele = bro.find_element_by_xpath('//*[@id="loginForm"]/div/ul[2]/li[4]/div/div/div[3]/img') #找见验证码区域
time.sleep(3)
location = code_img_ele.location # x,y
print('--',location) # -- {'x': 274, 'y': 274}
size = code_img_ele.size
print('++',location) # ++ {'x': 274, 'y': 274}
rangle = (int(location['x']),int(location['y']),int(location['x']+size['width']),int(location['y']+size['height'])) #验证码图裁剪区域 矩形
print('**',rangle) #矩形 四点 像素值
bro.save_screenshot('aa.png') # 快照 整张页面截图
# 指定区域的截图
i = Image.open('./aa.png') #打开图片
code_img_name = 'code.png' #最终验证码裁剪出来的保存名称
frame = i.crop(rangle) #裁剪
frame.save(code_img_name) #裁剪成功的图片保存
# 将验证码图片提交给 超级鹰 处理 先实例化
chaojiying = Chaojiying_Client('超级鹰账号', '超级鹰密码', '软件ID')#超级鹰用户中心>>软件ID 生成一个替换上
im = open('./code.png','rb').read() #读取验证码图片
result = chaojiying.PostPic(im, 9004)['pic_str'] # 返回坐标
# 'x1,y1|x2,y2' 'x,y' result值 转换成[['x','y']] [['x1','y1'],['x2','y2']]
all_list = []
if '|' in result:
list_1 = result.split('|')
count_1 = len(list_1)
for i in range(count_1):
xy_list = []
x = int(list_1[i].split(',')[0])
y = int(list_1[i].split(',')[1])
xy_list.append(x)
xy_list.append(y)
all_list.append(xy_list) else:
x = int(result.split(',')[0])
print(x)
y = int(result.split(',')[1])
xy_list = []
xy_list.append(x)
xy_list.append(y)
all_list.append(xy_list)
print(all_list) # [[24, 62], [40, 146], [112, 141]] 坐标位置
#code_img = bro.find_element_by_xpath('//*[@id="loginForm"]/div/ul[2]/li[4]/div/div/div[3]/img')
action = ActionChains(bro) #动作链 实例化一个对象 for l in all_list:
x = l[0]
y = l[1]
ActionChains(bro).move_to_element_with_offset(code_img_ele,x,y).click().perform() bro.find_element_by_id('username').send_keys('') #12306账号
time.sleep(2)
bro.find_element_by_id('password').send_keys('') #12306密码
time.sleep(2)
bro.find_element_by_id('loginSub').click()
time.sleep(10)
bro.quit() # 退出
12306 selenium 模拟登录的更多相关文章
- 4 使用Selenium模拟登录csdn,取出cookie信息,再用requests.session访问个人中心(保持登录状态)
代码: # -*- coding: utf-8 -*- """ Created on Fri Jul 13 16:13:52 2018 @author: a " ...
- 3 使用selenium模拟登录csdn
之前通过F12开发者模式调试,获取网站后台服务器验证用户名和密码的URL之后,再构造post数据的方式会存在一个问题,就是对目标网站的验证机制不明确,构造post数据除了用户名和密码之外,还可能有更复 ...
- 使用Python+Selenium模拟登录QQ空间
使用Python+Selenium模拟登录QQ空间爬QQ空间之类的页面时大多需要进行登录,研究QQ登录规则的话,得分析大量Javascript的加密解密,这绝对能掉好几斤头发.而现在有了seleniu ...
- selenium模拟登录豆瓣和qq空间
selenium模拟登录豆瓣和qq空间今天又重新学习了下selenium,模拟登录豆瓣,发现设置等待时间真的是很重要的一步,不然一直报错:selenium.common.exceptions.NoSu ...
- 使用selenium模拟登录知乎
网上流传着许多抓取知乎数据的代码,抓取它的数据有一个问题一定绕不过去,那就是模拟登录,今天我们就来聊聊知乎的模拟登录. 获取知乎内容的方法有两种,一种是使用request,想办法携带cookies等必 ...
- 使用selenium模拟登录12306网站
1 import yh 2 from selenium import webdriver 3 from PIL import Image 4 # from selenium.webdriver imp ...
- 九、Python+Selenium模拟登录
研究QQ登录规则的话,得分析大量Javascript的加密解密,比较耗时间.自己也是练习很少,短时间成功不了.所以走了个捷径. Selenium是一个WEB自动化测试工具,它运行时会直接实例化出一个浏 ...
- python selenium模拟登录163邮箱和QQ空间
最近在看python网络爬虫,于是我想自己写一个邮箱和QQ空间的自动登录的小程序, 下面以登录163邮箱和QQ空间和为例: 了解到在Web应用中经常会遇到frame/iframe 表单嵌套页面的应用, ...
- 验证码破解 | Selenium模拟登录简书
使用超级鹰打码平台处理登录的文字点击验证码 import time from io import BytesIO from PIL import Image from selenium import ...
随机推荐
- echart --toolbox
1.自定义的toolbox 消息回调 toolbox: { show: true, itemSize: 32, borderColor: '#0cb1b6', borderWidth: 1, bord ...
- C++——二维数组和对象数组
6.3 二维数组的声明和引用 声明:数据类型 标识符[常量表达式1][常量表达式2]:int a[3][4]; 表示a为整型二维数组,其中第一维有3个下标(0~2),第二维有4个下标(0~3),数组元 ...
- adb logcat日志抓取
adb命令 logcat日志抓取 一.logcat抓log方法:adb logcat命令,可以加条件过滤 1.安装SDK(参考android sdk环境安装) 2.使用数据线链接手机,在手机助手的sd ...
- 剑指offer 面试题43. 1~n整数中1出现的次数
leetcode上也见过一样的题,当时不会做 看了一下解法是纯数学解法就没看,结果剑指offer上也出现了这道题,那还是认真看下吧 对于数字abcde,如果第一位是1,比如12345,即计算f(123 ...
- python3爬取高清壁纸(1)
这次爬取的目标是:美桌网首页 > 桌面壁纸 > 卡通动漫 类别下的壁纸. 我们先随机选取一个专辑来爬(http://www.win4000.com/wallpaper_detail_545 ...
- MTV与MVC模式
MTV模型(django) M:模型层(models.py) 负责业务对象与数据库的对象(orm) T:templates 负责如何把页面展示给用户 V:views 负责业务逻辑,并在适当的时候调用m ...
- AcWing 8.二维费用的背包问题
#include<iostream> #include<algorithm> #include<cstring> using namespace std ; ; i ...
- [人物存档]【AI少女】【捏脸数据】人物鉴赏190
AISChaF_20200201011129905.png AISChaF_20200123004135233.png
- awk从放弃到入门(2):awk分隔符
一.awk分隔符 awk的默认分割符是空格,但是,这样描述并不精确,因为,awk的分隔符还分为两种,"输入分隔符" 和 "输出分隔符" . (1)输入分隔符:英 ...
- Makefile export
1) 1.在(parent,上层的)makefile中export出来变量,子makefile(sub make)中,是可以访问的. 2. 而同一级别的makefile(可通过makefile中内置变 ...