博客
关于我
java:后台调用接口链接方式(HttpURLConnection)
阅读量:159 次
发布时间:2019-02-28

本文共 2978 字,大约阅读时间需要 9 分钟。

首先贴了一个完整的方法

public class ConnectionUtils {    /**     *      * @param path  路径     * @param method  查询方法     * @param param  查询参数     * @return     * @throws IOException     */    public static String SearchQualifications(String path, String method, Map
param) throws IOException { OutputStreamWriter out = null; BufferedReader br = null; String data = null; StringBuffer result = new StringBuffer(""); /*处理data信息*/ data = JSONObject.toJSONString(param); URL url = new URL(path); /*打开链接*/ HttpURLConnection httpURLConnection = (HttpURLConnection) url.openConnection(); /*设置请求方式*/ httpURLConnection.setRequestMethod(method); /*设置通用请求属性*/ httpURLConnection.setRequestProperty("accept", "*/*"); httpURLConnection.setRequestProperty("connection", "Keep-Alive"); httpURLConnection.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1)"); httpURLConnection.setRequestProperty("Content-Type", "application/json;charset=utf-8"); //DoOutput设置是否向httpUrlConnection输出,DoInput设置是否从httpUrlConnection读入,此外发送post请求必须设置这两个 httpURLConnection.setDoOutput(true); httpURLConnection.setDoInput(true); /*写入数据*/ out = new OutputStreamWriter(httpURLConnection.getOutputStream(), "UTF-8"); out.write(data); out.flush(); /*获取输入流*/ InputStream inputStream = httpURLConnection.getInputStream(); br = new BufferedReader(new InputStreamReader(inputStream, "UTF-8")); String str = ""; while ((str = br.readLine()) != null) { result.append(str); } String resultStr = result.toString(); return resultStr; }}

 

主要分为了几个模块

1、创建 URL、Connection通道

URL url = new URL(path);/*打开链接*//*对 url 产生的 URLConnection 进行强转*/HttpURLConnection httpURLConnection = (HttpURLConnection) url.openConnection();

2、设置通道属性和请求方式

/*设置请求方式*/        httpURLConnection.setRequestMethod(method);        /*设置通用请求属性*/        httpURLConnection.setRequestProperty("accept", "*/*");        httpURLConnection.setRequestProperty("connection", "Keep-Alive");        httpURLConnection.setRequestProperty("Content-Type", "application/json;charset=utf-8");        //DoOutput设置是否向httpUrlConnection输出,DoInput设置是否从httpUrlConnection读入,此外发送post请求必须设置这两个        httpURLConnection.setDoOutput(true);        httpURLConnection.setDoInput(true);

3、写入数据、读取数据

/*写入数据*/        out = new OutputStreamWriter(httpURLConnection.getOutputStream(), "UTF-8");        out.write(data);        out.flush();        /*获取输入流*/        InputStream inputStream = httpURLConnection.getInputStream();        br = new BufferedReader(new InputStreamReader(inputStream, "UTF-8"));        String str = "";        while ((str = br.readLine()) != null) {            result.append(str);        }        String resultStr = result.toString();        return resultStr;    }

因为我这边调用的接口是返回json字符串类型。所以我是直接返回的 String类型。

暂时就这。

 

 

转载地址:http://eipc.baihongyu.com/

你可能感兴趣的文章
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>