enctype="multipart/form-data"设置与不设置的区别

本片文章将揭秘,在form表单中,enctype="multipart/form-data"设置与不设置时,服务器接收数据的不同情况!

情景1

页面:


服务端(核心部分)

//request方式获取值

System.out.println(req.getParameter("foodName"));
System.out.println(req.getParameter("foodPrice"));
System.out.println(req.getParameter("foodDetail"));
System.out.println(req.getParameter("foodLogo"));


//接收请求的输入流
fileSource = req.getInputStream();
//初始化临时文件路径名称
String tempFileName = Constants.FILE_ROOT + req.getContextPath() +
        File.separator + "file" + File.separator +
        "temp" + File.separator + "tempFile";
//初始化临时文件对象
File tempFile = new File(tempFileName);
//初始化临时文件路径
File tempFilePath = new File(tempFile.getParent());
if (!tempFilePath.exists()){
    tempFilePath.mkdirs();
}

outputStream = new FileOutputStream(tempFile);
int n;

//输入到tempfile文件中
while ((n = fileSource.read(b)) != -1){
    outputStream.write(b,0,n);
}
接收结果:

request获取到的值(如下图所示):


文件路径及文件被创建,但未传入数据;

情景2

页面:(multipart/form-data -> 以二进制数据流的方式传输)


服务端代码不变!

接收结果:


tempFile文件内容:


  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
enctype="multipart/form-data"是HTML表单中的一个属性,用于指定表单数据的编码类型。它表示表单数据包含多个部分,既包括文本数据,也包括文件等二进制数据。 需要注意的是,默认情况下,enctype的值是application/x-www-form-urlencoded,这种编码类型不能用于文件上传。只有在使用了multipart/form-data编码类型时,才能完整地传递文件数据。 使用enctype="multipart/form-data"可以模拟一个POST multipart/form-data类型的请求,这种请求格式与application/x-www-form-urlencoded完全不同。在这种编码类型中,需要在HTTP请求头中设置一个分隔符来分隔各个部分的数据。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [form表单中的enctype=“multipart/form-data“什么意思?](https://blog.csdn.net/lingxiyizhi_ljx/article/details/102514560)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [multipart form-data boundary 说明](https://blog.csdn.net/weixin_30547797/article/details/96177005)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值