0

我不明白为什么会出错:在下一个代码上:

void logout(HTTPServerRequest req, HTTPServerResponse res)
{
    try
    {
        logInfo("Logout section");
        Json request = req.json;
        Json responseBody = Json.emptyObject; // 

        if (req.session) // if user have active session
        {
            res.terminateSession();
            responseBody["status"] = "success";
            responseBody["isAuthorized"] = false;
            res.writeJsonBody(responseBody);
            logInfo("-------------------------------------------------------------------------------");
            logInfo(responseBody.toString);
            logInfo("^-----------------------------------------------------------------------------^");                              
            logInfo("User %s logout", request["username"]); //
            logInfo("User 12333333333333 logout"); //
        }

        else
        {
            responseBody["status"] = "fail"; // user do not have active session?
            logInfo("User do not have active session"); 
            res.writeJsonBody(responseBody);
        }
    writeln("-------before-------");
    writeln(responseBody.toString);
    res.writeJsonBody(responseBody);
    writeln("-------after-------");
    }

    catch (Exception e)
    {
        logInfo(e.msg);
        writeln("3333");
    }
}

这是截图

我做错了什么?

4

1 回答 1

3

writeJsonBody 立即序列化响应 JSON 设置statuscontent_type关闭输出流。仔细查看您的代码 - 它调用res.writeJsonBody(responseBody)了两次。

如果您想流式传输响应,您可以像这样访问输出流res.bodyWriter.put("a sentence."),但请注意,一旦第一次访问,就不允许更改响应的任何标头(例如状态码),因为标头已发送给客户。

顺便说一句,您可能对 Vibed 的高级REST API功能感兴趣。

于 2016-06-14T10:42:44.653 回答