httpsUtils外部接口调用

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.net.URL;
import java.security.KeyManagementException;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;

import javax.net.ssl.HostnameVerifier;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.KeyManager;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSession;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;

import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * HTTPS工具类.
 * 
 */
public class HttpsUtils {
    
    private static Logger logger = LoggerFactory.getLogger(HttpsUtils.class);

    private static final class DefaultTrustManager implements X509TrustManager {
        @Override
        public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
        }

        @Override
        public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
        }

        @Override
        public X509Certificate[] getAcceptedIssuers() {
            return null;
        }
    }

    /**
     * 发送GET请求.
     * 
     * @param url
     * @param param
     * @return
     */
    public static String sendGet(String url, String param, String token) {
        // 参数内容为空,直接返回
        if(StringUtils.isEmpty(param) || "{}".equals(param)){
            return null;
        }
        
        String result = "";// 结果内容
        try{
            // 获取连接
            HttpsURLConnection httpsConn = getHttpsURLConnection(url, "GET", token);
            // 设置文件长度
            httpsConn.setRequestProperty("Content-Length", String.valueOf(param.getBytes().length));
            // 获取返回结果
            result = getResultFromStream(httpsConn.getInputStream());
        }catch(Exception e){
            logger.error(url + param + "发送GET请求出现异常!", e);
        }

        return result;
    }

    /**
     * 发送POST请求.
     * 
     * @param url
     * @param param
     * @param token 
     * @return
     */
    public static String sendPost(String url, String param, String token) {
        // 参数内容为空,直接返回
        if(StringUtils.isEmpty(param) || "{}".equals(param)){
            return null;
        }
        
        String result = "";// 结果内容
        try{
            // 获取连接
            HttpsURLConnection httpsConn = getHttpsURLConnection(url, "POST", token);
            // 设置文件长度
            httpsConn.setRequestProperty("Content-Length", String.valueOf(param.getBytes().length));
            // 添加参数信息
            setParamToStream(httpsConn.getOutputStream(), param);
            // 获取返回结果
            result = getResultFromStream(httpsConn.getInputStream());
        }catch(Exception e){
            logger.error(url + param + "发送POST请求出现异常!", e);
        }
        
        return result;
    }

    /**
     * 获取请求连接.
     * 
     * @param url
     * @param method
     * @param token
     * @return
     * @throws IOException
     */
    private static HttpsURLConnection getHttpsURLConnection(String url, String method, String token) throws IOException {
        SSLContext ctx = null;
        try {
            ctx = SSLContext.getInstance("TLS");
            ctx.init(new KeyManager[0], new TrustManager[] { new DefaultTrustManager() }, new SecureRandom());
        } catch (KeyManagementException e) {
            e.printStackTrace();
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
        SSLSocketFactory ssf = ctx.getSocketFactory();

        URL httpsUrl = new URL(url);
        HttpsURLConnection httpsConn = (HttpsURLConnection) httpsUrl.openConnection();
        httpsConn.setSSLSocketFactory(ssf);
        httpsConn.setHostnameVerifier(new HostnameVerifier() {
            @Override
            public boolean verify(String arg0, SSLSession arg1) {
                return true;
            }
        });
        httpsConn.setRequestMethod(method);
        // post请求参数
        if("POST".equals(method.toUpperCase())){
            httpsConn.setDoInput(true);
            httpsConn.setDoOutput(true);
        }
        httpsConn.setRequestProperty("accept", "application/json");
        httpsConn.setRequestProperty("connection", "Keep-Alive");
        httpsConn.setRequestProperty("Content-Type", "application/json;charset=UTF-8");
        // 震坤行数据传输时,token内容需要放到header中验证
        if(StringUtils.isNotEmpty(token)){
            httpsConn.setRequestProperty("token", token);
        }
        
        return httpsConn;
    }
    
    /**
     * 从输入流中获取结果信息.
     * 
     * @param is
     * @return
     * @throws IOException
     */
    private static String getResultFromStream(InputStream is){
        String result = "";
        BufferedReader in = null;
        
        try{
            // 定义BufferedReader输入流来读取URL的响应
            in = new BufferedReader(new InputStreamReader(is));
            String line;
            while ((line = in.readLine()) != null) {
                result += line;
            }
        } catch (Exception e) {
            logger.error("从输入流中获取结果信息出现异常!", e);
        }
        
        // 使用finally块来关闭输出流
        finally{
            try{
                if(in != null){
                    in.close();
                }
            }
            catch(Exception ex){
                logger.error("关闭输入流出现异常!", ex);
            }
        }
        
        return result;
    }
    
    /**
     * 向输出流中添加参数内容.
     * 
     * @param os
     * @param param
     * @throws IOException
     */
    private static void setParamToStream(OutputStream os, String param){
        OutputStreamWriter out = null;
        try {
            // 获取URLConnection对象对应的输出流
            out = new OutputStreamWriter(os, "UTF-8");
            // 发送请求参数
            out.write(param);
            // flush输出流的缓冲
            out.flush();
        } catch (Exception e) {
            logger.error(param + "向输出流中添加参数内容出现异常!", e);
        }
        
        // 使用finally块来关闭输出流
        finally{
            try{
                if(out != null){
                    out.close();
                }
            }
            catch(Exception ex){
                logger.error(param + "关闭输出流出现异常!", ex);
            }
        }
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Ecology9是一个能够提供极致的生态系统建设的工具,它可以依托于现有的业务系统或资源,以确保企业的数据完整性和安全性。该工具支持调用外部接口,使企业能够更加灵活地集成现有数据或方案。 首先,Ecology9的API(应用程序接口)是开放的,它无任何限制地提供数据交换和通信。这意味着Ecology9可以轻松地访问外部系统和应用程序,从而从中收集数据或执行特定的任务,而不需要开发额外的模块或应用程序。 其次,通过API,Ecology9可以快速地实现与外部系统的互操作性。例如,它可以将数据从第三方应用程序中导入,同时它还可以将其自身的数据导出到另一个系统或环境中。此外,Ecology9可以与其他智能系统(如IoT设备或机器学习模型)集成,以便更好地管理和分析生态系统的数据。 最后,作为一个多功能的生态系统建设工具,Ecology9支持广泛的技术框架和语言,使它可以更加灵活地部署和执行。同时,Ecology9的使用和调用外部接口也非常容易,企业可以轻松地掌握其使用方法,从而根据自身的需求,进行定制化的开发和实现。 ### 回答2: 生态学语言中,ecology9 是一个用于进行生态学分析的 R 软件包。这个软件包中提供了多种函数和工具,用于生态系统的建模、统计分析和 绘图。除了这些内置的功能,ecology9 也支持与外部接口的交互,以便更好地支持生态学分析的需要。 调用外部接口是指使用已存在的其他软件包或者编写的自定义函数,以拓展ecology9 的功能。在生态学中,许多计算方法和工具已经被其他软件包实现,因此调用这些软件包可以方便地进行复杂分析。例如,R语言中有很多流行的生态学软件包,例如vegan、 BiodiversityR、adegenet、poppr等。这些包提供了各种生态学分析的方法包括生物多样性的计算,群落分析和遗传分析。通过使用ecology9的外部接口,用户可以轻松地将这些软件包的功能与ecology9的分析结合起来,从而最大化分析的效益。 总之,ecology9调用外部接口使得生态学家可以更高效地进行生态学分析。通过使用其他生态学软件包的功能,可以更准确地解释生态系统的现象,进一步深入研究生态学领域。 ### 回答3: Ecology9是一个企业级的生态系统管理平台,它的核心功能是管理企业的资源与流程,为企业提供全面的和可持续的发展支持。为了更好地实现这个目标,Ecology9调用了一些外部接口来补充其自身的功能。 首先,Ecology9使用外部接口来获取企业的相关数据,比如产品库存、销售数据、财务数据等等。这些数据是企业管理和决策所必需的,通过调用外部接口,Ecology9可以获取这些数据,并将其整理成易于查询和分析的格式,为企业提供更好的数据支持。 其次,Ecology9还调用外部接口来扩展其自身的功能,比如集成人力资源管理系统、客户关系管理系统等等。这些系统都有着自己的特点和优势,通过集成到Ecology9中,可以让企业在多个方向上获得更多的资源与服务。 最后,Ecology9调用外部接口来提高其平台的可用性和安全性。比如,它可能使用第三方的身份验证服务来确保用户的身份和权限,使用CDN服务来实现快速缓存和数据传输等等。这些服务都能够让企业更高效地使用Ecology9平台,同时也保障了用户的信息安全和秘密性。 总之,Ecology9调用外部接口是为了更好地满足企业的需求,这些接口可以从多个方向上扩展和完善Ecology9平台的功能,让企业在日常经营和发展中获得更多的支持和帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值