获得错误500但返回ok()

时间:2016-05-20 08:00:31

标签: java ajax playframework-2.0 internal-server-error

我正在使用Java和Play框架开发MVC项目,我遇到了一个问题。这是代码中有趣的部分(我清理了一下):

控制器:

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

我正在返回ok(“test”)以确保问题不是来自结果变量。

和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);
    }
});
}

System.out.println(“hello”)已成功显示在我的终端上,所以我想我正在返回ok(“test”),但我将此错误视为警告:

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

这怎么可能? 提前谢谢!

编辑: 我只是发现HTML代码对应NullPointerException,但我仍然不知道这里有什么可以为NULL。甚至结果变量也不是NULL并且看起来没问题......

1 个答案:

答案 0 :(得分:0)

事实证明问题不是来自json,也不是来自ajax:我只是想这样做:

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

有一个不再存在的字段。 我认为这种错误会引发异常并在程序到达函数结束之前停止该程序。