`
kakaluyi
  • 浏览: 446570 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

Java发送Html请求,并解析返回的请求

阅读更多

今天是2008年7月7日星期一,下午一直在学校做个人开始页面。因为离不开google的翻译,所以想把google的翻译整合到我的开始页面中来,于是乎就遇到了一个问题,怎样使用java程序发送http请求然后截获远程服务器返回的数据进行适当处理之后再输出?另外,google的翻译页面是使用post的方法提交数据的,无法直接通过网址进行处理,于是乎,这又涉及到了一个怎样使用java去post数据的问题。
经过拜读百度知道的提问(花了我20分),找到了一个htmlparser的jar包组件,据说是可以很高效率的进行html的解析。于是乎,立马下载了一个过来。(文后附件中有)试了一下果然不错。同时,在这个过程中也学会了怎样利用java来和其它网站交互,这可是一个非常不错的功能,配合htmlparser,可以随心所欲的截取别人网站的信息了!
废话不多说了,下面是具体的使用步骤。

首先,向一个Web站点发送POST请求只需要简单的几步:
注意,这里不需要导入任何第三方包

Java代码 复制代码
  1. package com.test;   
  2.   
  3. import java.io.BufferedReader;   
  4. import java.io.IOException;   
  5. import java.io.InputStream;   
  6. import java.io.InputStreamReader;   
  7. import java.io.OutputStreamWriter;   
  8. import java.net.URL;   
  9. import java.net.URLConnection;   
  10.   
  11. public class TestPost {   
  12.   
  13.     public static void testPost() throws IOException {   
  14.   
  15.         /**  
  16.          * 首先要和URL下的URLConnection对话。 URLConnection可以很容易的从URL得到。比如: // Using  
  17.          *  java.net.URL and //java.net.URLConnection  
  18.          */  
  19.         URL url = new URL("http://www.faircanton.com/message/check.asp");   
  20.         URLConnection connection = url.openConnection();   
  21.         /**  
  22.          * 然后把连接设为输出模式。URLConnection通常作为输入来使用,比如下载一个Web页。  
  23.          * 通过把URLConnection设为输出,你可以把数据向你个Web页传送。下面是如何做:  
  24.          */  
  25.         connection.setDoOutput(true);   
  26.         /**  
  27.          * 最后,为了得到OutputStream,简单起见,把它约束在Writer并且放入POST信息中,例如: ...  
  28.          */  
  29.         OutputStreamWriter out = new OutputStreamWriter(connection   
  30.                 .getOutputStream(), "8859_1");   
  31.         out.write("username=kevin&password=*********"); //post的关键所在!   
  32.         // remember to clean up   
  33.         out.flush();   
  34.         out.close();   
  35.         /**  
  36.          * 这样就可以发送一个看起来象这样的POST:   
  37.          * POST /jobsearch/jobsearch.cgi HTTP 1.0 ACCEPT:  
  38.          * text/plain Content-type: application/x-www-form-urlencoded  
  39.          * Content-length: 99 username=bob password=someword  
  40.          */  
  41.         // 一旦发送成功,用以下方法就可以得到服务器的回应:   
  42.         String sCurrentLine;   
  43.         String sTotalString;   
  44.         sCurrentLine = "";   
  45.         sTotalString = "";   
  46.         InputStream l_urlStream;   
  47.         l_urlStream = connection.getInputStream();   
  48.         // 传说中的三层包装阿!   
  49.         BufferedReader l_reader = new BufferedReader(new InputStreamReader(   
  50.                 l_urlStream));   
  51.         while ((sCurrentLine = l_reader.readLine()) != null) {   
  52.             sTotalString += sCurrentLine + "\r\n";   
  53.   
  54.         }   
  55.         System.out.println(sTotalString);   
  56.     }   
  57.   
  58.     public static void main(String[] args) throws IOException {   
  59.   
  60.         testPost();   
  61.   
  62.     }   
  63.   
  64. }  
package com.test;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.net.URL;
import java.net.URLConnection;

public class TestPost {

	public static void testPost() throws IOException {

		/**
		 * 首先要和URL下的URLConnection对话。 URLConnection可以很容易的从URL得到。比如: // Using
		 *  java.net.URL and //java.net.URLConnection
		 */
		URL url = new URL("http://www.faircanton.com/message/check.asp");
		URLConnection connection = url.openConnection();
		/**
		 * 然后把连接设为输出模式。URLConnection通常作为输入来使用,比如下载一个Web页。
		 * 通过把URLConnection设为输出,你可以把数据向你个Web页传送。下面是如何做:
		 */
		connection.setDoOutput(true);
		/**
		 * 最后,为了得到OutputStream,简单起见,把它约束在Writer并且放入POST信息中,例如: ...
		 */
		OutputStreamWriter out = new OutputStreamWriter(connection
				.getOutputStream(), "8859_1");
		out.write("username=kevin&password=*********"); //post的关键所在!
		// remember to clean up
		out.flush();
		out.close();
		/**
		 * 这样就可以发送一个看起来象这样的POST: 
		 * POST /jobsearch/jobsearch.cgi HTTP 1.0 ACCEPT:
		 * text/plain Content-type: application/x-www-form-urlencoded
		 * Content-length: 99 username=bob password=someword
		 */
		// 一旦发送成功,用以下方法就可以得到服务器的回应:
		String sCurrentLine;
		String sTotalString;
		sCurrentLine = "";
		sTotalString = "";
		InputStream l_urlStream;
		l_urlStream = connection.getInputStream();
		// 传说中的三层包装阿!
		BufferedReader l_reader = new BufferedReader(new InputStreamReader(
				l_urlStream));
		while ((sCurrentLine = l_reader.readLine()) != null) {
			sTotalString += sCurrentLine + "\r\n";

		}
		System.out.println(sTotalString);
	}

	public static void main(String[] args) throws IOException {

		testPost();

	}

}



执行的结果:(果真是返回了验证后的html阿!神奇!)

Html代码 复制代码
  1. <html>  
  2. <head>  
  3. <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />  
  4. <title>账户已经冻结</title>  
  5. <style type="text/css">  
  6. <!--   
  7. .temp {   
  8.     font-family: Arial, Helvetica, sans-serif;   
  9.     font-size: 14px;   
  10.     font-weight: bold;   
  11.     color: #666666;   
  12.     margin: 10px;   
  13.     padding: 10px;   
  14.     border: 1px solid #999999;   
  15. }   
  16. .STYLE1 {color: #FF0000}   
  17. -->  
  18. </style>  
  19. </head>  
  20.   
  21. <body>  
  22. <p> </p>  
  23. <p> </p>  
  24. <p> </p>  
  25. <table width="700" border="0" align="center" cellpadding="0" cellspacing="0" class="temp">  
  26.   <tr>  
  27.     <td width="135" height="192"><div align="center"><img src="images/err.jpg" width="54" height="58"></div></td>  
  28.     <td width="563"><p><span class="STYLE1">登录失败</span><br>  
  29.         <br>  
  30.     您的帐户活跃指数低于系统限制,您的帐户已经被暂时冻结。<br>  
  31.     请您联系网络主管或者人事主管重新激活您的帐户。</p>  
  32.     </td>  
  33.   </tr>  
  34. </table>  
  35. <p> </p>  
  36. </body>  
  37. </html>  
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>账户已经冻结</title>
<style type="text/css">
<!--
.temp {
	font-family: Arial, Helvetica, sans-serif;
	font-size: 14px;
	font-weight: bold;
	color: #666666;
	margin: 10px;
	padding: 10px;
	border: 1px solid #999999;
}
.STYLE1 {color: #FF0000}
-->
</style>
</head>

<body>
<p> </p>
<p> </p>
<p> </p>
<table width="700" border="0" align="center" cellpadding="0" cellspacing="0" class="temp">
  <tr>
    <td width="135" height="192"><div align="center"><img src="images/err.jpg" width="54" height="58"></div></td>
    <td width="563"><p><span class="STYLE1">登录失败</span><br>
        <br>
    您的帐户活跃指数低于系统限制,您的帐户已经被暂时冻结。<br>
    请您联系网络主管或者人事主管重新激活您的帐户。</p>
    </td>
  </tr>
</table>
<p> </p>
</body>
</html>





一些Web站点用POST形式而不是GET,这是因为POST能够携带更多的数据,而且不用URL,这使得它看起来不那么庞大。使用上面列出的大致的代码,Java代码可以和这些站点轻松的实现对话。


得到html以后,分析内容就显得相对轻松了。现在就可以使用htmlparser了,下面是一个简单的示例程序,过多的解释我就不说了,相信代码能够说明一切的!


Java代码 复制代码
  1. package com.test;   
  2.   
  3. import org.htmlparser.Node;   
  4. import org.htmlparser.NodeFilter;   
  5. import org.htmlparser.Parser;   
  6. import org.htmlparser.filters.TagNameFilter;   
  7. import org.htmlparser.tags.TableTag;   
  8. import org.htmlparser.util.NodeList;   
  9.   
  10. /**  
  11. * 标题:利用htmlparser提取网页纯文本的例子  
  12. */  
  13. public class TestHTMLParser {   
  14.   public static void testHtml() {   
  15.     try {   
  16.         String sCurrentLine;   
  17.         String sTotalString;   
  18.         sCurrentLine = "";   
  19.         sTotalString = "";   
  20.         java.io.InputStream l_urlStream;   
  21.         java.net.URL l_url = new java.net.URL("http://www.ideagrace.com/html/doc/2006/07/04/00929.html");   
  22.         java.net.HttpURLConnection l_connection = (java.net.HttpURLConnection) l_url.openConnection();   
  23.         l_connection.connect();   
  24.         l_urlStream = l_connection.getInputStream();   
  25.         java.io.BufferedReader l_reader = new java.io.BufferedReader(new java.io.InputStreamReader(l_urlStream));   
  26.         while ((sCurrentLine = l_reader.readLine()) != null) {   
  27.           sTotalString += sCurrentLine+"\r\n";   
  28.         //  System.out.println(sTotalString);   
  29.         }   
  30.         String testText = extractText(sTotalString);   
  31.         System.out.println( testText );   
  32.   
  33.     } catch (Exception e) {   
  34.         e.printStackTrace();   
  35.     }   
  36.   
  37.   }   
  38.     
  39.   public static String extractText(String inputHtml) throws Exception {   
  40.     StringBuffer text = new StringBuffer();   
  41.     Parser parser = Parser.createParser(new String(inputHtml.getBytes(),"GBK"), "GBK");   
  42.     // 遍历所有的节点   
  43.     NodeList nodes = parser.extractAllNodesThatMatch(new NodeFilter() {   
  44.         public boolean accept(Node node) {   
  45.           return true;   
  46.         }   
  47.     });   
  48.   
  49.     System.out.println(nodes.size()); //打印节点的数量   
  50.     for (int i=0;i<nodes.size();i++){   
  51.          Node nodet = nodes.elementAt(i);   
  52.          //System.out.println(nodet.getText());    
  53.         text.append(new String(nodet.toPlainTextString().getBytes("GBK"))+"\r\n");             
  54.     }   
  55.     return text.toString();   
  56.   }   
  57.     
  58.   public static void test5(String resource) throws Exception {   
  59.     Parser myParser = new Parser(resource);   
  60.     myParser.setEncoding("GBK");   
  61.     String filterStr = "table";   
  62.     NodeFilter filter = new TagNameFilter(filterStr);   
  63.     NodeList nodeList = myParser.extractAllNodesThatMatch(filter);   
  64.     TableTag tabletag = (TableTag) nodeList.elementAt(11);   
  65.         
  66.   }   
  67.   
  68.   public static void main(String[] args) throws Exception {   
  69.     // test5("http://www.ggdig.com");   
  70.     testHtml();   
  71.   }   
  72. }  
分享到:
评论

相关推荐

    Java发送Http请求,解析html返回

    Java发送Http请求,解析html返回

    JAVA发送HTTP请求,返回HTTP响应内容

    总结来说,Java发送HTTP请求涉及使用`java.net.HttpURLConnection`类,通过构造URL、设置请求属性、发送请求并解析响应内容来完成。封装这些操作到一个类中可以使代码更易于管理和复用。`HttpResponse`类则用于存储...

    Java编程:发送HTTP请求,返回响应内容

    总的来说,Java发送HTTP请求和处理响应涉及网络编程、HTTP协议理解、异常处理、输入/输出流操作,以及可能的HTML解析和网页爬虫技术。这些知识对于任何想要构建Web客户端应用或进行数据抓取的开发者来说都是必不可少...

    java实现http请求以及解析json与java对象转换 项目源代码实例

    具体到这个"java实现http请求以及解析json与java对象转换"项目,你可以期待以下几个关键知识点: 1. **HTTP请求**: - GET请求:获取服务器上的资源。 - POST请求:向服务器提交数据,常用于表单提交或API接口...

    Android向Java后台发送请求并返回Json数据

    总结,Android向Java后台发送请求并返回Json数据涉及的关键步骤包括选择网络请求库、设置请求参数、发送请求、处理响应以及解析Json数据。通过以上步骤,开发者可以实现Android客户端与后台服务的高效通信。在实际...

    java HttpClient 发送GET请求和带有表单参数的POST请求教程例子

    接下来,调用`execute()`方法来执行请求,最后解析返回的响应。 ##### 示例代码: ```java public static String sendGetRequest(String requestUrl) { long responseLength = 0; String responseContent = null...

    java发送http/https请求(get/post)Demo,亲测可用

    在处理返回的JSON数据时,Java提供了`org.json`库,可以方便地解析和构建JSON对象。例如: ```java import org.json.JSONObject; // 假设response是返回的JSON字符串 JSONObject jsonObject = new JSONObject...

    java发送http请求报文json

    对于 Java 开发者来说,能够熟练掌握如何使用 Java 来构建 HTTP 请求并发送 JSON 数据是一项重要的技能。下面将详细介绍如何使用 Java 发送一个包含 JSON 数据的 HTTP POST 请求。 #### 代码解析 该示例代码展示了...

    JAVA发送HttpClient请求及接收请求结果过程

    ### JAVA发送HttpClient请求及接收请求结果过程 #### 一、概述 在Java开发过程中,经常需要与外部系统进行HTTP通信,比如发送POST或GET请求来获取数据或提交数据。Apache HttpClient是一个强大的HTTP客户端库,提供...

    Java发https请求证书问题

    ### Java 发送 HTTPS 请求时遇到证书问题解析 在进行网络通信的过程中,HTTPS 协议由于其安全性被广泛应用。本文将围绕“Java 发送 HTTPS 请求证书问题”这一主题展开讨论,通过对给定文件中的代码示例及操作步骤...

    java代码发送JSON格式的httpPOST请求

    下面将详细解析如何利用`HttpURLConnection`来构建并发送一个包含JSON数据的POST请求: ```java import java.io.BufferedReader; import java.io.DataOutputStream; import java.io.IOException; import java.io....

    Java 解析http请求处理结果

    本主题将深入探讨如何使用Java解析HTTP请求处理结果,包括发送GET和POST请求、处理响应、解析网页内容以及应对常见问题。 首先,Java中的HttpURLConnection是标准库中用于执行HTTP请求的核心类。我们可以使用它来...

    java http 发送xml报文(java发送xml报文实例+参数)

    本篇文章将深入探讨如何在Java中利用HTTP协议发送XML报文,并通过实例和参数解析具体实现步骤。 首先,我们需要引入Java的HttpURLConnection类,这是Java标准库提供的HTTP客户端接口。发送XML报文通常涉及到POST或...

    java中main方法发送httpPost请求

    发送请求并读取响应状态码: ```java connection.connect(); int responseCode = connection.getResponseCode(); ``` 6. **处理响应** 读取服务器返回的数据,可能是JSON、XML或其他格式: ```java try...

    JAVA调用webservice并解析xml

    本教程将深入讲解如何在Java环境中,利用Eclipse或MyEclipse IDE调用Web服务并解析返回的XML数据。 首先,理解Web服务的基本概念是关键。Web服务是一种通过HTTP协议传输数据的应用程序接口(API)。SOAP是基于XML的...

    发送Post请求,内容格式为xml,并获取响应内容

    在给定的代码片段中,主要展示了如何使用Java中的Apache HttpClient库发送一个包含XML数据的POST请求,并接收响应。下面是对关键部分的详细分析: 1. **导入必要的库**:代码首先导入了处理网络请求、输入输出流...

    jdom解析xml java发送post请求

    在这个场景下,我们将探讨如何使用JDOM来解析XML,并通过Java实现POST请求,从而与PHP服务器进行交互,获取或发送远程资源。 首先,理解XML的基本结构至关重要。XML文档由元素、属性、文本内容等组成,这些元素通过...

    Java Http请求传json数据乱码问题的解决

    在Java代码中,当通过HTTP请求传输包含中文的JSON数据时,前端通常会使用JavaScript的`JSON.stringify`函数将JSON对象转换为字符串,并通过GET或POST请求传递给后端。在JavaScript中,字符串默认使用UTF-8编码,因此...

    java-http请求jar包

    Java发送HTTP请求是进行网络通信的基本操作之一,广泛应用于数据获取、API调用等场景。在Java中,Apache HttpClient库是一个强大的工具,它允许开发者高效、灵活地处理HTTP请求。这个"java-http请求jar包"实际上就是...

    JAVA发送HttpClient请求及接收请求完整代码实例

    设置请求头可以帮助服务器正确解析请求。 以上就是使用Java HttpClient发送HTTP请求和接收响应的基本操作。在实际开发中,可能还需要处理更多细节,比如重试机制、超时设置、Cookie管理等。HttpClient提供了丰富的...

Global site tag (gtag.js) - Google Analytics