EN

开发支持

首页/服务与支持/开发支持/

入门指南

98体育平台下载官方云API是针对企业二次开发需求封装的一套应用程序接口,可帮助您在自己的平台中获取和使用98体育平台下载官方云平台数据中心的部分数据。98体育平台下载官方云API支持AccessToken和白名单两种网关验证方式,验证接口调用是否合法。其中:AccessToken验证方式免费对外开放;白名单验证方式为付费功能,使用前请与我司技术支持人员联系沟通。

使用AccessToken

每个组织和工程都有一个AppID和AppSecret,组织的AppID和AppSecret权限等级较高,可以调用该组织下任意工程的数据,工程的AppID和AppSecret仅能调用该工程的数据。

使用AppID和AppSecret可获取一个AccessToken具体步骤请参考获取AccessToken》,在后续数据请求的接口中,请求头字段传入AccessToken值即可通过网关验证。

登录98体育平台下载官方云平台,选择工程,进入【管理】,可查看和获取工程的AppID和AppSecret。

20220420_1652497.png

登录98体育平台下载官方云平台,进入【管理后台】→【机构配置】,可查看和获取组织的AppID和AppSecret。

20211015_09243114.png

  登录98体育平台下载官方云平台,进入【管理后台】→【工程管理】→【工程详情】,可查看和获取某个工程的AppID和AppSecret。

20211015_09253768.png

使用白名单

通过白名单,用户可更方便快捷的调用接口,设置白名单后,调用数据获取接口时传入AppID即可通过网关验证。另外使用白名单可以对调用IP地址进行限制,即只有该白名单中的网站才能成功发起调用。

白名单使用前请与我司技术支持人员联系,由专业技术人员协助开通后,一个AppID最多可设置三个公网IP作为白名单。

白名单设置完成后,将AppID作为一个参数调用数据获取接口即可通过网关验证,请求参数支持放到Body和直接拼接到请求地址后两种形式。

开发环境准备(以Java为例)

Java环境下需要安装引用一些必备的依赖包,可采用通过Maven引用和通过下载引用两种方式加载。

1. 通过Maven引用

Maven项目引用以下,在配置文件中输入以下配置项即可。

    <dependency>
     <groupId>org.apache.httpcomponents</groupId>
     <artifactId>httpmime</artifactId>
     <version>4.5.8</version>
    </dependency>

2. 通过下载jar包方式引用

           手动下载jar包,并且在项目中引用,这里提供3个必须引用的jar包的下载地址。

            httpclient-4.5.8.jar

     httpcore-4.4.11.jar

     commons-logging-1.2.jar

将上述相关依赖包加载进项目后,为方便开发,可封装一个公共类引用相关资源,处理http请求。

import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import org.apache.http.HttpEntity;
import org.apache.http.NameValuePair;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.methods.HttpRequestBase;
import org.apache.http.config.SocketConfig;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils;
// HttpClient 连接池
public class HttpUtil { 

  private static PoolingHttpClientConnectionManager cm = null;

  public static PoolingHttpClientConnectionManager getHttpClientConnectionManager() {
    if (cm == null) {
      cm = new PoolingHttpClientConnectionManager();
      cm.setMaxTotal(200);
      cm.setDefaultMaxPerRoute(20);
      SocketConfig config = SocketConfig.custom().setSoTimeout(10000).build();
      cm.setDefaultSocketConfig(config);
    }
    return cm;
  }
// 初始化连接池,可用于请求HTTP/HTTPS(信任所有证书)
  static { 
    // 整个连接池最大连接数
    cm = getHttpClientConnectionManager(); 
    // 每路由最大连接数,默认值是2
    cm.setMaxTotal(200); 
    cm.setDefaultMaxPerRoute(5);
  }

  public static String postHttp(
    String url,
    Map<String, String> paramMap,
    Map<String, String> headerMap
  ) {
    HttpPost request = new HttpPost(url);
    request.addHeader("Content-Type", "application/x-www-form-urlencoded");
    if (paramMap != null && paramMap.size() > 0) {
      List<NameValuePair> nameValuePairs = covertParams2NVPS(paramMap);
      try {
        request.setEntity(
          new UrlEncodedFormEntity(
            nameValuePairs,
            StandardCharsets.UTF_8.name()
          )
        );
      } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
      }
    }
    if (headerMap != null) {
      for (Entry<String, String> param : headerMap.entrySet()) {
        request.addHeader(param.getKey(), param.getValue());
      }
    }
    return doHttp(request);
  }

  public static String post(
    String url,
    Map<String, String> paramMap,
    Map<String, String> headerMap
  ) {
    return postHttp(url, paramMap, headerMap);
  }

  public static String post(String url, Map<String, String> paramMap) {
    return postHttp(url, paramMap, null);
  }

  public static List<NameValuePair> covertParams2NVPS(
    Map<String, String> params
  ) {
    List<NameValuePair> pairs = new ArrayList<NameValuePair>();
    for (Map.Entry<String, String> param : params.entrySet()) pairs.add(
      new BasicNameValuePair(param.getKey(), param.getValue())
    );
    return pairs;
  }

  private static String doHttp(HttpRequestBase request) {
    CloseableHttpClient httpClient = HttpClients
      .custom()
      .setConnectionManager(cm)
      .build();
    return doRequest(httpClient, request);
  }

  private static String doRequest(
    CloseableHttpClient httpClient,
    HttpRequestBase request
  ) {
    String result = null;
    CloseableHttpResponse response = null;
    try {
      try {
        response = httpClient.execute(request);
        HttpEntity entity = response.getEntity();
        result = EntityUtils.toString(entity, StandardCharsets.UTF_8.name());
        EntityUtils.consume(entity);
      } catch (Exception e) {
        e.printStackTrace();
      }
    } finally {
      if (null != response) try {
        response.close();
      } catch (IOException e) {
        e.printStackTrace();
      }
    }
    return result;
  }
}


logo

触摸自然的脉搏 聆听世界的声音
对天地的敬畏 对人和安全的关怀
为了那一片宁静的风景
我们永远在路上
关注我们
关注我们
预览

公司地址

中国 江苏
南京市鼓楼区君兰路2号上鼓中心9楼
+86 25 84443850
周一至周日 8:00 - 18:00

合作与共赢