Python模拟百度登录实例详解

作者:mrr 时间:2023-07-18 19:06:46 

最近公司产品和百度贴吧合作搞活动,为了增加人气,打算做个自动签到的小程序。这个是测试登录的代码,写的比较随意,仅实现了登录并读取关注贴吧列表,下边的就比较简单。

百度登录还是有点麻烦的,由于用的ssl,所以要先获取token,然后再登录,这个用finddle2分析下,还是比较好解决的。


# -*- coding: utf8 -*-
import urllib2
import urllib
import cookielib
import re
import bs4
URL_BAIDU_INDEX = u'http://www.baidu.com/';
#https://passport.baidu.com/v2/api/?getapi&class=login&tpl=mn&tangram=true 也可以用这个
URL_BAIDU_TOKEN = 'https://passport.baidu.com/v2/api/?getapi&tpl=pp&apiver=v3&class=login';
URL_BAIDU_LOGIN = 'https://passport.baidu.com/v2/api/?login';
#设置用户名、密码
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,
'u' : 'https://passport.baidu.com/',
'tpl' : 'pp',
'token' : tokenVal,
'staticpage' : 'https://passport.baidu.com/static/passpc-account/html/v3Jump.html',
'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 这个是贴吧个人主页,各项信息都可以在此找到链接
teibaUrl = 'http://tieba.baidu.com/f/like/mylike?v=1387441831248'
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'];

关于python模拟百度登录相关知识就给大家介绍这么多,希望大家喜欢。

标签:python,模拟,登录
0
投稿

猜你喜欢

  • 亲手教你怎样创建一个简单的mysql数据库

    2024-01-18 21:59:04
  • Python全栈之学习CSS(1)

    2022-11-07 19:05:18
  • 年底了,你的mysql密码安全吗

    2024-01-12 23:50:00
  • 详解eslint在vue中如何使用

    2023-07-02 16:58:58
  • Python 图像处理 Pillow 库详情

    2022-12-05 04:46:12
  • Python关键字 asynico基本用法

    2023-02-19 08:34:42
  • Go错误处理之panic函数和recover函数使用及捕获异常方法

    2024-02-13 02:16:12
  • MYSQL server has gone away解决办法

    2010-11-25 17:22:00
  • 在PyTorch中使用标签平滑正则化的问题

    2021-12-26 17:46:54
  • pycharm 使用心得(一)安装和首次使用

    2023-06-14 05:49:37
  • 解决python彩色螺旋线绘制引发的问题

    2023-06-30 12:49:12
  • pytest中的fixture基本用法

    2023-07-14 12:26:45
  • 利用Python实现在同一网络中的本地文件共享方法

    2023-10-31 00:41:58
  • Python seaborn barplot画图案例

    2023-11-07 00:50:55
  • 详解Mysql中的JSON系列操作函数

    2024-01-20 02:08:08
  • 关于sql server批量插入和更新的两种解决方案

    2024-01-15 02:20:42
  • Pycharm直接使用远程服务器代码并调试的解决方法

    2021-05-13 10:21:03
  • pytorch下的unsqueeze和squeeze的用法说明

    2023-07-16 14:01:41
  • Python利用带权重随机数解决抽奖和游戏爆装备问题

    2023-09-21 10:16:43
  • 检测浏览器对事件的支持程度

    2009-12-23 19:40:00
  • asp之家 网络编程 m.aspxhome.com