- 浏览: 322392 次
- 性别:
- 来自: 成都
文章分类
最新评论
-
lst923:
...
java 实现图片裁剪 -
kakarottoz:
多谢博主分享,正好用到!
java 实现图片裁剪 -
Vcb:
http://osgi.jxtech.net 是一个完全基于O ...
OSGi介绍 -
Vcb:
是一个完全基于OSGi的开发平台,有在线演示,免费插件可供下 ...
OSGi介绍 -
mikey_5:
谢谢分享,原来设置: style="word-bre ...
td内容自动换行
本文是参考网络文章测试整理,报歉忘记参考地址了,要是作者有意见就请联系我.文中只是对程序的运行做了测试,但理论没有去考证正确性,等后面研究下再完善.这只是做参考
代码:
HttpURLConnection.connect函数,实际上只是建立了一个与服务器的tcp连接,并没有实际发送http请求。无论是post还是get,http请求实际上直到HttpURLConnection.getInputStream()这个函数里
面才正式发送出去。
在httpRequestPost() 中,顺序很重要,对connection对象的一切配置(那一堆set函数)都必须要在connect()函数执行之前完成。而对 outputStream的写操作,又必须要在inputStream的
读操作之前。这些顺序实际上是由http请求的格式决定的。
http 请求实际上由两部分组成,一个是http头,所有关于此次http请求的配置都在http头里面定义,一个是正文content,在connect()函数里面,会根据HttpURLConnection对象的配置值生
成http头,因此在调用connect函数之前,就必须把所有的配置准备好。
紧接着http头的是http请求的正文,正文的内容通过outputStream写入,实际上outputStream不是一个网络流,充其量是个字符串流,往里面写入的东西不会立即发送到网络,而是在流关闭
后,根据输入的内容生成http正文。
至此,http请求的东西已经准备就绪。在getInputStream()函数调用的时候,就会把准备好的http请求正式发送到服务器了,然后返回一个输入流,用于读取服务器对于此次http请求的返回
信息。由于http请求在getInputStream的时候已经发送出去了(包括http头和正文),因此在getInputStream()函数之后对connection对象进行设置(对http头的信息进行修改)或者写入 outputStream
(对正文进行修改)都是没有意义的了,执行这些操作会导致异常的发生
post请求的OutputStream实际上不是网络流,而是写入内存,在getInputStream中才真正把写道流里面的内容作为正文与根据之前的配置生成的http request头合并成真正的http request,
并在此时才真正向服务器发送。
HttpURLConnection.setChunkedStreamingMode 函数可以改变这个模式,设置了ChunkedStreamingMode后,不再等待OutputStream关闭后生成完整的http request一次过发送,而是先发送
http request头,正文内容则是网路流的方式实时传送到服务器。实际上是不告诉服务器http正文的长度,这种模式适用于向服务器传送较大的或者是不容易获取长度的数据,如文件。
代码:
import java.io.BufferedReader; import java.io.DataOutputStream; import java.io.InputStreamReader; import java.net.HttpURLConnection; import java.net.URL; import java.net.URLEncoder; /** * HttpURLConnection 模拟浏览器http请求处理测试 * * 整体操作流程(注意顺序) * 1.根据url地址创建URL对象 * 2.url.openConnection() 得到HttpURLConnection * 3.设置HttpURLConnection的配置(会根据配置生成http请求头信息) * 4.httpConn.connect()建立与服务器的TCP连接 * 5.通过httpConn得到输出流,并写入参数 * 6.通过httpConn得到输入流,并读取服务器返回信息(这时才真正产生http请求发送给服务器,但可以根据配置来改变;一般返回可能是html字符串) * * httpRequestPost/httpRequestGet两种方式测试通过,返回的是html字符串(后台是jsp) * */ public class HttpURLConnectionTest { public static void main(String[] strs) throws Exception{ HttpURLConnectionTest t = new HttpURLConnectionTest(); String url = "http://localhost:8080/URLTest/filesystem/fileBrowse.do"; t.httpUrlConnection(url); } private void httpUrlConnection(String urlStr) throws Exception{ httpRequestGet(urlStr); httpRequestPost(urlStr); } /** * http post请求 * @param urlStr URL地址 * @throws Exception */ private void httpRequestPost(String urlStr) throws Exception{ URL url = new URL(urlStr); HttpURLConnection httpConn = (HttpURLConnection)url.openConnection(); //设置是否向connection输出,因为是post请求,参数要放在 http正文内,因此需要设为true httpConn.setDoOutput(true); //是否向connection输入,默认为true httpConn.setDoInput(true); //POST请求方式 httpConn.setRequestMethod("POST"); //post请求不能使用缓存 httpConn.setUseCaches(false); //是否自动执行重定向,默认为true httpConn.setInstanceFollowRedirects(true); //配置本次连接的Content-type,配置为application/x-www-form-urlencoded的意思是正文是urlencoded编码过的form参数 //下面我们可以看到我们对正文内容使用URLEncoder.encode 进行编码 httpConn.setRequestProperty("Content-Type", "application/x-www-form-urlencoded"); //连接,从openConnection()至此的配置必须要在connect之前完成, 注意的是connection.getOutputStream会隐含的进行connect。 httpConn.connect(); DataOutputStream dos = new DataOutputStream(httpConn.getOutputStream()); //发送正文,正文内容其实跟get的URL中'?'后的参数字符串一致 word=wait&tn=news&from=news String content = "filePath=" + URLEncoder.encode("设计资料/设计", "utf-8"); //DataOutputStream.writeBytes将字符串中的16位的unicode字符以8位的字符形式写道流里面 dos.writeBytes(content); //刷新流 dos.flush(); //关闭流 dos.close(); // 取得输入流,并使用Reader读取 BufferedReader reader = new BufferedReader(new InputStreamReader(httpConn.getInputStream())); System.out.println("=========post request接收数据内容开始============"); String lines; while ((lines = reader.readLine()) != null) { System.out.println(lines); } reader.close(); System.out.println("=========post request接收数据内容结束============"); httpConn.disconnect(); } /** * http get 请求 * @param urlStr 请求URL地址 * @throws Exception */ private void httpRequestGet(String urlStr) throws Exception{ //URL拼接,如:"http://www.baidu.com?name=HI,中国",这里对特殊字符进行了编码,不然会产生乱码 URL url = new URL(urlStr + "?filePath=" + URLEncoder.encode("设计资料/设计", "utf-8")); //openConnection函数会根据URL的协议返回不同的URLConnection子类的对象 //这里URL是一个http,因此实际返回的是HttpURLConnection HttpURLConnection httpConn = (HttpURLConnection)url.openConnection(); //进行连接,实际上request要在下一句的connection.getInputStream()函数中才会真正发到 服务器****待验证 httpConn.connect(); // 取得输入流,并使用Reader读取 BufferedReader reader = new BufferedReader(new InputStreamReader(httpConn.getInputStream())); System.out.println("=========get request接收数据内容开始============"); String lines; while ((lines = reader.readLine()) != null) { System.out.println(lines); } reader.close(); System.out.println("=========get request接收数据内容结束============"); httpConn.disconnect(); } /** * http post 请求(未测试) * * @param urlStr * @throws Exception */ public static void httpRequestPostBig(String urlStr) throws Exception { URL postUrl = new URL(urlStr); HttpURLConnection connection = (HttpURLConnection) postUrl .openConnection(); connection.setDoOutput(true); connection.setDoInput(true); connection.setRequestMethod("POST"); connection.setUseCaches(false); connection.setInstanceFollowRedirects(true); connection.setRequestProperty("Content-Type","application/x-www-form-urlencoded"); //与httpRequestPost()的不同,设置了块大小为5字节 connection.setChunkedStreamingMode(5); connection.connect(); /* * 注意,下面的getOutputStream函数工作方式于在httpRequestPost()里面的不同 * 在httpRequestPost()里面该函数仍在准备http request,没有向服务器发送任何数据 * 而在这里由于设置了ChunkedStreamingMode,getOutputStream函数会根据connect之前的配置 * 生成http request头,先发送到服务器。 */ DataOutputStream out = new DataOutputStream(connection .getOutputStream()); String content = "name=" + URLEncoder.encode("发送到服务器 " + " " + "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa", "utf-8"); out.writeBytes(content); out.flush(); out.close(); //到此时服务器已经收到了完整的http request了,而在httpRequestPost()函数里,要等到下一句getInputStream()服务器才能收到http请求。 BufferedReader reader = new BufferedReader(new InputStreamReader( connection.getInputStream())); out.flush(); out.close(); String line; System.out.println("==========post request开始=========="); while ((line = reader.readLine()) != null) { System.out.println(line); } System.out.println("==========post request结束=========="); reader.close(); connection.disconnect(); } }
HttpURLConnection.connect函数,实际上只是建立了一个与服务器的tcp连接,并没有实际发送http请求。无论是post还是get,http请求实际上直到HttpURLConnection.getInputStream()这个函数里
面才正式发送出去。
在httpRequestPost() 中,顺序很重要,对connection对象的一切配置(那一堆set函数)都必须要在connect()函数执行之前完成。而对 outputStream的写操作,又必须要在inputStream的
读操作之前。这些顺序实际上是由http请求的格式决定的。
http 请求实际上由两部分组成,一个是http头,所有关于此次http请求的配置都在http头里面定义,一个是正文content,在connect()函数里面,会根据HttpURLConnection对象的配置值生
成http头,因此在调用connect函数之前,就必须把所有的配置准备好。
紧接着http头的是http请求的正文,正文的内容通过outputStream写入,实际上outputStream不是一个网络流,充其量是个字符串流,往里面写入的东西不会立即发送到网络,而是在流关闭
后,根据输入的内容生成http正文。
至此,http请求的东西已经准备就绪。在getInputStream()函数调用的时候,就会把准备好的http请求正式发送到服务器了,然后返回一个输入流,用于读取服务器对于此次http请求的返回
信息。由于http请求在getInputStream的时候已经发送出去了(包括http头和正文),因此在getInputStream()函数之后对connection对象进行设置(对http头的信息进行修改)或者写入 outputStream
(对正文进行修改)都是没有意义的了,执行这些操作会导致异常的发生
post请求的OutputStream实际上不是网络流,而是写入内存,在getInputStream中才真正把写道流里面的内容作为正文与根据之前的配置生成的http request头合并成真正的http request,
并在此时才真正向服务器发送。
HttpURLConnection.setChunkedStreamingMode 函数可以改变这个模式,设置了ChunkedStreamingMode后,不再等待OutputStream关闭后生成完整的http request一次过发送,而是先发送
http request头,正文内容则是网路流的方式实时传送到服务器。实际上是不告诉服务器http正文的长度,这种模式适用于向服务器传送较大的或者是不容易获取长度的数据,如文件。
发表评论
-
hibernate集合映射inverse和cascade详解
2013-05-04 12:14 949网上转载,出处不详 1、到底在哪用cascade=" ... -
java.lang.UnsupportedClassVersionError
2013-04-03 15:33 1127java.lang.UnsupportedClassVersi ... -
Hibernate实体注解
2013-04-03 15:29 1112转自:http://blog.csdn.net/sleepin ... -
转:Maven实战
2013-03-06 12:54 0转自http://www.iteye.com/topic/11 ... -
Spring定时器在SSH框架中的应用
2013-02-28 14:26 1151转自网络,来源不详.... 并非应用系统中发生的所有事情都是 ... -
ASCII字符集详解
2013-02-19 18:03 4960http://www.crifan.com/files/d ... -
安装eclipse windowbuilder
2013-02-17 10:01 2298windowbuilder,就是原来的SWT Designe ... -
点阵输出字符
2013-02-06 13:38 1230http://www.oschina.net/code/sni ... -
Hibernate主键生成策略
2013-01-28 15:50 8651) assigned 主键由外部程 ... -
结束多层循环
2013-01-23 12:28 1472没有啥意义的东西 public static void m ... -
JDBC Batch 批量插入
2013-01-22 17:02 1101JdbcBatchInsert.java import j ... -
JDBC 操作 oracle blob
2013-01-18 10:56 3976jdbc 插入、读取oracle blob字段 pac ... -
java.lang.UnsupportedClassVersionError: Bad version number in .class file
2013-01-17 13:30 943备忘一下: 导入一个工程后,运行时出现java.lang.Un ... -
List<Map> 自定义排序
2012-12-19 13:05 2504对list根据自定义方法排序记要 List list = ... -
后台拼接js代码字符串,处理特殊转义字符
2012-12-13 17:51 5329因为在JS程序代码中,如果生成的字符串中包含特殊字符,那程序容 ... -
java 实现图片裁剪
2012-10-26 15:04 14921import java.awt.Rectangle; i ... -
jar 的使用
2012-10-13 17:39 911偶儿用下,都是临时去查,现在把相关资料记录在这 执行:jav ... -
自动拆箱的bug
2012-10-09 09:13 988在这看到的代码,第二次调用 fun时,出NULL指针异常,看了 ... -
map的三种遍历方法
2012-09-28 16:06 784http://www.cnblogs.com/christ/a ... -
java日期间隔
2012-09-25 16:51 893/** * Date与Date之间的间隔小时 ...
相关推荐
在Java编程中,有时我们需要模拟浏览器发送HTTP请求,例如调用外部接口或API。`HttpURLConnection`是Java标准库提供的一种轻量级的HTTP客户端,它允许我们在后台代码中发送GET和POST请求。本篇文章将深入讲解如何...
- **HttpURLConnection**:Java标准库提供的基础HTTP客户端,可以用来发送GET和POST请求,模拟浏览器行为。 - **Apache HttpClient**:一个功能强大的HTTP客户端库,提供了更灵活和高效的API来处理HTTP请求。 - *...
这些需求可以通过模拟HTTP请求的方式实现。本篇文章将详细介绍如何使用Java语言来模拟发送网页请求,并特别关注POST请求及Cookie的处理。 #### 二、模拟发送GET请求 首先,我们来看看如何使用Java的`java.net.URL`...
在Android开发中,模拟HTTP请求是一项基础且重要的任务,它允许应用与远程服务器进行数据交互,获取或发送信息。本文将深入探讨如何在Android平台上实现HTTP请求,主要涉及以下几个方面: 1. **HTTP协议基础**:...
为了解决这个问题,我们需要实现session共享,使得多次HTTP请求之间能够识别彼此,模拟浏览器的会话保持。 首先,理解Session和Cookie的概念是关键。Session是服务器端保存用户状态的一种方式,而Cookie则是客户端...
我们可以使用 Java 语言来发送 HTTP 请求,并将 Cookie 信息写入到 HTTP 头部中,以便模拟用户的登陆行为。 Java 模拟 Cookie 登陆的实现 下面是一个简单的 Java 模拟 Cookie 登陆的示例代码: ```java import ...
在Android应用开发中,模拟HTTP请求是至关重要的一个环节,特别是在与服务器进行数据交互时。本资料包聚焦于这一主题,提供了源码示例供学习参考。以下将详细讲解Android中进行HTTP请求的方法、原理以及涉及到的相关...
1. **HTTP客户端库**:Java提供了多种库来发送HTTP请求,如HttpURLConnection(Java内置)、Apache HttpClient或OkHttp。这些库允许我们构造POST请求,模拟用户登录过程,通常需要设置请求头(如User-Agent)、POST...
HttpURLConnection可以模拟浏览器的行为,向服务器发送请求,并获取服务器的响应。 二、JAVA通过HttpURLConnection上传文件的方法 下面是一个使用HttpURLConnection上传文件的示例代码: ```java public class ...
Java中发送HTTP请求的方式有很多,如使用`java.net.HttpURLConnection`、`java.net.URL`、Apache HttpClient库或OkHttp库。本工具类主要基于`HttpURLConnection`,因为它是Java标准库的一部分,无需额外依赖,且能...
在Java中,`java.net.URL`类可以用于解析和表示URL,`java.net.HttpURLConnection`或`java.net.URLConnection`可以用来发起HTTP请求。 2. **页面加载与渲染**:加载HTML页面后,浏览器需要解析HTML代码并渲染成可视...
3. **HTTP请求**:对于HTTP请求,通常使用`HttpURLConnection`,它是`URLConnection`的子类,提供了更多的HTTP特性。通过`(HttpURLConnection) connection`转换类型,可以设置请求方法(如GET或POST)、设置请求头等...
在测试HTTP请求时,通常会用到如Postman这样的工具,或者在代码中使用HttpURLConnection、HttpClient、OkHttp等库来模拟发送GET、POST等请求。 描述中的链接指向了一篇博客文章,虽然内容未给出,但可以推测博主...
在构建浏览器实例时,需要创建各种类来模拟浏览器的功能,如URL解析、HTTP请求等。 2. **JAVA网络编程**:此实例涉及JAVA的`java.net`包,它包含了处理网络连接的类,如`URL`、`URLConnection`和`HttpURLConnection...
在IT行业中,模拟浏览器发送HTTP消息是一项常见的任务,特别是在自动化测试、数据抓取或API接口调试等场景。这里我们关注的是模拟Internet Explorer(IE)浏览器发送HTTP消息,这通常是通过编程实现的,例如使用...
在编程中,像Python的`requests`库或者Java的`HttpURLConnection`类都可以用来发送HTTP请求,并且可以通过设置代理来实现请求的拦截。例如,使用Python的`mitmproxy`库可以创建一个中间人代理,对HTTP请求进行拦截和...
- **设置请求头**:模拟浏览器行为,添加必要的请求头,如User-Agent,Content-Type等。 - **构造请求体**:创建一个包含用户名和密码的数据字符串,根据Content-Type设置编码格式。 - **写入请求数据**:调用...
6. **模拟浏览器行为**: 为了使模拟登录更接近真实用户,我们可能需要复制浏览器的一些行为,比如设置User-Agent,处理Referer字段,以及处理其他可能影响登录的HTTP头。 7. **持久化会话**: 如果登录成功,我们...
对于动态加载,可能需要用到Selenium等工具来模拟浏览器行为;对于反爬策略,可能需要定期更换User-Agent,设置延迟,甚至使用代理IP。 总的来说,Java爬虫模拟登录是一项涉及网络请求、HTML解析、Cookie管理等多个...