zoukankan      html  css  js  c++  java
  • python访问需要登录的网页

    有些网页需要你登录之后才可以访问,你需要提供账户和密码。

    只要在发送http请求时,带上含有正常登陆的cookie就可以了。

    1.首先我们要先了解cookie的工作原理。

    Cookie是由服务器端生成,发送给User-Agent(一般是浏览器),浏览器会将Cookie的key/value保存到某个目录下的文本文件内,下次请求同一网站时就发送该Cookie给服务器(前提是浏览器设置为启用cookie)。Cookie名称和值可以由服务器端开发自己定义,对于JSP而言也可以直接写入jsessionid,这样服务器可以知道该用户是否合法用户以及是否需要重新登录等。

    2.之后我们要获取到用户正常登录的cookie.

    python提供了cookieJar的库,只要把cookieJar的实例作为参数传到urllib2的一个opener里面。

    然后访问一次登录的页面,cookie就已经保存下来了。之后通过这个实例访问所有的页面都带有正常登陆的cookie了。

    以人人网为例子。

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    21

    22

    23

    24

    25

    26

    27

    #encoding=utf-8

    import urllib2

    import urllib

    import cookielib

    def renrenBrower(url,user,password):

        #登陆页面,可以通过抓包工具分析获得,如fiddler,wireshark

        login_page = "http://www.renren.com/PLogin.do"

        try:

            #获得一个cookieJar实例

            cj = cookielib.CookieJar()

            #cookieJar作为参数,获得一个opener的实例

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

            #伪装成一个正常的浏览器,避免有些web服务器拒绝访问。

            opener.addheaders = [('User-agent','Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)')]

            #生成Post数据,含有登陆用户名密码。

            data = urllib.urlencode({"email":user,"password":password})

            #以post的方法访问登陆页面,访问之后cookieJar会自定保存cookie

            opener.open(login_page,data)

            #以带cookie的方式访问页面

            op=opener.open(url)

            #读取页面源码

            data= op.read()

            return data

        except Exception,e:

            print str(e)

    #访问某用户的个人主页,其实这已经实现了人人网的签到功能。

    print renrenBrower("http://www.renren.com/home","用户名","密码")

       

  • 相关阅读:
    Unity3D脚本使用:物体调用物体
    Unity3D脚本使用:游戏对象访问
    Unity3D 浏览工具
    spring的工厂方法
    spring运用的设计模式
    Jquery ajax 与 lazyload的混合使用(实现图片异步加载)
    关于线程安全的一点总结
    lazyload的使用心得
    ajax原理及应用
    $.ajax和$.load的区别
  • 原文地址:https://www.cnblogs.com/Yiutto/p/5889436.html
Copyright © 2011-2022 走看看