用python登录Dr.com思路以及代码分享


Posted in Python onJune 25, 2014

前提:isp得支持web登录的方式。

说明:每个ISP的登录页面不一样,不过我估计算法都是一样的,于是解决方案应该也是相似的,只是表单的key可能不太一样。

首先,分析登录页面。

页面head镶嵌了<script>标签,所有的提交相关的脚本都在这里。页面关键部分是两个表单:f1和f0。整个f0是看不见的,但是点击f1的提交时,会直接调用f0的提交而不是提交自己。表单的table布局就不吐槽了...

部分HTML

<form name="f1" method="post" action="" onsubmit="return ee()">
<table border="0" width="100%" cellspacing="1" cellpadding="0" height="100%" class="f1">
...
<tr>
<td height="34" width="35%" align="right">账号 Account </td><td height="34" width="64%"> <input name="DDDDD" type="text" maxlength="26" class="input-border"></td>
</tr>

<tr>
<td height="32" width="35%" align="right">密码 Password </td><td height="32" width="64%"> <input name="upass" type="password" maxlength="16" class="input-border"></td>
</tr>

<tr>
<td height="57" width="35%"> </td><td height="57" width="64%"> <input type="submit" name="0MKKey" value="" onclick="cc(0)" class="login-b">  <input type="submit" name="" value="" onclick="reset();return false;"></td>
</tr>
...
</form>

这里可以看见,点击submit的时候,调用cc(0),提交的时候调用ee()函数

部分js:

function cc(ss) {
 f0.R1.value = ss;
}

function ee() {
 if (f1.DDDDD.value == "") {
  alert("请输入您的账号 Please enter your account account number");
  return false;
 }
 f0.DDDDD.value = f1.DDDDD.value
 if (ps == 0) {
  f0.upass.value = xproc1(f1.upass.value);
 } else {
  tmpchar = pid + f1.upass.value + calg;
  f0.upass.value = calcMD5(tmpchar) + calg + pid;
  f0.R2.value = 1;
 }
 document.f0.submit();
 return false;
}

显然,点击提交后,会对f0进行一系列赋值,如果没有问题就会提交f0

f0:

<form name="f0" method="post" action=""><input type="hidden" name="DDDDD" value="0"><input type="hidden" name="upass" value="0">
<input type="hidden" name="R1" value="0"><input type="hidden" name="R2" value="0"><input type="hidden" name="para" value="00">
<input type="hidden" name="0MKKey" value="123456">
</form>

参考js里的内容,用python的dict表示f0的话有如下的伪代码:

f0={}
 f0["DDDDD"] = f1['DDDD']
 f0["upass"] = calcMD5(pid + f1['upass'] + calg) + calg + pid;
 f0["R1"] = ss
 f0["R2"] = 1
 f0["para"] = 00
 f0["0MKKey"] = 123456

其中 ss、pid、calg都是常量,f1['DDDD']、f1['upass']分别是用户输入的用户名和密码字符串

关键在于calcMD5的算法。

从函数名和函数本身来看,这个函数是MD5的一种实现。然而对js代码进行移植的过程中出现了一些问题:js和python的移位操作表现不同。

既然整个f0['upass']字段除了用户输入的密码以外,其它都是常量,完全可以用js计算出f0['upass'],python中只要保存这个字符串就行了。

检查cookies发现整个网页没有使用cookies。

登录后跳转到登出页面,分析登出页面发现,登出只需要访问某个特定的网页就行了。

于是整个思路很简单,pos登录服务器实现登录,get指定网页登出。实现代码如下:

import sys
from urllib import urlencode
from urllib2 import urlopen

username = "s10********"
upass = "6696a3***********************************"
LOGIN = "http://202.1**.***.***/"
LOGOUT = "http://202.1**.***.***/F.htm"

def post(url, data=None):
 if data:
  data = urlencode(data)
 response = urlopen(url, data)
 return response.read()

def login():
 data={}
 data["DDDDD"] = username
 data["upass"] = upass
 data["R1"] = 0
 data["R2"] = 1
 data["para"] = 00
 data["0MKKey"] = 123456
 post(LOGIN, data)
 pass

def logout():
 post(LOGOUT)

def main(argv):
 if argv[0] in ('login','in','i'):
  login()
 elif argv[0] in ('logout','out','o'):
  logout()
  pass
 pass

if __name__ == '__main__': 
 main(sys.argv[1:]);
Python 相关文章推荐
python实现的一只从百度开始不断搜索的小爬虫
Aug 13 Python
使用setup.py安装python包和卸载python包的方法
Nov 27 Python
Python中用pycurl监控http响应时间脚本分享
Feb 02 Python
Python与shell的3种交互方式介绍
Apr 11 Python
python中的编码知识整理汇总
Jan 26 Python
python fabric实现远程部署
Jan 05 Python
python+selenium识别验证码并登录的示例代码
Dec 21 Python
详解python3中的真值测试
Aug 13 Python
Python中dict和set的用法讲解
Mar 28 Python
python中多个装饰器的调用顺序详解
Jul 16 Python
Django Rest framework权限的详细用法
Jul 25 Python
PyCharm Ctrl+Shift+F 失灵的简单有效解决操作
Jan 15 Python
python正则表达式re模块详解
Jun 25 #Python
Python通过websocket与js客户端通信示例分析
Jun 25 #Python
Flask框架学习笔记(一)安装篇(windows安装与centos安装)
Jun 25 #Python
Python中文编码那些事
Jun 25 #Python
教你如何在Django 1.6中正确使用 Signal
Jun 22 #Python
python抓取网页时字符集转换问题处理方案分享
Jun 19 #Python
python在linux中输出带颜色的文字的方法
Jun 19 #Python
You might like
PHP使用SOAP调用.net的WebService数据
2013/11/12 PHP
php基于mcrypt_encrypt和mcrypt_decrypt实现字符串加密解密的方法
2016/07/12 PHP
thinkphp关于简单的权限判定方法
2017/04/03 PHP
PHP实现批量修改文件名的方法示例
2019/09/18 PHP
学习YUI.Ext 第六天--关于树TreePanel(Part 2异步获取节点)
2007/03/10 Javascript
基于JavaScript实现继承机制之调用call()与apply()的方法详解
2013/05/07 Javascript
jQuery队列操作方法实例
2014/06/11 Javascript
兼容IE、firefox以及chrome的js获取时间(getFullYear)
2014/07/04 Javascript
TypeError document.getElementById(...) is null错误原因
2015/05/18 Javascript
jQuery+ajax实现文章点赞功能的方法
2015/12/31 Javascript
jquery+css3实现会动的小圆圈效果
2016/01/27 Javascript
详解javascript跨浏览器事件处理程序
2016/03/27 Javascript
javascript cookie用法基础教程(概念,设置,读取及删除)
2016/09/20 Javascript
Windows系统下安装Node.js的步骤图文详解
2016/11/15 Javascript
jq给页面添加覆盖层遮罩的实例
2017/02/16 Javascript
React复制到剪贴板的示例代码
2017/08/22 Javascript
浅谈vue路径优化之resolve
2017/10/13 Javascript
vue数据初始化initState的实例详解
2019/04/11 Javascript
Javascript实现html转pdf高清版(提高分辨率)
2020/02/19 Javascript
Vue自定义组件的四种方式示例详解
2020/02/28 Javascript
基于vue+echarts 数据可视化大屏展示的方法示例
2020/03/09 Javascript
Python入门学习指南分享
2018/04/11 Python
使用django-guardian实现django-admin的行级权限控制的方法
2018/10/30 Python
python实现字符串加密成纯数字
2019/03/19 Python
Python字符串匹配之6种方法的使用详解
2019/04/08 Python
简单了解Python读取大文件代码实例
2019/12/18 Python
win10下python3.8的PIL库安装过程
2020/06/08 Python
UNIX命令速查表
2012/03/10 面试题
岗位职责定义及内容
2013/11/08 职场文书
民族团结先进集体事迹材料
2014/05/22 职场文书
前台文员岗位职责
2015/02/04 职场文书
上帝也疯狂观后感
2015/06/09 职场文书
房产遗嘱范本
2015/08/06 职场文书
php 防护xss,PHP的防御XSS注入的终极解决方案
2021/04/01 PHP
golang中切片copy复制和等号复制的区别介绍
2021/04/27 Golang
MySQL创建高性能索引的全步骤
2021/05/02 MySQL