后台调用接口传输multipartFile

对方接口样式

后台直接调用该接口

import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.entity.mime.MultipartEntityBuilder;
import org.apache.http.entity.mime.HttpMultipartMode;


// 创建Http实例
        CloseableHttpClient httpClient = HttpClients.createDefault();
        // 创建HttpPost实例
        HttpPost httpPost = new HttpPost(hdsfip + uploadUrl+ "?zybm=123&fydm=123" );
        // 请求参数配置
        RequestConfig requestConfig = RequestConfig.custom().setSocketTimeout(60000).setConnectTimeout(60000)
                .setConnectionRequestTimeout(10000).build();
        httpPost.setConfig(requestConfig);
        httpPost.setHeader("Authorization","Bearer "+tokenVO.getAccess_token());
        try {
            MultipartEntityBuilder builder = MultipartEntityBuilder.create();
            builder.setCharset(StandardCharsets.UTF_8);
            builder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE);
            for (File file : files) {
                String fileName = file.getName();
                System.err.println(file);
                System.err.println(fileName);
                System.err.println("==============================");
                // 文件流
                builder.addBinaryBody("file", new FileInputStream(file), ContentType.MULTIPART_FORM_DATA, fileName);
            }
            //表单中其他参数,如果没有其他参数可以注释该部分
//            for(Map.Entry<String, String> entry: paramMap.entrySet()) {
//                builder.addPart(entry.getKey(),new StringBody(entry.getValue(), ContentType.create("text/plain", Consts.UTF_8)));
//            }
            HttpEntity entity = builder.build();
            httpPost.setEntity(entity);
            // 执行提交
            CloseableHttpResponse response = httpClient.execute(httpPost);
            if (response.getStatusLine().getStatusCode() == HttpStatus.SC_OK) {
                // 返回
                String result = EntityUtils.toString(response.getEntity(), StandardCharsets.UTF_8);
                System.err.println("文件上传:   "+result);
                HdsfResultVO resultVO = JSONObject.parseObject(result, HdsfResultVO.class);
                return resultVO;
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            if (httpClient != null) {
                try {
                    httpClient.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }

引包

        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpmime</artifactId>
            <version>4.5.2</version>
            <scope>compile</scope>
        </dependency>

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Python中调用Java接口,特别是涉及到文件上MultipartFile[])时,通常会遇到跨语言通信的问题。Python本身没有内置支持直接调用Java方法,但可以通过一些库如`py4j`(用于JVM和Python之间的交互)、`requests`配合JSON编码,或者使用像Django、Flask等框架提供的反序列化工具来处理。 当你想从Python递一个`MultipartFile[]`类型的参数给Java接口时,你需要这样做: 1. Python端准备数据: - 首先,将多个`MultipartFile`对象封装到一个列表或数组中。 - 每个`MultipartFile`对象代表一个文件,通常包含了文件内容和文件名信息。 ```python from flask import Flask, request, jsonify import requests app = Flask(__name__) files = [request.files.get('file{}'.format(i)) for i in range(len(file_list))] # 假设file_list是一个包含文件索引的列表 # 将文件列表转换为字典或其他适合序列化的形式 file_data = [{'filename': file.filename, 'content': file.read().decode()} for file in files] ``` 2. 序列化和发送请求: - 使用`json.dumps()`将Python字典转换成JSON字符串,因为大多数HTTP请求默认接受JSON格式的数据。 - 发送POST请求到Java接口,附带Content-Type设置为application/json。 ```python headers = {'Content-Type': 'application/json'} response = requests.post(url='your_java_api_url', json=file_data, headers=headers) if response.status_code == 200: # 处理返回结果 else: print(f"Error: {response.text}") ``` 3. Java接口接收: - 在Java端,定义一个能接受类似JSON结构的RESTful接口,解析接收到的JSON数据并处理每个`MultipartFile`。 - 可能需要用到如`com.fasterxml.jackson.databind.ObjectMapper`进行反序列化。 ```java @PostMapping("/upload") public ResponseEntity<String> uploadFiles(@RequestBody List<MultiPartFile> files) { // 解析并处理文件列表 // ... } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值