在使用表单传送数据的时候,如果form 加了enctype="multipart/form-data" 这个属性,那么表单请求传到另一个jsp或servlet 里时
是不能用request.getParameter()来获取到各个表单元素的值的。
可以通用这样(上传组件提供的API):

boolean isMultipart = ServletFileUpload.isMultipartContent(request);
 if (isMultipart) {
  // Create a factory for disk-based file items
  org.apache.commons.fileupload.FileItemFactory factory = new DiskFileItemFactory();

// Create a new file upload handler
  ServletFileUpload upload = new ServletFileUpload(factory);
  // Parse the request
  List /* FileItem */items = upload.parseRequest(request);

// Process the uploaded items
  Iterator iter = items.iterator();
 
  while (iter.hasNext()) {
   org.apache.commons.fileupload.FileItem item = (org.apache.commons.fileupload.FileItem) iter
     .next();
   if (item.isFormField()) {
    String name = item.getFieldName();
    String value = item.getString("GBK");
    //out.println(name + "=" + value);
    params.put(name.toUpperCase(), value.trim());
   } ......
**************************************************************************************

使用multipart/form-data上传时,发送的请求和一般的http不一样,需要转化后才能读其他参数。  
   
  如果你用spring,它提供一个MultiRequestResolver,只需要:  
  MultipartHttpServletRequest   multipartRequest   =   (MultipartHttpServletRequest)   request;  
  然后就能正常读取参数:  
  multipartRequest.getParameter("xxx");  
   
  以下是spring的处理方法,必须首先安装commons-fileupload组件:  
   
  public   MultipartHttpServletRequest   resolveMultipart(HttpServletRequest   request)   throws   MultipartException   {  
  DiskFileUpload   fileUpload   =   this.fileUpload;  
  String   enc   =   determineEncoding(request);  
   
  //   use   prototype   FileUpload   instance   if   the   request   specifies  
  //   its   own   encoding   that   does   not   match   the   default   encoding  
  if   (!enc.equals(this.defaultEncoding))   {  
  fileUpload   =   new   DiskFileUpload();  
  fileUpload.setSizeMax(this.fileUpload.getSizeMax());  
  fileUpload.setSizeThreshold(this.fileUpload.getSizeThreshold());  
  fileUpload.setRepositoryPath(this.fileUpload.getRepositoryPath());  
  fileUpload.setHeaderEncoding(enc);  
  }  
   
  try   {  
  List   fileItems   =   fileUpload.parseRequest(request);  
  Map   parameters   =   new   HashMap();  
  Map   multipartFiles   =   new   HashMap();  
  for   (Iterator   it   =   fileItems.iterator();   it.hasNext();)   {  
  FileItem   fileItem   =   (FileItem)   it.next();  
  if   (fileItem.isFormField())   {  
  String   value   =   null;  
  try   {  
  value   =   fileItem.getString(enc);  
  }  
  catch   (UnsupportedEncodingException   ex)   {  
  logger.warn("Could   not   decode   multipart   item   '"   +   fileItem.getFieldName()   +  
          "'   with   encoding   '"   +   enc   +   "':   using   platform   default");  
  value   =   fileItem.getString();  
  }  
  String[]   curParam   =   (String[])   parameters.get(fileItem.getFieldName());  
  if   (curParam   ==   null)   {  
  //   simple   form   field  
  parameters.put(fileItem.getFieldName(),   new   String[]   {   value   });  
  }  
  else   {  
  //   array   of   simple   form   fields  
  String[]   newParam   =   StringUtils.addStringToArray(curParam,   value);  
  parameters.put(fileItem.getFieldName(),   newParam);  
  }  
  }  
  else   {  
  //   multipart   file   field  
  CommonsMultipartFile   file   =   new   CommonsMultipartFile(fileItem);  
  multipartFiles.put(file.getName(),   file);  
  if   (logger.isDebugEnabled())   {  
  logger.debug("Found   multipart   file   ["   +   file.getName()   +   "]   of   size   "   +   file.getSize()   +  
          "   bytes   with   original   filename   ["   +   file.getOriginalFilename()   +   "],   stored   "   +  
          file.getStorageDescription());  
  }  
  }  
  }  
  /*****   注意   parameters   就是普通的text之类的字段的值   *****/  
  return   new   DefaultMultipartHttpServletRequest(request,   multipartFiles,   parameters);  
  }  
  catch   (FileUploadBase.SizeLimitExceededException   ex)   {  
  throw   new   MaxUploadSizeExceededException(this.fileUpload.getSizeMax(),   ex);  
  }  
  catch   (FileUploadException   ex)   {  
  throw   new   MultipartException("Could   not   parse   multipart   request",   ex);  
  }  
  }  
**************************************************************************************

<form name="userInfo" method="post" action="first_submit.jsp"  ENCTYPE="multipart/form-data">
表单标签中设置enctype="multipart/form-data"来确保匿名上载文件的正确编码。
如下:
 <tr>
    <td height="30" align="right">上传企业营业执照图片:</td>
    <td><INPUT TYPE="FILE" NAME="uploadfile" SIZE="34"  onChange="checkimage()"></td>
  </tr>
就得加ENCTYPE="multipart/form-data"。
表单中enctype="multipart/form-data"的意思,是设置表单的MIME编码。默认情况,这个编码格式是application /x-www-form-urlencoded,不能用于文件上传;只有使用了multipart/form- data,才能完整的传递文件数据,进行下面的操作.
enctype=\"multipart/form-data\"是上传二进制数据; form里面的input的值以2进制的方式传过去。
form里面的input的值以2进制的方式传过去,所以request就得不到值了。 也就是说加了这段代码,用request就会传递不成功,

取表单值加入数据库时,用到下面的:
 SmartUpload su = new SmartUpload();//新建一个SmartUpload对象
 su.getRequest().getParameterValues();取数组值
 su.getRequest().getParameter( );取单个参数单个值

表单form的enctype="multipart/form-data"使用疑惑的更多相关文章

  1. form 中Enctype=multipart/form-data 的作用

    form 中Enctype=multipart/form-data 的作用 ENCTYPE="multipart/form-data"用于表单里有图片上传. <form na ...

  2. 表单:!!!常用JS: form 表单代码

    手机(文本框): <input type="text" name="" maxlength="11" placeholder=&quo ...

  3. form表单标签的enctype属性的作用

    Enctype是指定将数据回发到server时浏览器使用的编码类型.其编码类型有下面三种 一. application/x-www-form-urlencoded         这是通过表单发送数据 ...

  4. Form表单标签的Enctype属性的作用及应用示例介绍

    Enctype :指定将数据回发到服务器时浏览器使用的编码类型.用于表单里有图片上传. 编码类型有以下三种: application/x-www-form-urlencoded: 在发送前编码所有字符 ...

  5. Form的enctype="multipart/form-data"作用

    <form class="form-horizontal" role="form" method="post" action=&quo ...

  6. 解决当FORM的ENCTYPE="multipart/form-data" 时request.getParameter()获取不到值的方法

    部分转载于: http://blog.csdn.net/georgejin/article/details/1706647 http://www.cnblogs.com/loveyunk/p/6089 ...

  7. 进一步丰富和简化表单管理的组件:form.js

    上文<简洁易用的表单数据设置和收集管理组件>介绍了我自己的表单管理的核心内容,本文在上文的基础上继续介绍自己关于表单初始值获取和设置以及表单数据提交等内容方面的做法,上文的组件粒度很小,都 ...

  8. servler中表单加了enctype="multipart/form-data"属性后request就接收不到表单传过来的值了

    在解决博问node.js接受参数的时候,发现当form中添加enctype:"multipart/form-data",后台确实获取不到数据,于是跑到百度上查了一下,终于明白为什么 ...

  9. 表单(上)EasyUI Form 表单、EasyUI Validatebox 验证框、EasyUI Combobox 组合框、EasyUI Combo 组合、EasyUI Combotree 组合树

    EasyUI Form 表单 通过 $.fn.form.defaults 重写默认的 defaults. 表单(form)提供多种方法来执行带有表单字段的动作,比如 ajax 提交.加载.清除,等等. ...

随机推荐

  1. LeetCode - Triangle

    题目: Given a triangle, find the minimum path sum from top to bottom. Each step you may move to adjace ...

  2. 【转】 Key/Value之王Memcached初探:三、Memcached解决Session的分布式存储场景的应用

    一.高可用的Session服务器场景简介 1.1 应用服务器的无状态特性 应用层服务器(这里一般指Web服务器)处理网站应用的业务逻辑,应用的一个最显著的特点是:应用的无状态性. PS:提到无状态特性 ...

  3. has no parameters and arguments were supplied

    这个问题,让Insus.NET花上不少时间与心机. 在项目中,Insus.NET是使用这个逻辑组件: <程序与数据库之间的连接桥梁和逻辑处理>http://www.cnblogs.com/ ...

  4. WebForm 基础

    IIS安装 webForm需要IIS安装 1.安装:控制面板--程序或功能--打开或关闭windows功能--Internet信息服务(打上勾)--确定 2.让vs和IIS相互认识vs:vs2012- ...

  5. C++ VS2012 内存泄露检测

    在VS2012中添加部分代码,可以起到检测内存泄露的作用. 今天刚刚收到的解决办法,原理还不是很清楚.先分享出来 1. 头文件中添加以下代码 #ifdef _DEBUG #define DEBUG_C ...

  6. js动态显示表格的汇总信息和详细信息

    我在做数据结果展示的时候,想要实现一个如下的功能:    用户可以选择一个时间段,默认显示这个时间段的汇总数据,当鼠标点击这个时间段的时候,将显示每个时间点的详细数据,再次点击的时候,详细数据收起,只 ...

  7. MVC - Action和ActionResult

    Action 定义在Controller中的Action方法返回ActionResult对象,ActionResult是对Action执行结果的封装,用于最终对请求进行响应.HTTP是一个单纯的采用请 ...

  8. CAS客户端服务器端配置步骤

    来自我的个人网站:http://lkf.22web.org/ cas介绍: CAS 是 Yale 大学发起的一个开源项目,旨在为 Web 应用系统提供一种可靠的单点登录方法,CAS 在 2004 年 ...

  9. Java识别操作系统

    /** * Created by xfyou on 2016/11/3. */ public class SysDep { final static String UNIX_NULL_DEV = &q ...

  10. java集合-LinkedList

    一.概述 LinkedList 与 ArrayList 一样实现 List 接口,只是 ArrayList 是 List 接口的大小可变数组的实现,LinkedList 是 List 接口链表的实现. ...