用python登录facebook

2024-04-27 16:14:19 发布

您现在位置:Python中文网/ 问答频道 /正文

如果我连续运行下面的代码10次,它将工作大约一半的时间,其余的都会失败。有人知道为什么吗?

import urllib2, cookielib, re, os, sys

class Facebook():
    def __init__(self, email, password):
        self.email = email
        self.password = password

        cj = cookielib.CookieJar()
        opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(cj))
        opener.addheaders = [('Referer', 'http://login.facebook.com/login.php'),
                            ('Content-Type', 'application/x-www-form-urlencoded'),
                            ('User-Agent', 'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.1.7) Gecko/20091221 Firefox/3.5.7 (.NET CLR 3.5.30729)')]
        self.opener = opener

    def login(self):
        url = 'https://login.facebook.com/login.php?login_attempt=1'
        data = "locale=en_US&non_com_login=&email="+self.email+"&pass="+self.password+"&lsd=20TOl"

        usock = self.opener.open('http://www.facebook.com')
        usock = self.opener.open(url, data)
        if "Logout" in usock.read():
            print "Logged in."
        else:
            print "failed login"
            print usock.read()
            sys.exit()

f = Facebook("test@gmail.com", "asdfasdf")
f.login()

Tags: selfcomfacebookemaildefsysloginpassword
3条回答

我也遇到过同样的问题。我找到的唯一解决办法是。。。facebook手机更稳定。

class Acc:
    jar = cookielib.CookieJar()
    cookie = urllib2.HTTPCookieProcessor(jar)       
    opener = urllib2.build_opener(cookie)

    headers = {
        "User-Agent" : "Mozilla/5.0 (X11; U; FreeBSD i386; en-US; rv:1.8.1.14) Gecko/20080609 Firefox/2.0.0.14",
        "Accept" : "text/xml,application/xml,application/xhtml+xml,text/html;q=0.9,text/plain;q=0.8,text/png,*/*;q=0.5",
        "Accept-Language" : "en-us,en;q=0.5",
        "Accept-Charset" : "ISO-8859-1",
        "Content-type": "application/x-www-form-urlencoded",
        "Host": "m.facebook.com"
    }

    def login(self):
        try:
            params = urllib.urlencode({'email':'test@test.test','pass':'dempassword','login':'Log+In'})
            req = urllib2.Request('http://m.facebook.com/login.php?m=m&refsrc=m.facebook.com%2F', params, self.headers)
            res = self.opener.open(req)
            html = res.read()

            #print res.getheader('location').split('/')[3]

        except urllib2.HTTPError, e:
            print e.msg
        except urllib2.URLError, e:
            print e.reason[1]
        return False

    def fetch(self,url):
        req = urllib2.Request(url,None,self.headers)
        res = self.opener.open(req)
        return res.read()

bla = Acc()
bla.login()

另外,facebook手机还没有ajax,所以弄清楚要发出什么请求要容易得多。

所以我尝试了你的代码,并让它登录一次,然后像你一样,我有麻烦登录再次。在“if”语句之前的一行,我添加了 打印usock.read() 最后得到了一堆html代码。然后我把代码放到记事本上,保存为一个html文件,然后把它拉上来。 这就是正在发生的事情:Facebook怀疑我们是从一个计算机程序登录的,并等待我们通过显示一个验证码来验证我们是真的。这个程序并没有考虑到这一点,当它实际上是一个挂起的登录时,会打印“失败的登录”。

每次修理对我都有效。 然后我想在登录后真正阅读页面内容。为此,我在“print”登录“”之后添加了“print usock.read()”,但这返回了空字符串。我猜是因为usock被打了两次电话,所以我修改了第一次给usock的电话:

    a = usock.read()
    if "logout" in a:
        print "Logged in."
        return a

这样一来,第一次只有一个电话打给usock,而且很管用。然后使用return a代替print a,因为这样可以直接使用login()返回页面源。不过,请随便。

相关问题 更多 >