HttpURLConnection用法
在SDK中的URLConnection链接Servlet的问题
1.URL的请求分类GET和POST
GET请求可以获取页面静态的值,参数放URL后,传给Serverlct
POST的参数是存放于http请求的正文中
2.URLConnection的对象问题
根据URL生成URLconnection,URLConnection在转成HttpUrlConnection.
URL url = new URL("www.baidu.com");
HttpUrlConnection httpUrlConnection = (HttpURLConnection) url.openConnection();
3.HttpURLConnection对象参数问题
设置是否向HttpURLConnection输出,因为这个是Post请求,参数要放在http正文中,因此要设置为true
httpUrlConnection.setDoOutput(true);
设置是否从httpUrlConnection读入,默认情况下是true
httpUrlConnection.setDoInput(true);
Post请求不能使用缓存
httpUrlConnection.setUseCaches(false);
设定传输的内容结果是可以序列化的JAVA对象
(假设不设置,在传送序列化对象时,当WEB服务器默认的不是这种类型时可能抛出java.io.eofexcrption)
httpUrlConnection.setRequestProperty("Content-type","application/x-java-serialized-object");
//设定请求的方式必须是POST,默认时GET
httpUrlConnection.setRequestMethod("Post");
分装完毕
httpUrlConnection.connect();
getOutPutStream会隐含着connect,所以在开发环境中不调用上述的connect()也可以
OutputStream outStrm = httpUrlConnection.getOutputStream()
现在通过输出流对象构建对象的输出流,以实现输出可序列化的对象
OutputStreamWriter out = new OutputStreamWriter(httpUrlConnection.getOutputStream(), "UTF-8");
向对象输出流写数据,这些数据保存到内存中
objectOutputStream.writeObject("测试字符串")
//刷新对象输出流,将任何字节都写入潜在流中
objOutputStm.flush()
// 定义BufferedReader输入流来读取URL的响应
BufferedReader in = new BufferedReader( new InputStreamReader(conn.getInputStream(), "UTF-8"));
String line
StringBuilder result = new StringBuilder();;
while ((line = in.readLine()) != null) {
result.append(line);
}
用finally{
关闭输出流和输入流。
in.close();
}
//关闭流对象,不在对输出流对象写入任何东西,先前写入的数据存在于缓存中
objOutputStm.close();
调用httpURLConnection连接对象的getInputStream()函数
将内存缓冲区封装好完整的HTTP请求电文发送到服务端
InputStream inStrm = httpConn.getInputStream();
HttpURLConnection用法的更多相关文章
- HttpURLConnection用法详解
针对JDK中的URLConnection连接Servlet的问题,网上有虽然有所涉及,但是只是说明了某一个或几个问题,是以FAQ的方式来解决的,而且比较零散,现在对这个类的使用就本人在项目中的使用经验 ...
- 【转】HttpURLConnection用法详解
原文链接:http://www.blogjava.net/supercrsky/articles/247449.html 针对JDK中的URLConnection连接Servlet的问题,网上有虽然有 ...
- [转]Android各大网络请求库的比较及实战
自己学习android也有一段时间了,在实际开发中,频繁的接触网络请求,而网络请求的方式很多,最常见的那么几个也就那么几个.本篇文章对常见的网络请求库进行一个总结. HttpUrlConnection ...
- Android之网络请求库
自己学习android也有一段时间了,在实际开发中,频繁的接触网络请求,而网络请求的方式很多,最常见的那么几个也就那么几个.本篇文章对常见的网络请求库进行一个总结. HttpUrlConnection ...
- Android进阶笔记01:Android 网络请求库的比较及实战(一)
在实际开发中,有的时候需要频繁的网络请求,而网络请求的方式很多,最常见的也就那么几个.本篇文章对常见的网络请求库进行一个总结. 一.使用HttpUrlConnection: 1. HttpUrlCon ...
- Android 几种网络请求的区别与联系
HttpUrlConnection 最开始学android的时候用的网络请求是HttpUrlConnection,当时很多东西还不知道,但是在android 2.2及以下版本中HttpUrlConne ...
- Android 各大网络请求库的比较及实战
自己学习android也有一段时间了,在实际开发中,频繁的接触网络请求,而网络请求的方式很多,最常见的那么几个也就那么几个.本篇文章对常见的网络请求库进行一个总结. HttpUrlConnection ...
- 关于HttpClient,HttpURLConnection,OkHttp的用法
1 HttpClient入门实例 1.1发送get请求 /** * HttpClient发送get请求 * @param url 请求地址 * @return * @throws IOExceptio ...
- HttpURLConnection和HttpClient的简单用法
HttpURLConnection的简单用法:先通过一个URL创建一个conn对象,然后就是可以设置get或者是post方法,接着用流来读取响应结果即可 String html = null; lon ...
随机推荐
- JavaScript splice() 方法
定义和用法 splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目. 注释:该方法会改变原始数组. 例子 1 在本例中,我们将创建一个新数组,并向其添加一个元素: <script ...
- [51nod1532]带可选字符的多字符串匹配
有一个文本串,它的长度为m (1 <= m <= 2000000),现在想找出其中所有的符合特定模式的子串位置. 符合特定模式是指,该子串的长度为n (1 <= n <= 50 ...
- springboot:快速构建一个springboot项目
前言: springboot作为springcloud的基础,springboot的热度一直很高,所以就有了这个springboot系列,花些时间来了解和学习为自己做技术储备,以备不时之需[手动滑稽] ...
- 织梦dedecms如何去除版权中的Power by DedeCms
很多站长在使用dedecms建站过程中,很多人都会调用到dedecms自带的powerby标签,这样在版权信息中就会多出Power by DedeCms这个连接.今天教大家如何去除. 工具/原料 de ...
- 如何完成域名和ip地址的绑定
首先,我们要知道什么是域名绑定,所谓域名绑定就是是指已选定的域名与服务器主机的空间绑定,实在是在域名注册查询上设置或者WEB服务器上设置,使一个域名被指导向一特定空间,从而使访问者访问你的域名的时候就 ...
- tp5 点击刷新验证码
<form action="<{:url('index/index/login')}>" method="post" name="f ...
- 版本控制——TortoiseSVN (3)多版本发布
=================================版权声明================================= 版权声明:原创文章 禁止转载 请通过右侧公告中的“联系邮 ...
- 阿里巴巴Java开发手册评
2016年底的时候阿里巴巴公开了其在内部使用的Java编程规范.随后进行了几次版本修订,目前的版本为v1.0.2版.下载地址可以在其官方社区-云栖社区https://yq.aliyun.com/art ...
- PostgreSql 分页limit
摘录自:http://jingyan.baidu.com/article/a17d528538119b8098c8f2ca.html 语法: select * from persons limit ...
- mysql 性能优化常见命令
mysql 性能优化常见命令: 一: 当发现mysql程序运行缓慢时,在排除sql主机问题之后,可以尝试在schema,table,和sql上进一步进行考查: 1:mysql> show ful ...