使用Python中的cookielib模拟登录网站

作者:goldensun 时间:2022-01-20 08:54:26 

前面简单提到了 Python 模拟登录的程序,但是没写清楚,这里再补上一个带注释的 Python 模拟登录的示例程序。简单说一下流程:先用cookielib获取cookie,再用获取到的cookie,进入需要登录的网站。


# -*- coding: utf-8 -*-

# !/usr/bin/python

import urllib2
import urllib
import cookielib
import re
auth_url = 'http://www.nowamagic.net/'
home_url = 'http://www.nowamagic.net/';
# 登陆用户名和密码
data={
  "username":"nowamagic",
  "password":"pass"
}
# urllib进行编码
post_data=urllib.urlencode(data)
# 发送头信息

headers ={

"Host":"www.nowamagic.net",
"Referer": "http://www.nowamagic.net"
}
# 初始化一个CookieJar来处理Cookie

cookieJar=cookielib.CookieJar()
# 实例化一个全局opener

opener=urllib2.build_opener(urllib2.HTTPCookieProcessor(cookieJar))

# 获取cookie
req=urllib2.Request(auth_url,post_data,headers)
result = opener.open(req)
# 访问主页 自动带着cookie信息
result = opener.open(home_url)
# 显示结果
print result.read()

再附带几个示例程序:

1. 使用已有的cookie访问网站


import cookielib, urllib2

ckjar = cookielib.MozillaCookieJar(os.path.join('C:\Documents and Settings\tom\Application Data\Mozilla\Firefox\Profiles\h5m61j1i.default', 'cookies.txt'))
req = urllib2.Request(url, postdata, header)

req.add_header('User-Agent', \
  'Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)')

opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(ckjar) )

f = opener.open(req)
htm = f.read()
f.close()

2. 访问网站获得cookie,并把获得的cookie保存在cookie文件中


import cookielib, urllib2

req = urllib2.Request(url, postdata, header)
req.add_header('User-Agent', \
  'Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)')

ckjar = cookielib.MozillaCookieJar(filename)
ckproc = urllib2.HTTPCookieProcessor(ckjar)

opener = urllib2.build_opener(ckproc)

f = opener.open(req)
htm = f.read()
f.close()

ckjar.save(ignore_discard=True, ignore_expires=True)

3. 使用指定的参数生成cookie,并用这个cookie访问网站


import cookielib, urllib2

cookiejar = cookielib.CookieJar()
urlOpener = urllib2.build_opener(urllib2.HTTPCookieProcessor(cookiejar))
values = {'redirect':", 'email':'abc@abc.com',
     'password':'password', 'rememberme':", 'submit':'OK, Let Me In!'}
data = urllib.urlencode(values)

request = urllib2.Request(url, data)
url = urlOpener.open(request)
print url.info()
page = url.read()

request = urllib2.Request(url)
url = urlOpener.open(request)
page = url.read()
print page
标签:Python
0
投稿

猜你喜欢

  • 基于Go Int转string几种方式性能测试

    2024-05-08 10:17:04
  • PHP hebrev()函数用法讲解

    2023-06-03 12:49:32
  • asp上传文件自动重命名方法

    2007-08-24 09:46:00
  • 简单了解Python变量作用域正确使用方法

    2022-02-03 04:18:55
  • python实现切割url得到域名、协议、主机名等各个字段的例子

    2022-02-26 11:02:25
  • python 读取Linux服务器上的文件方法

    2023-03-31 23:54:19
  • ASP.NET教程第二讲:安装ASP.NET

    2007-08-07 11:59:00
  • 关联的 script 标签

    2009-11-02 10:40:00
  • pandas中去除指定字符的实例

    2023-11-29 22:41:35
  • django admin管理工具自定义时间区间筛选器DateRangeFilter介绍

    2023-03-23 04:12:20
  • OpenCV机器学习MeanShift算法笔记分享

    2021-06-04 18:54:54
  • vue关于eslint空格缩进等的报错问题及解决

    2024-05-10 14:09:26
  • MySQL窗口函数OVER使用示例详细讲解

    2024-01-16 15:56:56
  • python Django的显示个人信息详解

    2021-10-09 15:47:14
  • cropper js基于vue的图片裁剪上传功能的实现代码

    2024-05-11 09:10:50
  • python相对包导入报“Attempted relative import in non-package”错误问题解决

    2022-02-28 12:57:05
  • asp如何用WSH获取机器的IP配置信息?

    2010-06-13 14:39:00
  • 访问javascript私有变量

    2010-01-19 13:56:00
  • 通过案例解析python鸭子类型相关原理

    2022-05-03 12:38:57
  • Python3 无重复字符的最长子串的实现

    2021-12-09 21:36:24
  • asp之家 网络编程 m.aspxhome.com