python编写登录脚本_python实现的登录和操作开心网脚本分享

#coding: utf-8

"""

开心网操作脚本

Author: piglei2007@gmail.com

Version: 1.0

"""

import re

import urllib

import urllib2

import random

import hashlib

import binascii

import cookielib

import simplejson

from xxtea import encrypt

LOGIN_URL = "http://www.kaixin001.com/login/login_api.php"

LOGIN_KEY_URL = "http://www.kaixin001.com/"

FRIEND_LIST_URL = "http://www.kaixin001.com/interface/suggestfriend.php"

MESSAGE_SEND_URL = "http://www.kaixin001.com/msg/post.php"

LOGIN_KEY_RE = re.compile(r"new\sEnLogin\('(.*?)'")

class LoginError(Exception):

"""

登录失败抛出异常

"""

class Kaixin001User(object):

"""

操作kaixin001,现有方法:

get_login_key - 获得用户访问登录页面时分配的加密key

get_rpassword - 获得经过xxtea以及sha1加密后的密码

login - 登录

get_friends_list - 获得所有好友,返回字典格式

send_messages_to_all - 给所有好友发消息

"""

def __init__(self, username, password):

self.username = username

self.password = password

self.cj = cookielib.CookieJar()

opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(self.cj))

opener.addheaders = [

("User-agent", "Mozilla/5.0 (X11; U; FreeBSD i386; en-US; rv:1.9.1) Gecko/20090704 Firefox/3.5"),

("Accept", "*/*"),

("Host", "www.kaixin001.com")

]

urllib2.install_opener(opener)

def get_login_key(self):

"""

获得登录时候的加密key

"""

_temp = urllib2.urlopen(LOGIN_KEY_URL).read()

key = LOGIN_KEY_RE.search(_temp).group(1)

return key

def login(self):

"""

登录

"""

login_key = self.get_login_key()

rpassword = self.get_rpassword(self.password, login_key)

login_params = {

'email': self.username,

'encypt': login_key,

'rpasswd': rpassword,

'url': '/home/',

'ver': '1'

}

req = urllib2.Request(LOGIN_URL, urllib.urlencode(login_params), {

"Referer": "http://www.kaixin001.com/"

})

result = urllib2.urlopen(req).read()

# 登录失败

if "errno" in result:

raise LoginError("登录失败,请检查用户名或密码")

print "用户 %s 登录成功!" % self.username

return 'ok'

def get_friends_list(self):

"""

获得所有好友列表

"""

get_friends_params = {

't': str(random.random()),

'type': 'all',

}

result = urllib2.urlopen(FRIEND_LIST_URL, urllib.urlencode(get_friends_params)).read()

friends = simplejson.loads(result)

print "你一共有 %s 位好友" % (len(friends) - 1)

return friends

def send_messages_to_all(self, message=''):

"""

给所有好友发消息

"""

friends = self.get_friends_list()

send_params = {

'attachment_cancel': '',

'attachment_forwarding': '',

'attachment_random': '',

'code': '',

'content': message,

'forward_thread': '',

'rcode': '',

'service': '0',

'texttype': 'html',

'uids': ",".join([str(f['uid']) for f in friends])

}

result = urllib2.urlopen(MESSAGE_SEND_URL, urllib.urlencode(send_params))

print result.geturl()

print "消息发送成功"

return 'ok'

def get_rpassword(self, password, key):

"""

获得加密后的密码

"""

xxtea_pw = binascii.b2a_hex( encrypt(password, key) )

r_password = hashlib.sha1(xxtea_pw).hexdigest()

return r_password

if __name__ == '__main__':

kxu = Kaixin001User(

username = 'your_username',

password = 'your_password'

)

kxu.login()

kxu.send_messages_to_all("This message is send by Python.")

这是脚本中需要用到的xxtea算法的python实现(xxtea.py):

import struct

_DELTA = 0x9E3779B9

def _long2str(v, w):

n = (len(v) - 1) << 2

if w:

m = v[-1]

if (m < n - 3) or (m > n): return ''

n = m

s = struct.pack('> 2), s))

if w: v.append(n)

return v

def encrypt(str, key):

if str == '': return str

v = _str2long(str, True)

k = _str2long(key.ljust(16, "\0"), False)

n = len(v) - 1

z = v[n]

y = v[0]

sum = 0

q = 6 + 52 // (n + 1)

while q > 0:

sum = (sum + _DELTA) & 0xffffffff

e = sum >> 2 & 3

for p in xrange(n):

y = v[p + 1]

v[p] = (v[p] + ((z >> 5 ^ y << 2) + (y >> 3 ^ z << 4) ^ (sum ^ y) + (k[p & 3 ^ e] ^ z))) & 0xffffffff

z = v[p]

y = v[0]

v[n] = (v[n] + ((z >> 5 ^ y << 2) + (y >> 3 ^ z << 4) ^ (sum ^ y) + (k[n & 3 ^ e] ^ z))) & 0xffffffff

z = v[n]

q -= 1

return _long2str(v, False)

def decrypt(str, key):

if str == '': return str

v = _str2long(str, False)

k = _str2long(key.ljust(16, "\0"), False)

n = len(v) - 1

z = v[n]

y = v[0]

q = 6 + 52 // (n + 1)

sum = (q * _DELTA) & 0xffffffff

while (sum != 0):

e = sum >> 2 & 3

for p in xrange(n, 0, -1):

z = v[p - 1]

v[p] = (v[p] - ((z >> 5 ^ y << 2) + (y >> 3 ^ z << 4) ^ (sum ^ y) + (k[p & 3 ^ e] ^ z))) & 0xffffffff

y = v[p]

z = v[n]

v[0] = (v[0] - ((z >> 5 ^ y << 2) + (y >> 3 ^ z << 4) ^ (sum ^ y) + (k[0 & 3 ^ e] ^ z))) & 0xffffffff

y = v[0]

sum = (sum - _DELTA) & 0xffffffff

return _long2str(v, True)

if __name__ == "__main__":

print decrypt(encrypt('Hello XXTEA!', '16bytelongstring'), '16bytelongstring')

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值