- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试在特定网页中搜索特定词,我正在使用 Java 和 Eclipse。问题是,如果我使用一个几乎没有内容的网页,它工作正常,但是当我在一个“大”网页中尝试时,它找不到这个词。
例如:我试图在网页中查找单词 ["InitialChatFriendsList"
:https://www.facebook.com
,如果找到word 然后打印 WIN!!!
这是完整的 Java 代码:
public class BR4Qustion {
public static void main(String[] args) {
BufferedReader br = null;
try {
URL url = new URL("https://www.facebook.com");
br = new BufferedReader(new InputStreamReader(url.openStream()));
String foundWord = "[\"InitialChatFriendsList\"";
String sCurrentLine;
while ((sCurrentLine = br.readLine()) != null) {
String[] words = sCurrentLine.split(",");
for (String word : words) {
if (word.equals(foundWord)) {
System.out.println("WIN!!!");
break;
}
}
}
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
if (br != null)
br.close();
} catch (IOException ex) {
System.out.println("*** IOException for URL : ");
}
}
}
}
最佳答案
除了您的代码存在一些小缺陷(您应该使用try-with-ressources 和新的 IO 库 NIO),它看起来完全没问题 并且似乎没有逻辑错误。
您在这里遇到了不同的问题。尝试阅读 Facebook 时,您首先需要登录您的帐户,否则您将看到起始页:
我猜您认为从浏览器(例如 Google Chrome)登录就足够了,但事实并非如此。登录信息保存在您使用的特定浏览器的本地存储中,例如在其 cookies 中。我们在 session 中交谈。
作为一个小实验,使用您的谷歌浏览器访问 Facebook 并登录。之后用 Internet Explorer 访问它,它将未登录并且您正在再次阅读起始页。
您的 Java 代码也会发生同样的情况,您只是在阅读起始页,因为对于“Java 浏览器”您还没有登录。您可以通过转储您的 BufferedReader
正在阅读的内容来检查它:
final URL url = new URL("https://www.facebook.com");
try (final BufferedReader br = new BufferedReader(new InputStreamReader(url.openStream()))) {
// Read the whole page
while (true) {
final String line = br.readLine();
if (line == null) {
break;
}
System.out.println(line);
}
}
看看输出,它可能是起始页的来源。
通过浏览器登录 Facebook 后,该网站向我发送以下 cookie:
突出显示的 c_user
cookie 绝对与 session 相关。如果我删除它并刷新页面,那么我就不再登录了。
为了工作,您的 Java 代码需要通过填写表单并提交(或仅通过发送相应的 POST 请求)自行登录,然后收听 Facebook 的回答并保存所有这些 cookie 信息。然而,自己做这件事将是一项艰巨的任务,我不推荐这样做。相反,您可以使用从 Java 内部模拟浏览器的 API,例如 HTMLUnit .或者,您可以使用像 Selenium 这样的库您可以通过它的驱动程序界面直接控制您最喜欢的浏览器。
另一种方法是劫持 session 。您尝试从您的浏览器本地文件中提取相关的 cookie 数据,并在您的 Java 应用程序中重新创建具有相同内容的 cookie 数据。对于非专家来说,如果没有 API,这也是一项艰巨的任务。
现在,非常重要的是,请注意 Facebook(以及 Twitter 等其他网站)有一个公共(public)可用 API ( Facebook for Developers ),旨在简化与自动化软件的交互。当然也有 Java API Wrapper 可用,比如 Facebook4J .因此,如果您尝试抓取 Facebook 等网站,您应该只使用这些 API。
另请注意,许多网站(包括 Facebook)在其服务条款 (TOS) 中声明,通过不使用其 API 的自动化软件进行的交互将被视为违反这些条款。这可能会导致法律后果。
服务条款的摘录:
- Safety
- You will not collect users' content or information, or otherwise access Facebook, using automated means (such as harvesting bots, robots, spiders, or scrapers) without our prior permission.
关于java - 使用java在网页中查找单词,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45905285/
我有以下数据框 (df_hvl),列名“FzListe”和以下数据: FzListe 7MA1, 7OS1 7MA1, 7ZJB 7MA2, 7MA3, 7OS1 76G1, 7MA1, 7OS1 7
我有点小问题。仅当尝试写入的相同字符串/单词不存在时,我才想写入文件。在我的例子中,它是一个 IP 地址和端口,用“:”分隔。如果我手动写入文件,例如 193...:80 和 193...:22,它指
如何返回结果列中的单词示例? 我得到的最接近的是 [\W]{2,}[^,\W].+[?=,] ID 文本 我的结果(完全匹配) 预期(完全匹配) 1 词A,世界B,词C , 世界 B, 字B 2 wo
我想在引号之间得到一个字符串 我知道一个解决方案是: /'.*?'/ 但问题是它不适用于英语中的所有格或收缩格 例如: What is the name of Mario's brother in t
我应该在句子中找到出现最多的单词。 这是我尝试过的,但不起作用。 '); $max = -1; $resultWords = array(); $resultCount = array(); $i =
我是vim的新手。我正在尝试练习(最近阅读了一些教程),但是我发现我不能不突出显示“复制粘贴”中的字符/单词/行。 在Textmate中,我通常使用SHIFT + CTRL + LeftArrowKe
有谁知道一个JSON格式的英语词典,该词典具有(单词,定义和单词类型,例如名词/形容词/动词/副词) 这种格式: [ {"Word" : "Chair", "Definition" : "A
我正在做一些 javascript,同时我注意到我无法替换 html 标记内的“ document.getElementById('label').innerHTML = document.get
您好,我正在使用 groovy 2.1.5,我必须编写一个代码来显示具有给定路径的目录的内容/文件,然后它会备份文件并替换文件中的单词/字符串。 这是我用来尝试替换所选文件中的单词的代码 String
我正在准备一个实验,我想使用python编写程序以识别参与者说出的某些单词。 我在python中搜索了很多有关语音识别的内容,但结果却很复杂(例如CMUSphinx)。 我要实现的是一个程序,该程序接
假设我有以下代码: $size = 23.9 $size = "$size GB" write $size 我想在其他事情上使用相同的变量,即 if ($size -lt 20) {...} 这显然是
我想替换字符串中单词 Date 的所有情况,除非它是 Date()(即 Date 后跟括号)。这是一个字符串示例以及我最初尝试的内容: x gsub("Date", paste("Date:", S
我对 Java 和编程都很陌生,请记住这一点,请不要对我严厉 ^^。接下来,我最近用 Java 进行了一些培训,我喜欢这个挑战,但现在我只是陷入困境。我做了一些示例来查找用户输入的最大字符串,一切都很
我必须给一个数字x,并写x个字符串(单词)。我必须找到写得最多的那一篇。它可以工作,但是当我尝试从文件中读取它时,却没有。例如,如果我执行 a.out'' #include #include in
这里是学习者,如果这个问题看起来很荒谬,请多多包涵。假设我试图引用字符串中的字符而不是字符串本身,我该怎么做呢?我的意思是; 给定:var str = "我想知道一个大脑分散的计算机如何保持理智" 我
这是阿克沙塔。我一直在解析以下数据。我想单独获取每个单词。我可以有一个示例代码以便我可以继续吗 RTRV-HDR RH01 SIMULATOR 09-11-18 16 13 19 M R
我有一个任意字符串,它总是包含至少一个英文单词后跟一系列数字:"Hello World 1234" 我如何只提取 "Hello World" 来自字符串? 最佳答案 在我看来你需要反正则表达式: St
我正在尝试输入一个四个单词的句子,然后能够使用indexOf和子字符串单独打印出每个单词。有什么想法我做错了吗? 已编辑 那么这就是它应该的样子吗?我已经运行了两次,得到了两个不同的答案,所以我不确定
如何在文本开头查找短语(单词) 我需要非常快速的解决方案来查明文本是否以某些已知短语开头 我在 Mysql (innodb) 表中的短语如下: CREATE TABLE IF NOT EXISTS `
我在 MYSQL 表中有一本字典,该表由 240 000 个单词组成。例如,如果我有字母 G、I、G、S、N> 和 O 我想选择表中包含所有或部分这些字母(并且没有其他字母)的所有单词。 可接受的词语
我是一名优秀的程序员,十分优秀!