2016-05-20 3 views
1

Je travaille sur un projet MVC, en utilisant Java et Play framework, et j'ai rencontré un problème. Voici la partie intéressante du code (je l'ai nettoyé un peu):Obtenir une erreur 500 mais renvoyé ok()

Le contrôleur:

public Result acceptInputSimulationPension() { 
    if (request().getHeader(CONTENT_TYPE) == null) { 
     return badRequest("error: no content type"); 
    } 
    if (!request().getHeader(CONTENT_TYPE).contains("multipart/form-data")) { 
     return badRequest("Error: wrong content type. Expected multipart/form-data, got " + CONTENT_TYPE); 
    } 

    Form<String> form = Form.form(String.class).bindFromRequest(); 
    Pension project = new Pension(); 

    project.setMaxloss(form.field("maxloss").value()); 
    // setting some other parameters... 
    project.setIdUser(Application.user.getId()); 

    if (project.getMaxloss() == 0) { 
     return badRequest("error: maxloss datalist malformed"); 
    } 

    double[] flows = Application.getPensionFlows(project, (int) project.computeContributionYears(), (int) project.computeAdditionalIncomeNeeded()); 
    Savings savings = new Savings((int) project.getInitialContribution(), flows, (int) project.computeContributionYears() * 12); 
    Ebean.save(project); 

    session("init/pension/maxloss"+project.getId(), form.field("maxloss").value()); 
    // setting some other session variables... 

    ObjectNode result = Application.jsonEncoder.encodeFinalSimulPension(project, savings.getSavings(), flows, false, true); 
    result.put("id", project.getId()); 
    System.out.println("hello?"); 
    return ok("test"); 
} 

Je retourne ok (« test ») pour vous assurer que le problème ne vient pas de la variable de résultat.

Et l'AJAX:

function ajaxPOST_simulation(data, id, formName) { 
$.ajax({ 
    type: 'POST', 
    url: "/input/simulation/"+formName, 
    processData: false, 
    contentType: false, 
    data: data, 
    success: function (resp) { 
     alert("ok"); 
    }, 
    error: function (resp) { 
     alert("error: " + resp.responseText); 
    } 
}); 
} 

Le System.out.println ("bonjour") est affiché avec succès sur mon terminal, donc je suppose que je retourne ok ("test"), mais je reçois ce erreur comme une alerte:

error: 
<!DOCTYPE html> 
<html lang="en"> 
    <head> 
     <title>Execution exception</title> 
     <link rel="shortcut icon" href="data:image/png;base64,iVBORw0KGgoAAAANSU... etc. 

Comment est-ce possible? Merci d'avance! J'ai juste compris que le code HTML correspondait à NullPointerException, mais je n'ai toujours aucune idée de ce qui pourrait être NULL ici. Même la variable de résultat est NULL et regarde ok ...

Répondre

0

Transforme que le problème ne venait pas du JSON, ni de la ajax: Je voulais simplement faire:

session("init/pension/maxloss"+project.getId(), form.field("maxloss").value()); 

avec un champ qui n'existait plus. Je pensais que ce genre d'erreur lèverait une exception et arrêterait le programme avant qu'il n'atteigne la fin de la fonction.