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");

即可获取参数的值。

猜你喜欢

转载自blog.csdn.net/weixin_52188227/article/details/126369127
今日推荐