form表单设置enctype=“multipart/form-data“后获取参数

一般我们写form表单时enctype默认为“application/x-www-form-urlencoded”。

但当form表单设置method="post" enctype="multipart/form-data"上传文件时, request就取不到参数了,但是可以获得到文件。

先介绍一下enctype属性

1、application/x-www-form-urlencoded。默认的编码方式。基于uri的percent-encoding编码的,表单里的数据被编码为名称/值对,但是在用文本的传输和MP3等大型文件的时候,使用这种编码就显得 效率低下。

2、multipart/form-data 。 指定传输数据为二进制类型,比如图片、mp3、文件。 这个一般文件上传时用。它告诉我们传输的数据要用到多媒体传输协议,由于多媒体传输的都是大量的数据,所以规定上传文件必须是post方法,type="file",浏览器会把整个表单以控件为单位分割。并为每个部分加上Content-Disposition(form-data或者file),Content-Type(默认为text/plain),name(控件name)等信息,并加上分割符(boundary)。

3、text/plain。纯文体的传输。空格转换为 “+” 加号,但不对特殊字符编码。


当我们上传二进制类型的文件时又想传递参数怎么办?

在此举个例子,编写HTML代码时像upload这个JAVA类传参,代码如下:

 <form action="upload?album=<%=session.getAttribute("entername") %>" method="post" enctype="multipart/form-data">
        <div class="group">
            <label id="account">选择上传的图片:</label>
            <input id="file1" type="file" name="Filename" >
        </div>
               <input id="button" type="submit" value="上传" class="input-group">
    </form>

然后在JAVA中写:

String album = request.getParameter("album");

即可获取参数的值。

  • 7
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@Benron

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值