Java 调用 MULTIPART_FORM_DATA 接口

news2024/11/24 4:44:30

以 QAnthing 上传文件(POST)接口为例,展示Java如何调用上传文件接口。
接口文档如下:

QAnthign接口文档地址

在这里插入图片描述

编码

RestTemplate 版


/**  
 * * @param url 接口地址  
 * @param filePath 文件本地路径  
 */  
public void uploadFile(String url, String filePath) {  
    // 使用RestTemplate上传文件  
    RestTemplate restTemplate = new RestTemplate();  
    // 设置请求头  
    HttpHeaders headers = new HttpHeaders();  
    headers.setContentType(org.springframework.http.MediaType.MULTIPART_FORM_DATA);  
    // 准备MultiValueMap来保存文件和其他表单字段  
    MultiValueMap<String, Object> body = new LinkedMultiValueMap<>();  
    body.add("files", new FileSystemResource(filePath));  
    body.add("user_id", "zzp");  
    body.add("kb_id", "KBb1dd58e8485443ce81166d24f6febda7");  
    body.add("mode", "soft");  
    // 创建HttpEntity  
    org.springframework.http.HttpEntity<MultiValueMap<String, Object>> requestEntity = new org.springframework.http.HttpEntity<>(body, headers);  
    // 发送请求  
    ResponseEntity<String> response = restTemplate.postForEntity(url, requestEntity,  
            String.class);  
    // 输出响应  
    System.out.println("Response: " + response.getBody());  
}

private File downloadFile(String fileUrl) throws IOException {  
    try (InputStream in = new URL(fileUrl).openStream()) {  
        File tempFile = Files.createTempFile("uploaded-", ".tmp").toFile();  
        try (FileOutputStream out = new FileOutputStream(tempFile)) {  
            byte[] buffer = new byte[4096];  
            int bytesRead;  
            while ((bytesRead = in.read(buffer)) != -1) {  
                out.write(buffer, 0, bytesRead);  
            }  
        }  
        System.out.println("File downloaded to: " + tempFile.getAbsolutePath());  
        return tempFile;  
    }  
}

OkHttp 版


private void uploadFile(File file, String fileName, String fileSuffix, String url) throws IOException {  
    OkHttpClient client = new OkHttpClient().newBuilder()  
            .build();  
    MediaType mediaType = MediaType.parse("text/plain");  
    //MultipartBody.Builder builder = new MultipartBody.Builder().setType(MultipartBody.FORM)  
    //        .addFormDataPart("user_id", "zzp")    //        .addFormDataPart("kb_id", "KB3e7062d6d6c54b10af79164009e736d8_240625")    //        .addFormDataPart("mode", "soft");    //for (File file : fileList) {    //    builder.addFormDataPart("files", file.getName(),    //            RequestBody.create(MediaType.parse("application/octet-stream"),    //                    file));    //}    //RequestBody body = builder.build();    RequestBody body = new MultipartBody.Builder().setType(MultipartBody.FORM)  
            .addFormDataPart("files", fileName + "." + fileSuffix,  
                    RequestBody.create(MediaType.parse("application/octet-stream"),  
                            file))  
            .addFormDataPart("user_id", "zzp")  
            .addFormDataPart("kb_id", "KBb1dd58e8485443ce81166d24f6febda7")  
            .addFormDataPart("mode", "soft")  
            .build();  
    Request request = new Request.Builder()  
            .url(url)  
            .method("POST", body)  
            .build();  
    Response response = client.newCall(request).execute();  
    System.out.println(response);  
}

如果文件是互联网资源文件可以使用如下代码进行下载:


/**  
 * 下载文件  
 *  
 * @param fileUrl  
 * @return  
 * @throws IOException  
 */  
private File downloadFile(String fileUrl) throws IOException {  
    try (InputStream in = new URL(fileUrl).openStream()) {  
        File tempFile = Files.createTempFile("uploaded-", ".tmp").toFile();  
        try (FileOutputStream out = new FileOutputStream(tempFile)) {  
            byte[] buffer = new byte[4096];  
            int bytesRead;  
            while ((bytesRead = in.read(buffer)) != -1) {  
                out.write(buffer, 0, bytesRead);  
            }  
        }  
        System.out.println("File downloaded to: " + tempFile.getAbsolutePath());  
        return tempFile;  
    }  
}  
  
/**  
 * 删除临时文件  
 *  
 * @param file  
 * @throws IOException  
 */  
private void delFile(File file) throws IOException {  
    // 删除临时文件  
    if (file.delete()) {  
        System.out.println("Temporary file deleted: " + file.getAbsolutePath());  
    } else {  
        System.out.println("Failed to delete temporary file: " + file.getAbsolutePath());  
    }  
}

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

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

相关文章

Spring Framework 的版本历史和JDK、Springboot对应关系

spring 历史版本迭代 版本版本特性Spring Framework 1.01. 所有代码都在一个项目中2. 支持核心功能IoC、AOP3. 内置支持Hibernate、iBatis等第三方框架4. 对第三方技术简单封装。如&#xff1a;JDBC、Mail、事务等5. 只支持XML配置方式。6.主要通过 XML 配置文件来管理对象和依…

SpringSecurity创建一个简单的认证应用

1、SpringSecurity 的简介 Spring Security是一个功能强大且高度可定制的身份验证和访问控制框架&#xff0c;它是Spring项目组中用来提供安全认证服务的框架&#xff0c;能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案。 Spring Security 的前身是 Acegi …

力扣 LeetCode 236. 二叉树的最近公共祖先(Day10:二叉树)

解题思路&#xff1a; 后序遍历 注意&#xff1a; p和q其中一个就是它们的公共祖先的情况也考虑到了&#xff0c;假设q是公共祖先&#xff0c;遇到q就直接返回&#xff0c;相当于是下面一边为空&#xff0c;一边不为空的情况&#xff0c;返回不为空就一边即可 class Solutio…

AIGC(生成式AI)试用 18 -- AI Prompt

"忘了"&#xff0c;“记不清了”&#xff0c;“有点印像” “能给点提示吗&#xff1f;” ...... “哦&#xff0c;想起来了&#xff0c;是这样的。。。。。。” 这就是提示的作用&#xff1a;通过关键信息、结构化信息提示&#xff0c;引导完整的、…

Telegram bot Mini-App开发实践---Telegram简单介绍与初始化小程序获取window.Telegram.WebApp对象并解析

➡️【好看的灵魂千篇一律,有趣的鲲志一百六七!】- 欢迎认识我~~ 作者:鲲志说 (公众号、B站同名,视频号:鲲志说996) 科技博主:极星会 星辉大使 后端研发:java、go、python、TS,前电商、现web3 主理人:COC杭州开发者社区主理人 、周周黑客松杭州主理人、 AI爱好…

在Windows环境下打包Qt C++项目为独立可执行文件的完整指南

目录 1. 配置Qt环境变量步骤&#xff1a; 2. 使用Release模式编译项目步骤&#xff1a; 3. 使用windeployqt工具收集依赖项步骤&#xff1a; 4. 精简复制后的文件目录方法一&#xff1a;使用windeployqt的选项方法二&#xff1a;手动删除不必要的文件方法三&#xff1a;使用静态…

多摩川编码器协议及单片机使用

参考&#xff1a; https://blog.csdn.net/qq_28149763/article/details/132718177 https://mp.weixin.qq.com/s/H4XoR1LZSMH6AxsjZuOw6g 1、多摩川编码器协议 多摩川数据通讯是基于485 硬件接口标准NRZ 协议&#xff0c;通讯波特率为2.5Mbps 的串行通讯&#xff0c;采用差分两…

2024年11月22日Github流行趋势

项目名称&#xff1a;twenty 项目维护者&#xff1a;charlesBochet, lucasbordeau, Weiko, FelixMalfait, bosiraphael 项目介绍&#xff1a;正在构建一个由社区驱动的现代Salesforce替代方案。 项目star数&#xff1a;22,938 项目fork数&#xff1a;2,413 项目名称&#xff1…

使用Kubernetes部署第一个应用

目录 前提条件 启动集群 部署 nginx 应用 创建 YAML 文件 应用 YAML 文件 查看部署结果 理解Pods 相关命令 公布应用程序 问题背景 Kubernetes Service&#xff08;服务&#xff09;概述 服务和标签 为Deployment 创建一个 Service 伸缩应用程序 Scaling&#x…

第T8周:Tensorflow实现猫狗识别(1)

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 具体实现 &#xff08;一&#xff09;环境 语言环境&#xff1a;Python 3.10 编 译 器: PyCharm 框 架: &#xff08;二&#xff09;具体步骤 from absl.l…

使用 OpenAI 进行数据探索性分析(EDA)

探索性数据分析&#xff08;Exploratory Data Analysis, 简称 EDA&#xff09;是数据分析中不可或缺的环节&#xff0c;帮助分析师快速了解数据的分布、特征和潜在模式。传统的 EDA 通常需要手动编写代码或使用工具完成。现在&#xff0c;通过 OpenAI 的 GPT-4 模型&#xff0c…

力扣-Hot100-栈【算法学习day.40】

前言 ###我做这类文档一个重要的目的还是给正在学习的大家提供方向&#xff08;例如想要掌握基础用法&#xff0c;该刷哪些题&#xff1f;&#xff09;我的解析也不会做的非常详细&#xff0c;只会提供思路和一些关键点&#xff0c;力扣上的大佬们的题解质量是非常非常高滴&am…

低速接口项目之串口Uart开发(四)——UART串口实现FPGA内部AXILITE寄存器的读写控制

本节目录 一、设计背景 二、设计思路 三、逻辑设计框架 四、仿真验证 五、上板验证 六、往期文章链接本节内容 一、设计背景 通常&#xff0c;芯片手册或者IP都会提供一系列的用户寄存器以及相关的定义&#xff0c;用于软件开发人员进行控制底层硬件来调试&#xff0c;或封装…

记录第一次安装laravel项目

window系统 Laravel中文文档&#xff1a;https://laravel-docs.catchadmin.com/docs/11/getting-started/installation 1.使用composer安装全局laravel composer global require laravel/installer2.安装完成后在命令行输入laravel&#xff0c;如果报错&#xff1a;laravel不是…

PDF电子发票信息转excel信息汇总

PDF电子发票信息提取&#xff0c;支持将pdf发票文件夹下的剩所有发票&#xff0c;转为excel格式的信息&#xff0c;对于发票量比较大&#xff0c;不好统计&#xff0c;需要一个一个去统计的情况&#xff0c;可节省2个点以上的时间&#xff0c;一次下载&#xff0c;终身有效。 使…

性能优化(二):ANR

介绍 ANR全称Application Not Responding&#xff0c;意思就是程序未响应。如果一个应用无法响应用户的输入&#xff0c;系统就会弹出一个ANR对话框&#xff0c;用户可以自行选择继续等待亦或者是停止当前程序。 Android系统会监控程序的响应状况&#xff0c;一旦出现下面情况…

Idea修改Commit Changes模式、idea使用git缺少部分Commit Changes

文章目录 一、模式一1、页面效果如下2、如何打开为这种样式&#xff1f; 二、模式二1、页面效果如下2、如何打开为这种样式&#xff1f; 三、总结 前言&#xff1a;Idea中代码提交到git库时的commit Change有两种模式&#xff0c;每种模式的界面及功能都不太一样。 Commit Cha…

【UE5】在材质中计算模型在屏幕上的比例

ViewProperty节点有很多有意思的变量 例如用 ViewProperty 的 tan ⁡ ( FOV / 2 ) \tan(\text{FOV} / 2) tan(FOV/2) 输出&#xff0c;用它计算模型占屏幕的比例。 &#xff08;常用于for运算的次数优化&#xff0c;也可以用于各种美术效果&#xff09; ScaleOnScreen Obje…

【STM32】MPU6050简介

文章目录 MPU6050简介MPU6050关键块带有16位ADC和信号调理的三轴MEMS陀螺仪具有16位ADC和信号调理的三轴MEMS加速度计I2C串行通信接口 MPU6050对应的数据手册&#xff1a;MPU6050 陀螺仪加速度计 链接: https://pan.baidu.com/s/13nwEhGvsfxx0euR2hMHsyw?pwdv2i6 提取码: v2i6…

vue3 在哪些方便做了性能提升?

概要 Vue (读音 /vjuː/&#xff0c;类似于 view) 是一套用于构建用户界面的渐进式框架。vue2版本阶段已经证明了它的易用性和流行性&#xff0c;说明它已经足够优秀在构建前端应用领域&#xff0c;而vue3的推出更是将性能提升做了最大的优化&#xff0c;更加易用、灵活、高效&…