为什么通过浏览器和网络应用程序的Instagram搜索结果之间存在差异?

时间:2019-01-21 19:07:55

标签: python instagram

当我通过浏览器在Instagram搜索一些标签时,它会向服务器发送请求,如下所示:

https://www.instagram.com/web/search/topsearch/?context=blended&query=#trump&rank_token=0.11476949782296608&include_reel=true

并响应JSON内容100个相似的标签。

当我从Web应用程序发出基于Flask的请求时,我仅收到55个类似的标签。而且我不明白为什么。

我试图像浏览器一样写标题,但是结果是一样的。 我找到了一些可以测试GET查询的免费服务,但结果是相同的。

以下是Flask函数来进行查询:

def query():
    headers = {'authority': 'www.instagram.com',
            'method': 'GET',
            'scheme': 'https',
            'accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',
            'accept-encoding': 'gzip, deflate, br',
            'accept-language': 'ru-RU,ru;q=0.9,en-US;q=0.8,en;q=0.7',
            'cache-control': 'max-age=0',
            'cookie': 'rur=FTW; mid=XEXhXgAEAAFQ0Lg-pAfeVCCnUTzw; mcd=3; csrftoken=IeAstJqVSC7I3TYuKDoCxuGOI5kq4OL3',
            'upgrade-insecure-requests': '1',
            'user-agent': 'Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.98 Safari/537.36',
            'x-compress': 'null',
            'x-requested-with': 'XMLHttpRequest'
        }
    payload = {'query': request.args.get('text')}
    baseUrl = 'https://www.instagram.com/web/search/topsearch/'

    try:
        response = requests.get(baseUrl, params=payload, headers=headers)
        response.raise_for_status()
    except requests.RequestException:
        return None

工作正常,但我希望得到100个结果,而不是55个。

如果您有什么想法,请告诉我。

p.s。可能是因为会话参数?

0 个答案:

没有答案