简体   繁体   English

无法使用请求模块登录 Facebook

[英]Can't log in to facebook using requests module

I'm trying to log in to facebook using requests module.我正在尝试使用请求模块登录 Facebook。 Although it seems I've prepared payload in the right way but when I send it with post requests, I don't get desired content in the response.虽然看起来我已经以正确的方式准备了有效负载,但是当我通过发布请求发送它时,我没有在响应中获得所需的内容。 I get 200 status code, though.不过,我得到 200 状态代码。 To let you know, If I get response accordingly, I should find my fullname within it.让你知道,如果我得到相应的回应,我应该在其中找到我的全名。

I initially tried like the following:我最初尝试如下:

import requests
from bs4 import BeautifulSoup
from datetime import datetime

link = 'https://www.facebook.com/'
base_url = 'https://www.facebook.com{}'

time = int(datetime.now().timestamp())

headers = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.150 Safari/537.36',
    'referer': 'https://www.facebook.com/',
}

with requests.Session() as s:
    r = s.get(link)
    soup = BeautifulSoup(r.text,"lxml")
    form_url = soup.select_one("form[data-testid='royal_login_form']")['action']
    post_url = base_url.format(form_url)
    payload = {i['name']:i.get('value','') for i in soup.select('input[name]')}
    payload['email'] = 'YOUR_EMAIL'
    payload['encpass'] = f'#PWD_BROWSER:0:{time}:YOUR_PASSWORD'
    payload.pop('pass')
    res = s.post(post_url,data=payload,headers=headers)
    print(res.url)
    print(res.text)

This is another way I tried which didn't work out either:这是我尝试过的另一种方法,但也没有奏效:

import requests
from bs4 import BeautifulSoup
from datetime import datetime

login_url = 'https://www.facebook.com/login/device-based/regular/login/?login_attempt=1&lwv=101'
time = int(datetime.now().timestamp())

headers = {
    'user-agent': 'Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36',
    'origin': 'https://www.facebook.com',
    'referer': 'https://www.facebook.com/login/device-based/regular/login/?login_attempt=1&lwv=101'
}

with requests.Session() as s:
    r = s.get(login_url)
    soup = BeautifulSoup(r.text,"lxml")
    payload = {i['name']:i.get('value','') for i in soup.select('input[name]')}
    payload['email'] = 'YOUR_EMAIL'
    payload['encpass'] = f'#PWD_BROWSER:0:{time}:YOUR_PASSWORD'
    payload['had_password_prefilled'] = 'true'
    payload['had_cp_prefilled'] = 'true'
    payload['prefill_source'] = 'browser_dropdown'
    payload['prefill_type'] = 'contact_point'
    payload['first_prefill_source'] = 'last_login'
    payload['first_prefill_type'] = 'contact_point'
    payload['prefill_contact_point'] = 'YOUR_EMAIL'
    payload.pop('pass')
    r = s.post(login_url,data=payload,headers=headers)
    print(r.status_code)
    print(r.url)

How can I log in to facebook using requests?如何使用请求登录 Facebook?

This might be a case of xy problem这可能是xy 问题的一个案例

I recommend trying Selenium in accessing Facebook programmatically.我建议在以编程方式访问 Facebook 时尝试使用Selenium

More examples using Selenium in logging in.更多使用 Selenium 登录的例子。

https://www.askpython.com/python/examples/python-automate-facebook-login https://www.askpython.com/python/examples/python-automate-facebook-login

https://www.guru99.com/facebook-login-using-python.html https://www.guru99.com/facebook-login-using-python.html

If logging in is all that you require, then using selenium, you could do it as:如果您只需要登录,那么使用 selenium,您可以这样做:

from selenium import webdriver
from selenium.webdriver.common.keys import Keys
URL = 'https://www.facebook.com/'
PATH = r'C:\Program Files (x86)\chromedriver.exe'
driver = webdriver.Chrome(PATH)
driver.get(URL)
email = driver.find_element_by_id('email')
email.send_keys('YourEmail')
password = driver.find_element_by_id('pass')
password.send_keys('YourPassword')
password.send_keys(Keys.RETURN)

I would recommend that you use the browser that you frequently use to login for this process.我建议您使用您经常使用的浏览器登录此过程。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM