Java发送httpPost,httpGet,httpDelete请求

        业务场景:最近开发的项目使用的将文件图片和视频存储在Minio当中,但是准备上线申请资源的时候申请不到资源,就临时决定使用厂商提供的Api接口进行文件图片和视频上传,然后就需要在后端进行登录,文件校验和文件存储和文件检索等http请求的书写,所以下面就分享给大家,如果有不足的地方还请多指教。

Maven依赖:

        <dependency><groupId>org.apache.httpcomponents</groupId><artifactId>httpmime</artifactId><version>4.5.13</version> <!-- 根据需要选择版本 --></dependency><!-- Apache HttpClient 依赖 --><dependency><groupId>org.apache.httpcomponents</groupId><artifactId>httpclient</artifactId><version>4.5.13</version> <!-- 根据需要选择版本 --></dependency>

Controller:

        httpPost请求:

import cn.hutool.json.JSONArray;
import cn.hutool.json.JSONObject;
import com.fasterxml.jackson.databind.ObjectMapper; // 需要导入 Jackson 库
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.collections4.MapUtils;
import org.apache.http.HttpEntity;
import org.apache.http.HttpHeaders;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.ByteArrayEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils;
import org.springframework.beans.factory.annotation.Autowired;import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
import xyz.playedu.api.BCtx;
import xyz.playedu.api.config.DIMSConfig;import xyz.playedu.api.constant.BPermissionConstant;
import xyz.playedu.api.domain.InfosVO;
import xyz.playedu.api.domain.Resource;
import xyz.playedu.api.exception.ServiceException;
import xyz.playedu.api.middleware.BackendPermissionMiddleware;
import xyz.playedu.api.service.MinioService;
import xyz.playedu.api.service.ResourceService;
import xyz.playedu.api.service.UploadService;
import xyz.playedu.api.types.JsonResponse;import java.io.IOException;
import java.math.BigInteger;
import java.security.MessageDigest;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;/*** 上传到minio*/
@RestController
@Slf4j
@RequestMapping("/backend/v1/upload")
public class UploadDIMSController {//MinioService@Autowiredprivate MinioService minioService;@Autowiredprivate UploadService uploadService;@Autowiredprivate ResourceService resourceService;@Autowiredprivate DIMSConfig dimsConfig;/*** DIMS文件上传的接口* 统一使用一个接口*/@BackendPermissionMiddleware(slug = BPermissionConstant.RESOURCE_CATEGORY)@PostMapping("/dims-upload")public JsonResponse uploadDIMSHttp(@RequestParam HashMap<String, Object> params, MultipartFile file)throws ServiceException {if (file != null && !file.isEmpty()) {try {//1.登录获取tokenString token = loginDIMS(dimsConfig.getDimsSysCode(), dimsConfig.getUsername(), dimsConfig.getPassword());if (token == "获取token失败") {return JsonResponse.error("服务器异常,请稍后重试;" + token);}//2.获取批次号 和scanTimeHashMap<String, String> scanTimeAndBatchCode = getBatchCode(dimsConfig.getDimsSysCode(), dimsConfig.getDimsFunCode(), token);if (scanTimeAndBatchCode == null && scanTimeAndBatchCode.isEmpty()) {log.info("dims服务器异常,获取批次号失败。");return JsonResponse.error("服务器异常,请稍后重试");}//3.上传文件 获取imageID上传的唯一标识String imageId = uploadFileAcquireImageId(file);if (imageId == "文件上传失败") {log.info("dims服务器异常,文件上传失败。");return JsonResponse.error("服务器异常,请稍后重试;" + imageId);}//4.上传业务信息List<InfosVO> arrayList = new ArrayList<>();InfosVO infosVO = new InfosVO();infosVO.setSysCode(dimsConfig.getDimsSysCode());infosVO.setIdentifier(dimsConfig.getIdentifier());infosVO.setImageId(imageId);infosVO.setImageName(file.getOriginalFilename());infosVO.setScanTime(scanTimeAndBatchCode.get("scanTime"));infosVO.setBatchCode(scanTimeAndBatchCode.get("batchCode"));infosVO.setOpId(dimsConfig.getOpId());infosVO.setFlwCode(dimsConfig.getDimsFlwCode());infosVO.setBisInfCode(dimsConfig.getClassCode());infosVO.setOrgCode(dimsConfig.getOrgCode());infosVO.setFunCode(dimsConfig.getDimsFunCode());infosVO.setMd5(getMd5(file));arrayList.add(infosVO);String code = uploadFileInfo(dimsConfig.getDimsSysCode(), token, dimsConfig.getDimsFunCode(), arrayList);if (code != "1") {log.info("dims服务器异常,上传业务信息失败。");return JsonResponse.error("服务器异常,请稍后重试;");}//5.文件检索,将检索的地址直接保存到数据库当中直接返回给前端,前端进行处理String downloadUrl = fileSearchAndSavaUrlToResource(dimsConfig.getDimsSysCode(), scanTimeAndBatchCode.get("batchCode"), token, dimsConfig.getDimsFunCode());if (downloadUrl == "文件检索失败。") {log.info("dims服务器异常,文件检索失败。");return JsonResponse.error("服务器异常,请稍后重试;" + downloadUrl);}String dimsUrl = dimsConfig.getDownLoadJointFirstUrl() + downloadUrl;//获取上传到那个分类当中String categoryIds = MapUtils.getString(params, "category_ids");//传递管理员id,文件,和分类Resource resource = uploadService.storeDIMS(BCtx.getId(), file, categoryIds, dimsUrl);if (resource != null) {//上传成功应该传递文件的路径return JsonResponse.data("上传成功。");} else {return JsonResponse.error("上传失败。");}} catch (IOException e) {e.printStackTrace();throw new ServiceException("Error uploading file to DIMS server");}} else {return JsonResponse.error("文件为空。");}}/*** 1.登录获取token的方法*/public String loginDIMS(String sysCode, String userName, String password) throws IOException {// 构建HTTP客户端CloseableHttpClient httpClient = HttpClients.createDefault();// 创建 HTTP POST 请求HttpPost httpPost = new HttpPost(dimsConfig.getLoginUrl());// 创建要传递的参数列表List<NameValuePair> params = new ArrayList<>();params.add(new BasicNameValuePair("sysCode", sysCode));params.add(new BasicNameValuePair("user", userName));params.add(new BasicNameValuePair("pwd", password));// 将参数设置到请求中httpPost.setEntity(new UrlEncodedFormEntity(params));try {// 执行请求并获取响应HttpResponse response = httpClient.execute(httpPost);HttpEntity entity = response.getEntity();// 处理响应if (entity != null) {// 将响应实体转换为字符串,响应的tokenString responseText = EntityUtils.toString(entity);return responseText;} else {return "获取token失败";}} finally {// 释放资源httpPost.releaseConnection();}}/*** 2.获取批次号*/public HashMap<String, String> getBatchCode(String sysCode, String funCode, String token) throws IOException {HashMap<String, String> hashMap = new HashMap<>();ObjectMapper objectMapper = new ObjectMapper();// 构建HTTP客户端CloseableHttpClient httpClient = HttpClients.createDefault();// 创建 HTTP POST 请求HttpPost httpPost = new HttpPost(dimsConfig.getBatchCodeUrl());// 创建要传递的参数列表List<NameValuePair> params = new ArrayList<>();params.add(new BasicNameValuePair("sysCode", sysCode));params.add(new BasicNameValuePair("funCode", funCode));params.add(new BasicNameValuePair("token", token));// 将参数设置到请求中httpPost.setEntity(new UrlEncodedFormEntity(params));try {// 执行请求并获取响应HttpResponse response = httpClient.execute(httpPost);HttpEntity entity = response.getEntity();// 处理响应if (entity != null) {String responseText = EntityUtils.toString(entity);log.info("getBatchCode-entity:{}", responseText);//{"msg":"获取成功","data":"{\"scanTime\":\"2023-09-27 7:40:32\"}}"// 去除jar包返回的空字符,对接的系统的bugString sanitizedText = responseText.replace("\0", "");//  String sanitizedText = responseText.trim(); //第二种方式去除空白字符//{"msg":"获取成功","data":{"scanTime":"2023-09-27 7:40:32","batchCode":"sdsdas211dsdx"}}// 解析响应字符串JSONObject entries = new JSONObject(sanitizedText);hashMap.put("scanTime", entries.getJSONObject("data").getStr("scanTime"));hashMap.put("batchCode", entries.getJSONObject("data").getStr("batchCode"));return hashMap;} else {return new HashMap<>();}} finally {// 释放资源httpPost.releaseConnection();}}/*** 3.上传文件返回imageId*/public String uploadFileAcquireImageId(MultipartFile file) throws IOException {// 构建HTTP客户端CloseableHttpClient httpClient = HttpClients.createDefault();// 创建HTTP POST请求HttpPost httpPost = new HttpPost(dimsConfig.getUploadMaxFileUrl());// 创建一个包含文件和其他参数的多部分实体/*** 这是需要对接的这个接口也是用MultipartFile file进行接收的方式* *//*    MultipartEntityBuilder builder = MultipartEntityBuilder.create();builder.addBinaryBody("file", file.getInputStream(), ContentType.MULTIPART_FORM_DATA, file.getOriginalFilename());httpPost.setEntity(builder.build());*//*** 接口接收二进制数据* */// 设置请求头,告诉服务器请求体是二进制数据httpPost.setHeader(HttpHeaders.CONTENT_TYPE, "application/octet-stream");// 将文件内容作为二进制数据设置为请求体byte[] fileBytes = file.getBytes();HttpEntity entity = new ByteArrayEntity(fileBytes);httpPost.setEntity(entity);try {// 发送HTTP请求HttpResponse response = httpClient.execute(httpPost);// 处理响应int statusCode = response.getStatusLine().getStatusCode();String responseBody = EntityUtils.toString(response.getEntity());if (statusCode == 200) {// 请求成功,根据响应处理结果//这里可能还是要对responseBody进行空值截取JSONObject entries = new JSONObject(responseBody);return entries.getJSONObject("data").getStr("imageId");} else {// 请求失败,根据需要处理错误情况
//                return new JsonResponse("Upload failed", responseBody);return "文件上传失败";}} finally {// 释放资源httpPost.releaseConnection();}}/*** 4.上传业务信息*///            uploadFileInfo(dimsConfig.getDimsSysCode(),token,dimsConfig.getDimsFunCode(),arrayList);public String uploadFileInfo(String sysCode, String token, String funCode, List<InfosVO> arrayList) throws IOException {// 创建 ObjectMapper 对象,用于将对象转换为 JSON 字符串ObjectMapper objectMapper = new ObjectMapper();// 将 arrayList 转换为 JSON 字符串String arrayListJson = objectMapper.writeValueAsString(arrayList);// 构建HTTP客户端CloseableHttpClient httpClient = HttpClients.createDefault();// 创建 HTTP POST 请求HttpPost httpPost = new HttpPost(dimsConfig.getUploadServiceInfoUrl());// 创建要传递的参数列表List<NameValuePair> params = new ArrayList<>();params.add(new BasicNameValuePair("sysCode", sysCode));params.add(new BasicNameValuePair("token", token));params.add(new BasicNameValuePair("funCode", funCode));params.add(new BasicNameValuePair("infos", arrayListJson));//转换成JSON字符串// 将参数设置到请求中httpPost.setEntity(new UrlEncodedFormEntity(params));try {// 执行请求并获取响应HttpResponse response = httpClient.execute(httpPost);// 处理响应String responseBody = EntityUtils.toString(response.getEntity());// 请求成功,根据响应处理结果//这里可能还是要对responseBody进行空值截取JSONObject entries = new JSONObject(responseBody);return entries.getStr("code");} finally {// 释放资源httpPost.releaseConnection();}}/*** 5.文件检索,获取 downloadUrl 进行拼接进行下载*///            fileSearchAndSavaUrlToResource(dimsConfig.getDimsSysCode(),scanTimeAndBatchCode.get("batchCode"),token,dimsConfig.getDimsFunCode());public String fileSearchAndSavaUrlToResource(String sysCode, String batchCode, String token, String funCOde) throws IOException {// 构建HTTP客户端CloseableHttpClient httpClient = HttpClients.createDefault();// 创建 HTTP POST 请求HttpPost httpPost = new HttpPost(dimsConfig.getFileSearchUrl());// 创建要传递的参数列表List<NameValuePair> params = new ArrayList<>();params.add(new BasicNameValuePair("sysCode", sysCode));params.add(new BasicNameValuePair("batchCode", batchCode));params.add(new BasicNameValuePair("token", token));params.add(new BasicNameValuePair("funCode", funCOde));// 将参数设置到请求中httpPost.setEntity(new UrlEncodedFormEntity(params));try {// 执行请求并获取响应HttpResponse response = httpClient.execute(httpPost);HttpEntity entity = response.getEntity();log.info("fileSearchAndSavaUrlToResource-entity:{}", entity);// 处理响应if (entity != null) {// 将响应实体转换为字符串String responseText = EntityUtils.toString(entity);JSONObject entries = new JSONObject(responseText);if (entries.getStr("code") == "1") {JSONArray dataArray = entries.getJSONArray("data");JSONObject firstElement = dataArray.getJSONObject(0);// 这里的 firstElement 就是第一个元素return firstElement.getStr("downloadUrl");//获取 downloadUrl} else {return "文件检索失败。";}} else {return "文件检索失败。";}} finally {// 释放资源httpPost.releaseConnection();}}/*** 获取上传文件的md5** @param file* @return* @throws IOException*/public String getMd5(MultipartFile file) {try {//获取文件的byte信息byte[] uploadBytes = file.getBytes();// 拿到一个MD5转换器MessageDigest md5 = MessageDigest.getInstance("MD5");byte[] digest = md5.digest(uploadBytes);//转换为16进制return new BigInteger(1, digest).toString(16);} catch (Exception e) {log.error(e.getMessage());}return null;}}

          httpGet请求:     

public String loginDIMS(String sysCode, String userName, String password) throws IOException {// 创建HTTP客户端HttpClient httpClient = HttpClients.createDefault();// 构建GET请求URLString getUrl = dimsConfig.getLoginUrl() + "?sysCode=" + sysCode + "&user=" + userName + "&pwd=" + password;// 创建HTTP GET请求HttpGet httpGet = new HttpGet(getUrl);try {// 执行GET请求并获取响应HttpResponse response = httpClient.execute(httpGet);HttpEntity entity = response.getEntity();// 处理响应if (entity != null) {// 将响应实体转换为字符串,响应的tokenString responseText = EntityUtils.toString(entity);return responseText;} else {return "获取token失败";}} finally {// 释放资源httpGet.releaseConnection();}
}

        httpDelete请求:

public String deleteDIMS(String resourceUrl) throws IOException {// 创建HTTP客户端HttpClient httpClient = HttpClients.createDefault();// 构建DELETE请求HttpDelete httpDelete = new HttpDelete(resourceUrl);try {// 执行DELETE请求并获取响应HttpResponse response = httpClient.execute(httpDelete);int statusCode = response.getStatusLine().getStatusCode();// 处理响应if (statusCode == 200) {// 处理成功的响应,根据需要返回结果return "删除成功";} else {// 处理失败的响应,根据需要返回错误信息return "删除失败,状态码:" + statusCode;}} finally {// 释放资源httpDelete.releaseConnection();}
}

还有一个小知识:就是在对接厂商提供的接口的时候获取返回的JSON数据发现数据格式为

{"msg":"获取成功","data":"{\"scanTime\":\"2023-09-27 7:40:32\"}}"

其实就是JSON格式,但是就是识别不出来,最后发现这段数据中{”msg“前面有一个空字符,特别神奇,也不知道他们响应是如何响应的,然后我通过

String sanitizedText = responseText.replace("\0", "");

这个方法把这个小问题给解决了,也可以使用

String sanitizedText = responseText.trim(); //第二种方式去除空白字符

进行解决。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/92662.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

源码编译postgresql

没什么好研究的了&#xff0c;就试试编译Postgresql源码&#xff0c;按照网站查的资料一步步测试的&#xff0c;方便后期定制数据库时候用&#xff0c;也算是开源的大优势了&#xff0c;只要你愿意折腾&#xff0c;可以自己定制或改进一个数据库来满足特殊业务。后面研究一下他…

搭建智能桥梁,Amazon CodeWhisperer助您轻松编程

零&#xff1a;前言 随着时间的推移&#xff0c;人工智能技术以惊人的速度向前发展&#xff0c;正掀起着全新的编程范式革命。不仅仅局限于代码生成&#xff0c;智能编程助手等创新应用也进一步提升了开发效率和代码质量&#xff0c;极大地推动着软件开发领域的快速繁荣。 当前…

Guitar Pro 8 .1全新功能介绍及2023官方特惠优惠券

《中国好声音》节目诞生10年多热度不减&#xff0c;每一季都有籍籍无名的学员成为万众瞩目的新星。怎么像他们一样把爱好变成事业&#xff1f;带着这个问题在不断的探寻中找到了答案&#xff0c;那就是要在有限的时间里比别人做效率更高的事。所谓“工欲善其事&#xff0c;必先…

制作原创音乐app软件FL Studio21.2中文版

如果你正在录制、编辑或创作新歌曲&#xff0c;你会需要使用 FL Studio 快捷键。FL Studio 可用于录制、编辑和制作&#xff0c;以及专业人士录制和创作歌曲。在 FL Studio 中创建音乐专辑也是一个漫长的过程&#xff0c;可能会变得复杂且需要较长时间。很好的是&#xff0c;学…

电池集成充电解决方案提供商【XCharge Group】获得壳牌风险投资

来源&#xff1a;猛兽财经 作者&#xff1a;猛兽财经 猛兽财经获悉&#xff0c;总部位于德国汉堡的电池集成充电解决方案提供商XCharge Group今日宣布已获得了壳牌风险投资公司的投资&#xff0c;这笔交易的金额没有披露。 XCharge Group计划将这笔资金用在三方面&#xff1a;…

UE5 虚幻引擎 详解蓝图通信 必备的知识技能之一!!!

目录 0 引言1 直接蓝图通信1.1 在关卡蓝图中直接拖拽Actor1.2 Get Actor of Class/Get All Actors of Class 2 事件分发器2.1 创建事件分发器2.2 绑定事件分发器2.3 调用事件分发器 3 蓝图接口3.1 使用步骤3.2 为什么要使用蓝图接口 4 蓝图转换 0 引言 问题&#xff1a;为什么需…

【C++】map和set的使用

&#x1f680;write in front&#x1f680; &#x1f4dc;所属专栏&#xff1a; C学习 &#x1f6f0;️博客主页&#xff1a;睿睿的博客主页 &#x1f6f0;️代码仓库&#xff1a;&#x1f389;VS2022_C语言仓库 &#x1f3a1;您的点赞、关注、收藏、评论&#xff0c;是对我最大…

斯坦福数据挖掘教程·第三版》读书笔记(英文版)Chapter 10 Mining Social-Network Graphs

来源&#xff1a;《斯坦福数据挖掘教程第三版》对应的公开英文书和PPT。 Chapter 10 Mining Social-Network Graphs The essential characteristics of a social network are: There is a collection of entities that participate in the network. Typically, these entiti…

JS defineProperty详解

defineProperty Object.defineProperty():方法会在对象上直接定义个新的属性&#xff0c;或者修改现有的属性&#xff0c;并返回此对象 let obj {} //与我们使用 obj.name zhangsna 效果一样 但是用defineProperty定义的属性无法改变 或者删除 Object.defineProperty(obj,n…

MEIS —— 前端部分基本配置

项目基本配置 这篇文章我们随着上一篇文章继续往下叙述&#xff0c;主要是将element和windicss等开发配置进项目中&#xff0c;以及基本的一些页面和组件给他完成。 1. 安装element plus 运行&#xff1a; npm install element-plus --save 这里我们是按需引入(自动)&#x…

flink处理函数--副输出功能

背景 在flink中&#xff0c;如果你想要访问记录的处理时间或者事件时间&#xff0c;注册定时器&#xff0c;或者是将记录输出到多个输出流中&#xff0c;你都需要处理函数的帮助&#xff0c;本文就来通过一个例子来讲解下副输出 副输出 本文还是基于streaming-with-flink这本…

基于YOLOv8的安全帽检测系统

1.Yolov8介绍 Ultralytics YOLOv8是Ultralytics公司开发的YOLO目标检测和图像分割模型的最新版本。YOLOv8是一种尖端的、最先进的&#xff08;SOTA&#xff09;模型&#xff0c;它建立在先前YOLO成功基础上&#xff0c;并引入了新功能和改进&#xff0c;以进一步提升性能和灵活…

树的表示——孩子兄弟表示法

从图中可以看出&#xff0c;树的每个结点&#xff0c;都有不确定的指向他们的孩子的节点&#xff0c;如果我们定义这样一个结构体来便是数的结构的话&#xff1a; struct TreeNode { int val; struct TreeNodep1; struct TreeNodep1; … }; 是不能够表示一棵树的&#xff0c;因…

9.25 day 2

1. 简述方法重写与方法重载的意义与区别&#xff1a; 方法重写&#xff1a; 1.参数列表必须完全与被重写方法相同 //参数列表&#xff08;分为四种&#xff09;&#xff1a; &#xff08;1&#xff09;无参无返回值方法&#xff1b; &#xff08;2&#xff09;有参无返回…

“智慧时代的引领者:探索人工智能的无限可能性“

目录 一.背景 二.应用 2.1金融领域 2.2医疗领域 2.3教育领域 三.发展 四.总结: 一.背景 人工智能&#xff08;Artificial Intelligence&#xff0c;简称AI&#xff09;&#xff0c;是指通过计算机程序模拟人类智能的一种技术。它是计算机科学、工程学、语言学、哲学等多…

【Redis】redis基本数据类型详解(String、List、Hash、Set、ZSet)

目录 RedisString(字符串)List(列表)Hash(字典)Set(集合)ZSet(有序集合) Redis Redis有5种基本的数据结构&#xff0c;分别为&#xff1a;string&#xff08;字符串&#xff09;、list&#xff08;列表&#xff09;、set&#xff08;集合&#xff09;、hash&#xff08;哈希&a…

CUDA、cudNN 、CUDAToolKit三者关系

cudatoolkit和cuda有关系吗 CUDA 是 NVIDIA 推出的一种并行计算平台和编程模型&#xff0c;可以在 NVIDIA GPU 上运行 C/C 代码。 CUDA Toolkit 是 NVIDIA 提供的一套开发工具&#xff0c;它包含了用于开发 CUDA 应用程序所需的各种工具&#xff0c;如编译器、调试器和库。 因…

音频编辑软件Steinberg SpectraLayers Pro mac中文软件介绍

Steinberg SpectraLayers Pro mac是一款专业的音频编辑软件&#xff0c;旨在帮助音频专业人士进行精细的音频编辑和声音处理。它提供了强大的频谱编辑功能&#xff0c;可以对音频文件进行深入的频谱分析和编辑。 Steinberg SpectraLayers Pro mac软件特点 1. 频谱编辑&#xff…

transformers简介

目录 1、前言 2、网络结构 &#xff08;1&#xff09;、Transformers的总体架构可以分为四部分 &#xff08;2&#xff09;、输入文本包含 &#xff08;3&#xff09;、输出部分包含 &#xff08;4&#xff09;、编码器部分 &#xff08;5&#xff09;、解码器部分 1、前…