mirror of https://github.com/testerSunshine/12306
parent
fd2f691ce3
commit
bd30d7e457
|
@ -1,51 +0,0 @@
|
||||||
<component name="InspectionProjectProfileManager">
|
|
||||||
<profile version="1.0">
|
|
||||||
<option name="myName" value="Project Default" />
|
|
||||||
<inspection_tool class="PyPackageRequirementsInspection" enabled="true" level="WARNING" enabled_by_default="true">
|
|
||||||
<option name="ignoredPackages">
|
|
||||||
<value>
|
|
||||||
<list size="13">
|
|
||||||
<item index="0" class="java.lang.String" itemvalue="nose" />
|
|
||||||
<item index="1" class="java.lang.String" itemvalue="locust" />
|
|
||||||
<item index="2" class="java.lang.String" itemvalue="selenium" />
|
|
||||||
<item index="3" class="java.lang.String" itemvalue="locustio" />
|
|
||||||
<item index="4" class="java.lang.String" itemvalue="pymssql" />
|
|
||||||
<item index="5" class="java.lang.String" itemvalue="python-hessian" />
|
|
||||||
<item index="6" class="java.lang.String" itemvalue="suds" />
|
|
||||||
<item index="7" class="java.lang.String" itemvalue="DBUtils" />
|
|
||||||
<item index="8" class="java.lang.String" itemvalue="MySQL-python" />
|
|
||||||
<item index="9" class="java.lang.String" itemvalue="redis" />
|
|
||||||
<item index="10" class="java.lang.String" itemvalue="redis_py_cluster" />
|
|
||||||
<item index="11" class="java.lang.String" itemvalue="requests" />
|
|
||||||
<item index="12" class="java.lang.String" itemvalue="APScheduler" />
|
|
||||||
</list>
|
|
||||||
</value>
|
|
||||||
</option>
|
|
||||||
</inspection_tool>
|
|
||||||
<inspection_tool class="PyPep8Inspection" enabled="true" level="WEAK WARNING" enabled_by_default="true">
|
|
||||||
<option name="ignoredErrors">
|
|
||||||
<list>
|
|
||||||
<option value="E501" />
|
|
||||||
</list>
|
|
||||||
</option>
|
|
||||||
</inspection_tool>
|
|
||||||
<inspection_tool class="PyPep8NamingInspection" enabled="true" level="WEAK WARNING" enabled_by_default="true">
|
|
||||||
<option name="ignoredErrors">
|
|
||||||
<list>
|
|
||||||
<option value="N801" />
|
|
||||||
<option value="N803" />
|
|
||||||
<option value="N806" />
|
|
||||||
<option value="N802" />
|
|
||||||
</list>
|
|
||||||
</option>
|
|
||||||
</inspection_tool>
|
|
||||||
<inspection_tool class="PyUnresolvedReferencesInspection" enabled="true" level="WARNING" enabled_by_default="true">
|
|
||||||
<option name="ignoredIdentifiers">
|
|
||||||
<list>
|
|
||||||
<option value="list.__setitem__" />
|
|
||||||
<option value="dict.json" />
|
|
||||||
</list>
|
|
||||||
</option>
|
|
||||||
</inspection_tool>
|
|
||||||
</profile>
|
|
||||||
</component>
|
|
|
@ -1,14 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project version="4">
|
|
||||||
<component name="CoverageDataManager">
|
|
||||||
<SUITE FILE_PATH="coverage/12306$Nosetests_for_TestAll_testAll_testLogin.coverage" NAME="Nosetests for TestAll.testAll.testLogin Coverage Results" MODIFIED="1547517351085" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$/UnitTest" />
|
|
||||||
<SUITE FILE_PATH="coverage/12306$pushbearConf.coverage" NAME="pushbearConf Coverage Results" MODIFIED="1547607924184" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$/config" />
|
|
||||||
<SUITE FILE_PATH="coverage/12306$XiaomiRouter.coverage" NAME="XiaomiRouter Coverage Results" MODIFIED="1547958003325" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$/config" />
|
|
||||||
<SUITE FILE_PATH="coverage/12306$cdn_utils.coverage" NAME="cdn_utils Coverage Results" MODIFIED="1547546064988" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$/agency" />
|
|
||||||
<SUITE FILE_PATH="coverage/12306$select_ticket_info.coverage" NAME="select_ticket_info Coverage Results" MODIFIED="1547545588185" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$/init" />
|
|
||||||
<SUITE FILE_PATH="coverage/12306$AutoCode.coverage" NAME="AutoCode Coverage Results" MODIFIED="1547991393078" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$/damatuCode" />
|
|
||||||
<SUITE FILE_PATH="coverage/12306$GetPassCodeNewOrderAndLogin.coverage" NAME="GetPassCodeNewOrderAndLogin Coverage Results" MODIFIED="1554299912823" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$/inter" />
|
|
||||||
<SUITE FILE_PATH="coverage/12306$run.coverage" NAME="run Coverage Results" MODIFIED="1555334112595" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" />
|
|
||||||
<SUITE FILE_PATH="coverage/12306$TPLinkRouter.coverage" NAME="TPLinkRouter Coverage Results" MODIFIED="1547990820548" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$/config" />
|
|
||||||
</component>
|
|
||||||
</project>
|
|
18
README.md
18
README.md
|
@ -5,9 +5,11 @@
|
||||||
- [ ] 2.7.9
|
- [ ] 2.7.9
|
||||||
|
|
||||||
#### 依赖库
|
#### 依赖库
|
||||||
- 依赖若快 若快注册地址:http://www.ruokuai.com/client/index?6726 推荐用若快,请注册个人账号
|
- 验证码目前可以本地识别,需要下载模型,放于项目更目录,全部代码来源于此项目 [传送门](https://github.com/zhaipro/easy12306),表示感谢
|
||||||
```
|
```
|
||||||
PS: 现在登录有一定几率不用验证码了,
|
PS:
|
||||||
|
1. 模型下载链接:https://pan.baidu.com/s/1rS155VjweWVWIJogakechA 密码:bmlm
|
||||||
|
群里面也可以下载
|
||||||
```
|
```
|
||||||
- 项目依赖包查看 requirements.txt
|
- 项目依赖包查看 requirements.txt
|
||||||
- 安装方法-Windows:
|
- 安装方法-Windows:
|
||||||
|
@ -97,6 +99,14 @@
|
||||||
mac gui and windows gui 下载链接:https://pan.baidu.com/s/1SbVJWxiwP27yb8HUi1kzDQ 密码:41wp
|
mac gui and windows gui 下载链接:https://pan.baidu.com/s/1SbVJWxiwP27yb8HUi1kzDQ 密码:41wp
|
||||||
```
|
```
|
||||||
- 自动更换ip软件目前已支持TPLINK和小米路由器,只限家庭网络[点我跳转](https://github.com/testerSunshine/AutoRouterIP)
|
- 自动更换ip软件目前已支持TPLINK和小米路由器,只限家庭网络[点我跳转](https://github.com/testerSunshine/AutoRouterIP)
|
||||||
|
- 关于登录接口需要识别DEVICES_ID的情况,可以使用本地打开12306,在任意一接口里面抓取DEVICES_ID,填于login.py文件中的141行
|
||||||
|
```
|
||||||
|
原来的 devicesId = eval(devicesIdRsp.split("(")[1].split(")")[0].replace("'", ""))["dfp"]
|
||||||
|
更换为 devicesId = 刚才抓取的DEVICES_ID填上即可
|
||||||
|
```
|
||||||
|
- 浏览器截图
|
||||||
|

|
||||||
|
|
||||||
#### 感谢一下小伙伴对本项目提供的帮助
|
#### 感谢一下小伙伴对本项目提供的帮助
|
||||||
- @sun7127@126.com
|
- @sun7127@126.com
|
||||||
- @ 才
|
- @ 才
|
||||||
|
@ -104,7 +114,3 @@
|
||||||
- 以及所有为此项目提供pr的同学
|
- 以及所有为此项目提供pr的同学
|
||||||
#### 更新日志
|
#### 更新日志
|
||||||
- [更新日志](Update.md)
|
- [更新日志](Update.md)
|
||||||
|
|
||||||
#### 如果觉得项目还不错,可以考虑打赏一波
|
|
||||||
- 
|
|
||||||
- 
|
|
||||||
|
|
|
@ -149,3 +149,6 @@
|
||||||
|
|
||||||
- 2019.04.23更新
|
- 2019.04.23更新
|
||||||
- 修复登录302问题,如果下次没来得及更新,请自行抓包修改urlConf中getDevicesId接口即可登录
|
- 修复登录302问题,如果下次没来得及更新,请自行抓包修改urlConf中getDevicesId接口即可登录
|
||||||
|
|
||||||
|
- 2019.04.23更新
|
||||||
|
- 更新本地识别
|
||||||
|
|
|
@ -139,7 +139,7 @@ urls = {
|
||||||
"is_json": False,
|
"is_json": False,
|
||||||
},
|
},
|
||||||
"getDevicesId": { # 获取用户信息
|
"getDevicesId": { # 获取用户信息
|
||||||
"req_url": "/otn/HttpZF/logdevice?algID=pKLII3uPX6&hashCode=w0gl_WcMRdpcp8OVHljAtCv2bIz0TUXYjBqPjrXX8og&FMQw=0&q4f3=zh-CN&VySQ=FGGnyDds9R8yEU-K-VRgvF-LXI74dn56&VPIf=1&custID=133&VEek=unknown&dzuS=0&yD16=1&EOQP=c227b88b01f5c513710d4b9f16a5ce52&jp76=69f27b80c0ec8437d2a1f4278674e7fb&hAqN=MacIntel&platform=WEB&ks0Q=e848b8c6800147e416e6663782ca3789&TeRS=831x1440&tOHY=24xx900x1440&Fvje=i1l1o1s1&q5aJ=-8&wNLf=99115dfb07133750ba677d055874de87&0aew=Mozilla/5.0%20(Macintosh;%20Intel%20Mac%20OS%20X%2010_13_4)%20AppleWebKit/605.1.15%20(KHTML,%20like%20Gecko)%20Version/11.1%20Safari/605.1.15&E3gR=a70e835beef705b96a6e51c6ebd50cd4×tamp={0}",
|
"req_url": "/otn/HttpZF/logdevice?algID=3yxNoRW8BM&hashCode=8EFUGZrjK3cO8VdDugvPxyyiUqMNmKhl6pbW1ftnEVI&FMQw=0&q4f3=zh-CN&VPIf=1&custID=133&VEek=unknown&dzuS=0&yD16=0&EOQP=c227b88b01f5c513710d4b9f16a5ce52&lEnu=2887005765&jp76=52d67b2a5aa5e031084733d5006cc664&hAqN=MacIntel&platform=WEB&ks0Q=d22ca0b81584fbea62237b14bd04c866&TeRS=1013x1920&tOHY=24xx1080x1920&Fvje=i1l1o1s1&q5aJ=-8&wNLf=99115dfb07133750ba677d055874de87&0aew=Mozilla/5.0%20(Macintosh;%20Intel%20Mac%20OS%20X%2010_14_4)%20AppleWebKit/537.36%20(KHTML,%20like%20Gecko)%20Chrome/74.0.3729.131%20Safari/537.36&E3gR=d4c1ccb1725a4a45cc350f16ac26f32b×tamp={0}",
|
||||||
"req_type": "get",
|
"req_type": "get",
|
||||||
"Referer": "https://kyfw.12306.cn/otn/passport?redirect=/otn/",
|
"Referer": "https://kyfw.12306.cn/otn/passport?redirect=/otn/",
|
||||||
"Host": "kyfw.12306.cn",
|
"Host": "kyfw.12306.cn",
|
||||||
|
|
|
@ -127,17 +127,12 @@ class GoLogin:
|
||||||
:param passwd: 密码
|
:param passwd: 密码
|
||||||
:return:
|
:return:
|
||||||
"""
|
"""
|
||||||
# if self.is_auto_code and self.auto_code_type == 1:
|
|
||||||
# balance = DamatuApi(_get_yaml()["auto_code_account"]["user"], _get_yaml()["auto_code_account"]["pwd"]).getBalance()
|
|
||||||
# if int(balance) < 40:
|
|
||||||
# raise balanceException(u'余额不足,当前余额为: {}'.format(balance))
|
|
||||||
user, passwd = _get_yaml()["set"]["12306account"][0]["user"], _get_yaml()["set"]["12306account"][1]["pwd"]
|
user, passwd = _get_yaml()["set"]["12306account"][0]["user"], _get_yaml()["set"]["12306account"][1]["pwd"]
|
||||||
if not user or not passwd:
|
if not user or not passwd:
|
||||||
raise UserPasswordException(u"温馨提示: 用户名或者密码为空,请仔细检查")
|
raise UserPasswordException(u"温馨提示: 用户名或者密码为空,请仔细检查")
|
||||||
login_num = 0
|
login_num = 0
|
||||||
while True:
|
while True:
|
||||||
if loginConf(self.session):
|
if loginConf(self.session):
|
||||||
# result = getPassCodeNewOrderAndLogin(session=self.session, imgType="login")
|
|
||||||
self.auth()
|
self.auth()
|
||||||
|
|
||||||
devicesIdUrl = copy.deepcopy(self.session.urls["getDevicesId"])
|
devicesIdUrl = copy.deepcopy(self.session.urls["getDevicesId"])
|
||||||
|
@ -151,6 +146,7 @@ class GoLogin:
|
||||||
if not result:
|
if not result:
|
||||||
continue
|
continue
|
||||||
self.randCode = getRandCode(self.is_auto_code, self.auto_code_type, result)
|
self.randCode = getRandCode(self.is_auto_code, self.auto_code_type, result)
|
||||||
|
print(self.randCode)
|
||||||
login_num += 1
|
login_num += 1
|
||||||
self.auth()
|
self.auth()
|
||||||
if self.codeCheck():
|
if self.codeCheck():
|
||||||
|
@ -162,9 +158,3 @@ class GoLogin:
|
||||||
loginAysnSuggest(self.session, username=user, password=passwd)
|
loginAysnSuggest(self.session, username=user, password=passwd)
|
||||||
login_num += 1
|
login_num += 1
|
||||||
break
|
break
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# if __name__ == "__main__":
|
|
||||||
# # main()
|
|
||||||
# # logout()
|
|
|
@ -2,7 +2,8 @@
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
from config.ticketConf import _get_yaml
|
from config.ticketConf import _get_yaml
|
||||||
from damatuCode.ruokuai import RClient
|
from verify.localVerifyCode import verify
|
||||||
|
from verify.ruokuai import RClient
|
||||||
|
|
||||||
try:
|
try:
|
||||||
raw_input # Python 2
|
raw_input # Python 2
|
||||||
|
@ -21,16 +22,8 @@ def getRandCode(is_auto_code, auto_code_type, result):
|
||||||
print(u"打码兔已关闭, 如需使用自动识别,请使用如果平台 auto_code_type == 2")
|
print(u"打码兔已关闭, 如需使用自动识别,请使用如果平台 auto_code_type == 2")
|
||||||
return
|
return
|
||||||
if auto_code_type == 2:
|
if auto_code_type == 2:
|
||||||
rc = RClient(_get_yaml()["auto_code_account"]["user"], _get_yaml()["auto_code_account"]["pwd"])
|
Result = verify(result)
|
||||||
# im = open('./tkcode', 'rb').read()
|
return codexy(Ofset=Result, is_raw_input=False)
|
||||||
# Result = rc.rk_create(result, 6113)
|
|
||||||
Result = rc.rk_create_base64(result, 6113)
|
|
||||||
if "Result" in Result:
|
|
||||||
return codexy(Ofset=",".join(list(Result["Result"])), is_raw_input=False)
|
|
||||||
else:
|
|
||||||
if "Error" in Result and Result["Error"]:
|
|
||||||
print(u"打码平台错误: {0}, 请登录打码平台查看-http://www.ruokuai.com/client/index?6726".format(Result["Error"]))
|
|
||||||
return ""
|
|
||||||
else:
|
else:
|
||||||
img = Image.open('./tkcode.png')
|
img = Image.open('./tkcode.png')
|
||||||
img.show()
|
img.show()
|
||||||
|
@ -56,6 +49,9 @@ def codexy(Ofset=None, is_raw_input=True):
|
||||||
print(u"如果是linux无图形界面,请使用自动打码,is_auto_code: True")
|
print(u"如果是linux无图形界面,请使用自动打码,is_auto_code: True")
|
||||||
print(u"如果没有弹出验证码,请手动双击根目录下的tkcode.png文件")
|
print(u"如果没有弹出验证码,请手动双击根目录下的tkcode.png文件")
|
||||||
Ofset = raw_input(u"输入对应的验证码: ")
|
Ofset = raw_input(u"输入对应的验证码: ")
|
||||||
|
if isinstance(Ofset, list):
|
||||||
|
select = Ofset
|
||||||
|
else:
|
||||||
Ofset = Ofset.replace(",", ",")
|
Ofset = Ofset.replace(",", ",")
|
||||||
select = Ofset.split(',')
|
select = Ofset.split(',')
|
||||||
post = []
|
post = []
|
||||||
|
|
|
@ -170,5 +170,4 @@ class HTTPClient(object):
|
||||||
pass
|
pass
|
||||||
except socket.error:
|
except socket.error:
|
||||||
pass
|
pass
|
||||||
print(error_data.get("massage"))
|
|
||||||
return error_data
|
return error_data
|
||||||
|
|
BIN
tkcode.png
BIN
tkcode.png
Binary file not shown.
Before Width: | Height: | Size: 1.5 KiB After Width: | Height: | Size: 12 KiB |
Loading…
Reference in New Issue