Domanda

Ho un'applicazione Web Play 2.0 scritta in Scala.Ho generato un file di guerra usando il plugin di Guerra Play e dispiegato su Tomcat 7.0.27.

Quando inviare un modulo con Encype="Multipart / Form-Data", la richiesta cade.L'errore sembra essere con il quadro di gioco che non trova un "confine" ai dati.

Ho già provato a mettere AllowCasualmultiPartParsing="True" ma non aiuta

Lo stesso codice funziona bene sul server PLAY.Cosa mi manca su Tomcat?Esiste una configurazione specifica che abilita / sopprime Multipart?

Il codice del modulo pertinente è:

<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>
.

Il codice del controller è simile a:

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

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

Anche se non caricando un file, ho ancora un dump Badrichest come segue:

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] 
.

È stato utile?

Soluzione

Il problema è stato che se usi "Richiesta.body.asmultipartformData" come stavo usando nel mio codice, funziona con il gioco ma non è su Tomcat.Tuttavia, se usi il 'Parse.multipartformData' bodyparser, che funziona.Non so perché, ma lo fa Allora, ora, il mio metodo sembra:

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

Ho aggiunto un metodo per garantire il tratto:

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

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top