原生java处理influxdb

如有疑问添加qq 1074420209进行沟通,

废话少说直接上代码,这是封装供外部调用的两种请求方式,GET &  POST

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.URLConnection;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.List;
import java.util.Map;

public class HttpUtils {
    /**
     * 向指定URL发送GET方法的请求
     * 
     * @param url   发送请求的URL
     * @param param 请求参数,请求参数应该是 db=db_name&q=select%20*%20from%20test_measurement
     *              的形式。db代表数据库name,q代表查询语句,注意查询语句的特殊字符需进行转码
     * @return URL 所代表远程资源的响应结果
     */
    public static String sendGet(String url, String param,String charset) {
        String result = "";
        BufferedReader in = null;
        try {
            String urlNameString = url + "?" + param;
            URL realUrl = new URL(urlNameString);
            // 打开和URL之间的连接
            URLConnection connection = realUrl.openConnection();
            // 设置通用的请求属性
            connection.setRequestProperty("accept", "*/*");
            connection.setRequestProperty("connection", "Keep-Alive");
            connection.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
            // 建立实际的连接
            connection.connect();
            // 获取所有响应头字段
            Map<String, List<String>> map = connection.getHeaderFields();
            // 遍历所有的响应头字段
            for (String key : map.keySet()) {
                System.out.println(key + "--->" + map.get(key));
            }
            // 定义 BufferedReader输入流来读取URL的响应
            in = new BufferedReader(new InputStreamReader(connection.getInputStream(),charset));
            String line;
            while ((line = in.readLine()) != null) {
                result += line;
            }
        } catch (Exception e) {
            System.out.println("发送GET请求出现异常!" + e);
            e.printStackTrace();
        }
        // 使用finally块来关闭输入流
        finally {
            try {
                if (in != null) {
                    in.close();
                }
            } catch (Exception e2) {
                e2.printStackTrace();
            }
        }
        // System.out.println(result);
        return result;
    }

    /**
     * 
     * @param uri     请求地址 http://localhost:8086/write?db=db_name&u=admin;&p=admin
     *                write代表写入数据,db代表数据库name,u代表用户,p代表密码
     * @param param   请求参数,请求参数应该是'test_measurement,col1=1,col2=2 col3=5,col4=6'的形式。
     *                test_measurement表格名称 col1,col2为tags列 ,col3,col4为fields列
     *                该表格必须有tags列 tags列与fields列之间用空格隔开,当有多条数据要插入表格,用\n隔开
     *                'test_measurement,col1=1,col2=2
     *                col3=3,col4=4\ntest_measurement,col1=5,col2=6 col3=7,col4=8'
     * @param charset 请使用"UTF-8"
     * @return  函数返回
     */
    public static String sendPost(String uri, String param, String charset) {
        String result = null;
        PrintWriter out = null;
        InputStream in = null;
        try {
            URL url = new URL(uri);
            HttpURLConnection urlcon = (HttpURLConnection) url.openConnection();
            urlcon.setDoInput(true);
            urlcon.setDoOutput(true);
            urlcon.setUseCaches(false);
            urlcon.setRequestMethod("POST");
            urlcon.connect();// 获取连接
            out = new PrintWriter(urlcon.getOutputStream());
            out.print(param);
            out.flush();
            in = urlcon.getInputStream();
            BufferedReader buffer = new BufferedReader(new InputStreamReader(in, charset));
            StringBuffer bs = new StringBuffer();
            String line = null;
            while ((line = buffer.readLine()) != null) {
                bs.append(line);
            }
            result = bs.toString();
        } catch (Exception e) {
            System.out.println("[请求异常][地址:" + uri + "][参数:" + param + "][错误信息:" + e.getMessage() + "]");
        } finally {
            try {
                if (null != in)
                    in.close();
                if (null != out)
                    out.close();
            } catch (Exception e2) {
                System.out.println("[关闭流异常][错误信息:" + e2.getMessage() + "]");
            }
        }
        // System.out.println(result);
        return result;
    }
}

这个是调用两个请求的方式,并且注明了传参要求

import java.net.URLEncoder;

public class TestInfluxdb {
    public static void main(String[] args) {
        String postData = "";
        postData = "test_table,col1=1,col2=2 col3=3,col4=4\ntest_measurement,col1=5,col2=6 col3=7,col4=8";
        HttpUtils.sendPost("http://localhost:8086/write?db=db_name&u=admin;&p=admin", postData, "UTF-8");

        String selectData = "";
        try {
            // 查询measurement数据,本来想使用这个转码,结果encode(str),这玩意废弃了
            // selectData = URLEncoder.encode("select * from test_measurement")
            // 用下边这个转码,encode(str,charset)妥妥的
            selectData = URLEncoder.encode("drop measurement test_measurement", "utf-8")
                        .replaceAll("\\%28", "(")                          
                        .replaceAll("\\%29", ")")   		
                        .replaceAll("\\+", "%20")                          
                        .replaceAll("\\%27", "'")   			   
                        .replaceAll("\\%21", "!")
                        .replaceAll("\\%7E", "~");
        } catch (Exception e) {
            System.out.println(e);
        }
        String getData = "db=db_name&q="+ selectData;
        HttpUtils.sendGet("http://localhost:8086/query", getData, "UTF-8");
    } 
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值