Tomcat 7多部分表单数据

问题描述:

我有一个用Scala编写的Play 2.0 web应用程序。我使用play war插件生成了一个WAR文件,并部署在tomcat 7.0.27上。Tomcat 7多部分表单数据

当我使用enctype =“multipart/form-data”提交表单时,请求就会失败。这个错误似乎与播放框架没有找到数据的“边界”有关。

我已经试图把allowCasualMultipartParsing =“真”,但它并不能帮助

相同的代码工作发挥服务器上的罚款。我在Tomcat上错过了什么?是否有特定的配置可以启用/禁止多部分?

相关格式代码为:

<form method="POST" action="/create" id="myform" class="form-horizontal" enctype="multipart/form-data"> 
<input type="file" name="logo" id="logo" placeholder="Logo Image" class="input-xlarge" /> 
<input type="submit" value="Save Details" class="btn btn-info"/> 
</form> 

控制器代码如下所示:

val hash_string = "xxxxxxxxxxxx" 
var logoFile: String = null 

request.body.asMultipartFormData.map { x => x.file("logo").map { logo => logoFile = uploadFile(hash_string, logo) } } 

即使我不上传文件,我仍然得到一个错误请求 - 自卸如下:

Map(HOST -> non-empty iterator, ACCEPT-ENCODING -> non-empty iterator, 
ACCEPT-LANGUAGE -> non-empty iterator, REFERER -> non-empty iterator, 
CONTENT-LENGTH -> non-empty iterator, ORIGIN -> non-empty iterator, 
ACCEPT-CHARSET -> non-empty iterator, CONNECTION -> non-empty 
iterator, CONTENT-TYPE -> empty iterator, CACHE-CONTROL -> non-empty 
iterator, ACCEPT -> non-empty iterator, COOKIE -> empty iterator, USER- 
AGENT -> non-empty iterator) Map(utmc -> Cookie(utmc, 
84437902,-1,/,None,false,false), utmz -> Cookie(utmz, 
84437902.1337318013.1.1.utmcsr,-1,/,None,false,false), PLAYSESSION -> 
Cookie(PLAY_SESSION,11cd5ffd7e2b56910a6a118e0de60be50c963697-email 
%3Axxxxxxxxxxx,-1,/,None,false,false), __utma -> Cookie(utma, 
84437902.1740292094.1337318013.1337510573.1337583859.6,-1,/,None,false,fals e), 
__utmb -> Cookie(_utmb, 
84437902.2.10.1337583859,-1,/,None,false,false))' [Missing boundary 
header] 
+0

请贴上错误的情况 – UVM

+0

@UnniVMana,添加。 – aishwarya

问题是如果您使用 “request.body.asMultipartFormData”作为我在我的代码中使用,它运行 与戏剧,但不在tomcat上。但是,如果您使用 'parse.multipartFormData'BodyParser,那就行了。不知道为什么,但 它 所以现在,我的方法是这样的:

def create = IsMultipartAuthenticated(parse.multipartFormData) { user 
    => implicit request => 
    ... 
    request.body.file("logo").map { logo => ... } 
    ... 
    Ok 
} 

我已经加入到担保性状的方法:

def IsMultipartAuthenticated(p: BodyParser[MultipartFormData[TemporaryFile]])(f: => String => 
    Request[MultipartFormData[TemporaryFile]] => Result) = 
    Security.Authenticated(username, onUnauthorized) { user => 
    Action(p)(request => f(user)(request)) 
    }