Python 实现12306登录功能实例代码
作者:獨荹儛臨 发布时间:2021-04-07 08:55:35
标签:python,12306,登录
下面一段代码给大家带来了python实现12306登录功能,具体代码如下所示:
#!/usr/bin/env python
import requests
import urllib.parse
import random
import time
req = requests.session()
import sys
import re
import urllib3
import getpass # 密文输入
urllib3.disable_warnings()
# 登陆-------------------------
apptklist = []
newStrList = []
def signin():
ran = random.uniform(1, 0)
imgUrl = ('https://kyfw.12306.cn/passport/captcha/captcha-image?'
'login_site=E&module=login&rand=sjrand&%s' % ran)
print(imgUrl)
imgresponse = req.get(url=imgUrl, verify=False)
codeimg = imgresponse.content
fn = open('code.png', 'wb')
fn.write(codeimg)
fn.close()
codeStr = input('请输入验证码的坐标:')
a = ''
b = ''
c = ''
d = ''
e = ''
f = ''
g = ''
h = ''
if '1' in codeStr:
a = '37,37,'
if '2' in codeStr:
b = '100,37,'
if '3' in codeStr:
c = '180,37,'
if '4' in codeStr:
d = '250,37,'
if '5' in codeStr:
e = '37,100,'
if '6' in codeStr:
f = '100,100,'
if '7' in codeStr:
g = '180,100,'
if '8' in codeStr:
h = '250,100,'
newCodeStr = a+b+c+d+e+f+g+h
newStr = newCodeStr[:-1]
newStrList.append(newStr)
url = 'https://kyfw.12306.cn/passport/captcha/captcha-check'
data = {
'answer':newStr,
'login_site':'E',
'rand':'sjrand'
}
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko)'
' Chrome/63.0.3239.108 Safari/537.36',
}
response = req.post(url=url, data=data, headers=headers, verify=False)
print('检测图片-----------', url)
print(response.text)
result = response.json()
if result['result_code'] == '4':
print('验证码校验成功')
else:
print('验证码校验失败,请注意填写正确的坐标')
signin()
return
userName = input('Please input your userName:')
# password = input('Please input your password:')
password = getpass.getpass('Please input your password:')
loginData = {
'username':userName,
'password':password,
'appid':'otn'
}
headers = {
'Host':'kyfw.12306.cn',
'Referer':'https://kyfw.12306.cn/otn/login/init',
'User-Agent':'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_2)'
' AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 '
'Safari/537.36'
}
response = req.post('https://kyfw.12306.cn/passport/web/login', data=loginData, headers=headers, verify=False)
print('--------------登陆中--------------------')
print('https://kyfw.12306.cn/passport/web/login')
print('response', response.text.encode('utf-8').decode('utf-8'))
fd = open("locate.html", 'wb+')
fd.write(response.content)
yzData = {
'appid':'otn'
}
response = req.post('https://kyfw.12306.cn/passport/web/auth/uamtk', data=yzData, headers=headers, verify=False)
print('---------------------第一次验证---------------------')
print(response.text)
# print('typeof response',type(response))
loginMessage = response.json()['newapptk']
print('loginMessage=', loginMessage)
# 第二次验证开始++++++++++++++++++++++++++++++
yz2Data = {
'tk': loginMessage
}
response = req.post('https://kyfw.12306.cn/otn/uamauthclient', data=yz2Data, headers=headers,verify=False)
print('---------------------第二次验证---------------------')
print(response.text)
apptk = response.json()['apptk']
apptklist.append(apptk)
def buy():
print(newStrList)
req.headers['Referer'] = 'https://kyfw.12306.cn/otn/leftTicket/init'
result = req.post('https://kyfw.12306.cn/otn/login/checkUser')
print('----------------购票系统--------------')
print(result.text)
print('验证登录状态成功checkUser')
headers = {
'Referer':'https://kyfw.12306.cn/otn/leftTicket/init',
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36'
' (KHTML, like Gecko) Chrome/63.0.3239.84 Safari/537.36',
}
data = {
# 'secretStr':reserve[1],
'train_date':'2018-01-17',
'back_train_date':'2018-01-17',
'tour_flag':'dc', # dc 单程
'purpose_codes':'ADULT', # adult 成人票
'query_from_station_name':'成都',
'query_to_station_name':'长沙',
'undefined':''
}
def ticket():
# 先登陆、然后查询车票信息
signin()
url = ('https://kyfw.12306.cn/otn/leftTicket/queryZ?leftTicketDTO.train_date=2018-02-10&'
'leftTicketDTO.from_station=SZQ&leftTicketDTO.to_station=NFG&purpose_codes=ADULT')
try:
response = requests.get(url, verify=False)
result = response.json()
print(result)
return result['data']['result']
except Exception as e:
return None
if __name__ == "__main__":
# ticket()
# with open('./aaa.xlsx', encoding='utf-8') as f:
#
# print(f.read())
dic = {}
context = [('IDS_ABOUT_OFFICAL_PHONE', 'Službeni telefon'),
('IDS_ABOUT_OFFICAL_WEBSITE', 'Službeno web-mjesto'),
('IDS_ABOUT_OFFICIAL_PHONE_CALL_NOT_SUPPORT', 'Trenutni uređaj ne može pozivati.')]
for i in range(len(context)):
print(i)
dic.setdefault(context[i][0],context[i][1])
print(dic)
print(dic.keys())
总结
以上所述是小编给大家介绍的Python 实现12306登录实例代码网站的支持!
来源:https://www.jianshu.com/p/f2baaf0751d9
0
投稿
猜你喜欢
- 良好的编程习惯是每个程序员都应该具备的工作素质,在我的软件生涯中屡屡发现一些程序员的身上总有这样或者那样的坏毛病。这些毛病在一些从业时间不是
- 去听了牛人 dbaron 的一个 Web Page Layout/Display in Mozilla 讲座( via )。讲的东西对我一个
- 技术栈win7+python3+selenium之前有个需求需要实现自动化提流程,为了在任何电脑都能实现该功能,特此写了个爬虫,并将其打包成
- 你喜欢在博客文章中使用图片吗?是的,如果不是很麻烦的话,相信大家都不会介意放上几张漂亮的图片来点缀一下内容的,不过你的图片可能会导致下面的两
- 原文地址:30 Days of Mootools 1.2 Tutorials - Day 19 - TooltipsMootools 1.2
- 虽然说表单验证在客户端使用javascript来验证已经可以了,但是我们为了防止访客绕过客户端验证也为了数据安全最好还是在服务器端加上必要的
- 上一讲完成了基本博客的配置和项目工程的生成。这次开始将博客一些基本的操作主要是数据库方面学习。1.设计博客数据库表结构博客最主要的功能就是展
- 今天的问题是请问以下 alert 弹出值分别是什么?var f = function f2()&nb
- 01-初心缘由最近在研究语音识别方向,看了很多的语音识别的资料和文章,了解了一下语音识别的前世今生,其中包含了很多算法的演变,目前来说最流行
- key_buffer_size - 这对MyISAM表来说非常重要。如果只是使用MyISAM表,可以把它设置为可用内存的 30-40%。合理
- 数据库连接字符串的常见问题和解决方法:基本知识1:SQL Server数据库的身份验证方式,分windows验证,SQL Server验证两
- 本文实例讲述了Python使用re模块正则提取字符串中括号内的内容操作。分享给大家供大家参考,具体如下:直接上代码吧:# -*- codin
- WebSocket的作用WebSock其实在平常使用,我们是时常见到的,用于实时通讯,例如我们常用的实时聊天、服务端向客户端消息推送、也可以
- 触发器权限和所有权CREATE TRIGGER 权限默认授予定义触发器的表所有者、sysadmin 固定服务器角色成员以及 db_owner
- 看网络小说一般会攒上一波,然后导入Kindle里面去看,但是攒的多了,机械的Ctrl+C和Ctrl+V实在是OUT,所以就出现了此文。其实P
- 本文实例讲述了Python Web框架之Django框架cookie和session用法。分享给大家供大家参考,具体如下:part 1 概念
- 本文实例讲述了PHP学习记录之面向对象(Object-oriented programming,OOP)基础。分享给大家供大家参考,具体如下
- 概 述 ---- 现在有不少介绍利用ASP实现动态分页的文章,方法大同小异,就是每次利用ADO返回原始
- 用dicompyler软件打开dicom图像,头文件如图所示:当然也可以直接读取:ds = dicom.read_file('H:\
- 一、 软件介绍 DB2MYSQL是一个可以自动将ACCESS数据库文件转化为对应的SQL代码的软件。可广泛应用于ACCESS数据库转换为MY