当前位置: 首页 > news >正文

根据basic auth请求https获取token

根据basic auth请求https获取token


对接第三方接口,给了接口文档,但是没有示例代码,postman一直可请求成功,java就是不行。百思不得其解,最后请求公司大神,得到一套秘籍。

第一步

在这里插入图片描述
第二步
在这里插入图片描述
Authorization:Bearer access_token。其中,Bearer为固定字符串,后面包含一个空格,access_token表示实际获取到的token。

第三步:写出代码。


import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.spcp.platform.common.util.StringUtil;
import org.apache.http.conn.ssl.NoopHostnameVerifier;
import org.apache.http.conn.ssl.SSLConnectionSocketFactory;
import org.apache.http.conn.ssl.TrustStrategy;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.ssl.SSLContexts;
import org.springframework.http.*;
import org.springframework.http.client.HttpComponentsClientHttpRequestFactory;
import org.springframework.util.MultiValueMap;
import org.springframework.web.client.RestTemplate;import javax.net.ssl.SSLContext;
import java.security.KeyManagementException;
import java.security.KeyStoreException;
import java.security.NoSuchAlgorithmException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;public String getToken() {String token = "";try {TrustStrategy acceptingTrustStrategy = (x509Certificates, authType) -> true;SSLContext sslContext = SSLContexts.custom().loadTrustMaterial(null, acceptingTrustStrategy).build();SSLConnectionSocketFactory sslFactory = new SSLConnectionSocketFactory(sslContext, new NoopHostnameVerifier());CloseableHttpClient httpClient = HttpClients.custom().setSSLSocketFactory(sslFactory).build();HttpComponentsClientHttpRequestFactory factory =new HttpComponentsClientHttpRequestFactory();factory.setConnectTimeout(3600000);factory.setReadTimeout(3600000);factory.setHttpClient(httpClient);RestTemplate restTemplate = new RestTemplate(factory);// 要请求的URLString requestUrl = "https://110:39/oauth/token?grant_type=client_credentials";// header根据实际情况设置,没有就空着MultiValueMap<String, String> params = new HttpHeaders();params.add("grant_type", "client_credentials-aqjc");HttpHeaders headers = new HttpHeaders();// 加密后的用户名和密码,这个替换成加密后的headers.add("Authorization", "Basic d2666666666666==");//headers.add("Content-Type", "application/x-www-form-urlencoded");HttpEntity<?> requestEntity = new HttpEntity<>(params, headers);// 发送请求并接收响应ResponseEntity<String> response = restTemplate.exchange(requestUrl, HttpMethod.POST, requestEntity, String.class);// 获取响应体String responseBody = response.getBody();// 输出响应体内容Map<String, String> resMap = new ObjectMapper().readValue(responseBody, new TypeReference<Map<String, String>>() {});token = resMap.get("access_token");} catch (Exception e) {e.printStackTrace();}return token;}

总结:其实挺难的,尤其https认证。

http://www.lryc.cn/news/462030.html

相关文章:

  • 【基础版】React缓存路由
  • Java基础15-Java高级
  • selenium工具的几种截屏方法介绍(9)
  • 【设计模式】深入理解Python中的过滤器模式(Filter Pattern)
  • vue的动态组件 keep-alive
  • 现代框架开发官网
  • 一篇文章快速认识YOLO11 | 关键改进点 | 安装使用 | 模型训练和推理
  • AtCoder Beginner Contest 375(A,B,C,D,E,F)(大模拟,前缀和,dp,离线处理,Floyd)
  • 认识maven
  • OSINT技术情报精选·2024年10月第2周
  • 中企通信赋能中信戴卡入选工信部颁发的2023年工业互联网试点示范名单
  • 【C语言】函数的声明与定义
  • 游戏如何应对薅羊毛问题
  • Chromium html<script>对应c++接口定义
  • ollama + fastgpt+m3e本地部署
  • Linux执行source /etc/profile命令报错:权限不够问(已解决)
  • Windows 11开发全解析
  • 如何进行数学家式的学习思考?
  • 自定义类型--结构体
  • 笔试练习day7
  • python 爬虫 入门 一、基础工具
  • 金融衍生品中的风险对冲策略分析
  • linux下建立软链接
  • MySql数据库left join中添加子查询
  • redis--过期策略和内存淘汰策略
  • qt QTableview 左侧 序号 倒序
  • 隧道代理IP如何帮助企业采集数据?
  • Spring Boot知识管理系统:技术与方法论
  • SpringBoot1~~~
  • 兼容多家品牌手机的多协议取电快充芯片