Python模拟百度登录实例

原文:http://www.jb51.net/article/78406.htm


记录下来,慢慢学习:

要先获取token,然后再登录

# -*- coding: utf8 -*-
import urllib2
import urllib
import cookielib
import re
import bs4
URL_BAIDU_INDEX = u 'http://www.baidu.com/' ;
#设置用户名、密码
username = '';
password = '';
#设置cookie,这里cookiejar可自动管理,无需手动指定
cj = cookielib.CookieJar();
opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(cj));
urllib2.install_opener(opener);
reqReturn = urllib2.urlopen(URL_BAIDU_INDEX);
#获取token,
tokenReturn = urllib2.urlopen(URL_BAIDU_TOKEN);
matchVal = re.search(u '"token" : "(?P<tokenVal>.*?)"' ,tokenReturn.read());
tokenVal = matchVal.group( 'tokenVal' );
#构造登录请求参数,该请求数据是通过抓包获得,对应https://passport.baidu.com/v2/api/?login请求
postData = {
'username' : username,
'password' : password,
'tpl' : 'pp' ,
'token' : tokenVal,
'isPhone' : 'false' ,
'charset' : 'UTF-8' ,
'callback' : 'parent.bd__pcbs__ra48vi'
};
postData = urllib.urlencode(postData);
#发送登录请求
loginRequest = urllib2.Request(URL_BAIDU_LOGIN,postData);
loginRequest.add_header( 'Accept' , 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8' );
loginRequest.add_header( 'Accept-Encoding' , 'gzip,deflate,sdch' );
loginRequest.add_header( 'Accept-Language' , 'zh-CN,zh;q=0.8' );
loginRequest.add_header( 'User-Agent' , 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/28.0.1500.72 Safari/537.36' );
loginRequest.add_header( 'Content-Type' , 'application/x-www-form-urlencoded' );
sendPost = urllib2.urlopen(loginRequest);
#查看贴吧个人主页 ,测试是否登陆成功,由于cookie自动管理,这里处理起来方便很多
#http://tieba.baidu.com/home/main?un=XXXX&fr=index 这个是贴吧个人主页,各项信息都可以在此找到链接
content = urllib2.urlopen(teibaUrl).read();
content = content.decode( 'gbk' ).encode( 'utf8' );
print content;
#解析数据,用的BeautifulSoup4,感觉没有jsoup用的爽
soup = bs4.BeautifulSoup(content);
list = soup.findAll( 'tr' );
list = list [ 1 : len ( list )];
careTeibalist = [];
print '贴吧链接\\t吧名\\t等级' ;
for elem in list :
soup1 = bs4.BeautifulSoup( str (elem));
print 'http://tieba.baidu.com/' + soup1.find( 'a' )[ 'href' ] + '\\t' + soup1.find( 'a' )[ 'title' ] + '\\t' + soup1.find( 'a' ,{ 'class' , 'like_badge' })[ 'title' ];

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值