python调用js函数_Python请求如何在发布之前调用js函数以计算...

我使用请求(2.2.1)登录URL http://tx3.netease.com/logging.php?action=login,但是此URL的登录逻辑与Django的csrf令牌机制不同,即:

>当您获取此URL时,html文本中有两个导入值formhash和sts,这两个导入值都将在js函数do_encrypt中使用(在文件http://tx3.netease.com/forumdata/cache/rsa/rsa_min中.js).很好,我可以轻松地通过re抓住它们.

html文本的关键部分是:

...

...

2.输入电子邮件和原始密码ori_password后,单击Submit按钮将调用do_encrypt,它将使用formhash,sts和ori_password设置post dict的真实密码.问题出来了-似乎没有办法直接获取密码字符串. (相比之下,在Django情况下,您可以直接从session_client.cookies [‘csrftoken’]获取csrfmiddlewaretoken)

这是代码:

import requests

import json

import re

loginUrl = "http://tx3.netease.com/logging.php?action=login"

client = requests.session()

r = client.get(loginUrl)

r.encoding='gb18030'

stsPat = re.compile('')

formhashPat = re.compile('')

sts = stsPat.search(r.text).groups()[0]

formhash = formhashPat.search(r.text).groups()[0]

loginData={

'username' : "smaller9@163.com",

'password' : ..., # Set by js function do_encrypt

'referer':'/',

'loginfield':'username',

'ori_password':'', # it's `111111`, but `do_encrypt` will set it to empty.

'loginsubmit':'true',

'sts':sts,

'formhash':formhash,

}

# r = client.post(url=loginUrl,data=loginData)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值