通过后台Http请求的形式实现文件的上传与传输

简介: 在开发中,我们可能会遇到两个不同的系统之间进行文件传输的需求,由于没有对应的界面操作,所以,此时就需要通过java后台代码的形式来实现文件的上传操作,本文主要讲解如何通过后台方法的形式来实现文件的上传功能,并能实现相应的接收功能。

本文仅已两个不同的接口来模拟两台服务器(两台服务器是同样的代码即可实现)

本文是比较简单的实现【初级版】,能够满足文件的发送,并且能够携带必要的参数
后续会迭代新的版本,比如说多文件传输,参数多样化等
/**
 * 模拟发送方
 */
@RequestMapping(value = "/send")
@ResponseBody
public void send() throws IOException {
    String requestUrl = "http://127.0.0.1/profile/filetest/rec";
    Map<String, String> params = new HashMap<>();
    File file = new File("D:\\test\\test.png");
    HttpFileUtils.upLoadFilePost(requestUrl, file, params);
}

/**
 * 模拟接收方
 */
@RequestMapping(value = "/rec")
@ResponseBody
public String rec(MultipartHttpServletRequest multiRequest){
    if (multiRequest == null)
        return null;
    try {
        MultipartFile file = multiRequest.getFile("file");
        if (!file.isEmpty()) {
            Map<String, String[]> parameterMap = multiRequest.getParameterMap();
            //接收参数信息
            for(String key: parameterMap.keySet()){
                System.err.println(key+":"+parameterMap.get(key));
            }

            //接收文件
            String profilePath = "D:\\test\\1\\rec.png";
            File iFile = new File(profilePath);
            File iFileParent = iFile.getParentFile();
            if (!iFileParent.exists())
                iFileParent.mkdirs();
            // 转存文件
            file.transferTo(iFile);
        }
    } catch (Exception e1) {
        e1.printStackTrace();
        logger.info("从Request拉取文件失败");
    }
    return "success";
}

工具类

/**
 * 通用http发送文件方法
 *
 * @author liguangni
 * @Date 2022.03.18
 */
public class HttpFileUtils {
    private static final Logger log = LoggerFactory.getLogger(HttpFileUtils.class);


    /**
     * 通过Http发送单个文件
     *
     * @param requestUrl 目标接口请求地址
     * @param file      发送的文件
     * @param params    附加的参数
     * @return
     * @throws IOException
     */
    public static String upLoadFilePost(String requestUrl, File file, Map<String, String> params) throws IOException {
        String BOUNDARY = java.util.UUID.randomUUID().toString();
        String PREFIX = "--", LINEND = "\r\n";
        String MULTIPART_FROM_DATA = "multipart/form-data";
        String CHARSET = "UTF-8";
        URL uri = new URL(requestUrl);
        HttpURLConnection conn = (HttpURLConnection) uri.openConnection();
        conn.setReadTimeout(5 * 1000);
        conn.setDoInput(true);// 允许输入
        conn.setDoOutput(true);// 允许输出
        conn.setUseCaches(false);
        conn.setRequestMethod("POST"); // Post方式
        conn.setRequestProperty("connection", "keep-alive");
        conn.setRequestProperty("Charsert", "UTF-8");
        conn.setRequestProperty("Content-Type", MULTIPART_FROM_DATA + ";boundary=" + BOUNDARY);

        DataOutputStream outStream = new DataOutputStream(conn.getOutputStream());

        // 添加参数
        StringBuffer paramsb = new StringBuffer();
        for (Map.Entry<String, String> entry : params.entrySet()) {
            paramsb.append(PREFIX);
            paramsb.append(BOUNDARY);
            paramsb.append(LINEND);
            paramsb.append("Content-Disposition: form-data;name=\"" + entry.getKey() + "\"");
            paramsb.append(LINEND);
            paramsb.append(LINEND);
            paramsb.append(entry.getValue());
            paramsb.append(LINEND);
        }
        outStream.write(paramsb.toString().getBytes());

        // 发送文件数据
        StringBuilder sb1 = new StringBuilder();
        sb1.append(PREFIX);
        sb1.append(BOUNDARY);
        sb1.append(LINEND);
        sb1.append("Content-Disposition: form-data; name=\"file\"; filename=\"" + file.getName() + "\"" + LINEND);
        sb1.append("Content-Type: application/octet-stream; charset=" + CHARSET + LINEND);
        sb1.append(LINEND);
        outStream.write(sb1.toString().getBytes());
        InputStream is = new FileInputStream(file);
        byte[] buffer = new byte[1024];
        int len = 0;
        while ((len = is.read(buffer)) != -1) {
            outStream.write(buffer, 0, len);
        }

        is.close();
        outStream.write(LINEND.getBytes());


        // 请求结束标志
        byte[] end_data = (PREFIX + BOUNDARY + PREFIX + LINEND).getBytes();
        outStream.write(end_data);
        outStream.flush();

        // 得到响应码
        int res = conn.getResponseCode();
        if (res == 200) {
            InputStream in = conn.getInputStream();
            InputStreamReader isReader = new InputStreamReader(in);
            BufferedReader bufReader = new BufferedReader(isReader);
            String line = "";
            String data = "";
            while ((line = bufReader.readLine()) != null) {
                data += line;
            }
            outStream.close();
            conn.disconnect();
            return data;
        }
        outStream.close();
        conn.disconnect();
        return null;
    }
}
目录
相关文章
|
1月前
|
数据采集
Haskell爬虫:连接管理与HTTP请求性能
Haskell爬虫:连接管理与HTTP请求性能
|
15天前
|
监控 网络协议 应用服务中间件
【Tomcat源码分析】从零开始理解 HTTP 请求处理 (第一篇)
本文详细解析了Tomcat架构中复杂的`Connector`组件。作为客户端与服务器间沟通的桥梁,`Connector`负责接收请求、封装为`Request`和`Response`对象,并传递给`Container`处理。文章通过四个关键问题逐步剖析了`Connector`的工作原理,并深入探讨了其构造方法、`init()`与`start()`方法。通过分析`ProtocolHandler`、`Endpoint`等核心组件,揭示了`Connector`初始化及启动的全过程。本文适合希望深入了解Tomcat内部机制的读者。欢迎关注并点赞,持续更新中。如有问题,可搜索【码上遇见你】交流。
【Tomcat源码分析】从零开始理解 HTTP 请求处理 (第一篇)
|
4天前
|
JSON Java 数据格式
java操作http请求针对不同提交方式(application/json和application/x-www-form-urlencoded)
java操作http请求针对不同提交方式(application/json和application/x-www-form-urlencoded)
9 1
|
24天前
|
JSON JavaScript 前端开发
Haskell中的数据交换:通过http-conduit发送JSON请求
Haskell中的数据交换:通过http-conduit发送JSON请求
|
26天前
|
JSON API 开发者
Python网络编程新纪元:urllib与requests库,让你的HTTP请求无所不能
【9月更文挑战第9天】随着互联网的发展,网络编程成为现代软件开发的关键部分。Python凭借简洁、易读及强大的特性,在该领域展现出独特魅力。本文介绍了Python标准库中的`urllib`和第三方库`requests`在处理HTTP请求方面的优势。`urllib`虽API底层但功能全面,适用于深入控制HTTP请求;而`requests`则以简洁的API和人性化设计著称,使HTTP请求变得简单高效。两者互补共存,共同推动Python网络编程进入全新纪元,无论初学者还是资深开发者都能从中受益。
39 7
|
24天前
|
开发者
HTTP状态码是由网页服务器返回的三位数字响应代码,用于表示请求的处理结果和状态
HTTP状态码是由网页服务器返回的三位数字响应代码,用于表示请求的处理结果和状态
24 1
|
27天前
|
存储 JSON API
Python编程:解析HTTP请求返回的JSON数据
使用Python处理HTTP请求和解析JSON数据既直接又高效。`requests`库的简洁性和强大功能使得发送请求、接收和解析响应变得异常简单。以上步骤和示例提供了一个基础的框架,可以根据你的具体需求进行调整和扩展。通过合适的异常处理,你的代码将更加健壮和可靠,为用户提供更加流畅的体验。
64 0
|
Web App开发
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
TCP洪水攻击(SYN Flood)的诊断和处理 Posted by  海涛  on 2013 年 7 月 11 日 Tweet1 ​1. SYN Flood介绍 前段时间网站被攻击多次,其中最猛烈的就是TCP洪水攻击,即SYN Flood。
986 0
|
Web App开发 前端开发 Java
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
ZooKeeper 保证了数据的强一致性,  zk集群中任意节点(一个zkServer)上的相同znode下的数据一定是相同的。
791 0

热门文章

最新文章

下一篇
无影云桌面