gpt4 book ai didi

Java jsoup html解析机器人index/bot检测、noindex

转载 作者:行者123 更新时间:2023-11-30 02:52:03 31 4
gpt4 key购买 nike

首先,这不是一个重复的问题,因为我已经检查了几乎所有的503/机器人索引问题。他们都没有解决我的问题。我正在尝试从 indiegala.com 获取赠品列表,但该网站有某种保护措施来防止机器人。我的目的并不违法,我只是想获得赠品列表,然后检查游戏是否有 Steam 交易卡。但要知道,indiegala 给了我一个机器人索引。目前我正在使用该代码;

       String url = "https://www.indiegala.com/giveaways";
try {
String content = Jsoup.connect(url).userAgent("Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36").ignoreHttpErrors(true).followRedirects(true).get().html();
System.out.println(content);
} catch (IOException ex) {
System.out.println(ex.toString());
}

要查看输出(网站的来源,在我的代码中,变量“内容”),您可以运行我给出的代码,我无法在此处添加输出,因为它有点长。但看起来是这样的;

<head>
<meta name="ROBOTS" content="NOINDEX, NOFOLLOW" />
</head>

那么我怎样才能通过这个保护呢?我的程序可以假装像人一样通过这种保护吗?

最佳答案

我已经查看了您的案例,并找到了如何绕过机器人检测的方法。

您需要的是cookie。参见下面的代码:

String url = "https://www.indiegala.com/giveaways";

Document doc = Jsoup.connect(url)
.userAgent("Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36")
.header("cookie", "incap_ses_436_255598=zI1vN7X6+BY84PhGvPsMBjKChVcAAAAAVhJ+1//uCecPhV2QjUMw6w==")
.timeout(0)
.get();

这看起来像是网站所需的特定 cookie,将其添加到 header 中已成功为我提供了实际的网站内容:)

注意:通常,如果您遇到这样的情况,您可以轻松地使用 Chrome 开发者工具来检查 Chrome 发送的请求,然后将其复制到您的 Jsoup 请求中:)

关于Java jsoup html解析机器人index/bot检测、noindex,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38338418/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com