簡體   English   中英

從 Servlet 向 Javascript/JSP 頁面返回 JSON 響應

[英]Returning JSON response from Servlet to Javascript/JSP page

我認為(實際上我知道:)我在這里做錯了我試圖將一些值填充到 HashMap 並將每個 hasmap 添加到列表中,該列表將添加到 JSON 對象中:

JSONObject json = new JSONObject();
try
{
    Map address;
    List addresses = new ArrayList();

    int count = 15;

    for (int i=0 ; i<count ; i++)
    {
        address = new HashMap();
        address.put("CustomerName"     , "Decepticons" + i);
        address.put("AccountId"        , "1999" + i);
        address.put("SiteId"           , "1888" + i);
        address.put("Number"            , "7" + i);
        address.put("Building"          , "StarScream Skyscraper" + i);
        address.put("Street"            , "Devestator Avenue" + i);
        address.put("City"              , "Megatron City" + i);
        address.put("ZipCode"          , "ZZ00 XX1" + i);
        address.put("Country"           , "CyberTron" + i);
        addresses.add(address);
    }
    json.put("Addresses", addresses);
}
catch (JSONException jse)
{

}
response.setContentType("application/json");
response.getWriter().write(json.toString());

我的問題是我知道這是返回一個字符串,我似乎無法解析(這是問題所在)。 我的問題是如何返回實際的 JSON 編碼字符串(或者我什至應該這樣做嗎?)或者針對此類問題的最佳攻擊方法是什么。 我使用的 JavaScript 如下:

function getReadyStateHandler(req)
{
    // Return an anonymous function that listens to the
    // XMLHttpRequest instance
    return function ()
    {
        // If the request's status is "complete"
        if (req.readyState == 4)
        {
            // Check that a successful server response was received
            if (req.status == 200)
            {
                msgBox("JSON Response recieved...");
                populateDatagrid(req.responseText.toJSON());
            }
            else
            {
                // An HTTP problem has occurred
                alert("HTTP error: " + req.status);
            }
        }
    }
}

請注意 JSON 響應恢復正常,但它是一個字符串。 任何意見是極大的贊賞。 我也開始使用谷歌 Gson,但對此沒有太多了解。

得到它的工作! 我應該一直在構建JSONObjectJSONArray ,然后將該數組添加到最終的“地址” JSONObject中。 請注意以下事項:

JSONObject json      = new JSONObject();
JSONArray  addresses = new JSONArray();
JSONObject address;
try
{
   int count = 15;

   for (int i=0 ; i<count ; i++)
   {
       address = new JSONObject();
       address.put("CustomerName"     , "Decepticons" + i);
       address.put("AccountId"        , "1999" + i);
       address.put("SiteId"           , "1888" + i);
       address.put("Number"            , "7" + i);
       address.put("Building"          , "StarScream Skyscraper" + i);
       address.put("Street"            , "Devestator Avenue" + i);
       address.put("City"              , "Megatron City" + i);
       address.put("ZipCode"          , "ZZ00 XX1" + i);
       address.put("Country"           , "CyberTron" + i);
       addresses.add(address);
   }
   json.put("Addresses", addresses);
}
catch (JSONException jse)
{ 

}
response.setContentType("application/json");
response.getWriter().write(json.toString());

這有效並返回了有效且可解析的 JSON。 希望這對將來的其他人有所幫助。 感謝您的幫助馬塞爾

我在 Servlet 中使用了 JSONObject,如下所示。

    JSONObject jsonReturn = new JSONObject();

    NhAdminTree = AdminTasks.GetNeighborhoodTreeForNhAdministrator( connection, bwcon, userName);

    map = new HashMap<String, String>();
    map.put("Status", "Success");
    map.put("FailureReason", "None");
    map.put("DataElements", "2");

    jsonReturn = new JSONObject();
    jsonReturn.accumulate("Header", map);

    List<String> list = new ArrayList<String>();
    list.add(NhAdminTree);
    list.add(userName);

    jsonReturn.accumulate("Elements", list);

Servlet 返回此 JSON object,如下所示:

    response.setContentType("application/json");
    response.getWriter().write(jsonReturn.toString());

使用 AngularJs 從瀏覽器調用此 Servlet,如下所示

$scope.GetNeighborhoodTreeUsingPost = function(){
    alert("Clicked GetNeighborhoodTreeUsingPost : " + $scope.userName );

    $http({

        method: 'POST',
        url : 'http://localhost:8080/EPortal/xlEPortalService',
        headers: {
           'Content-Type': 'application/json'
         },
        data : {
            'action': 64,
            'userName' : $scope.userName
        }
    }).success(function(data, status, headers, config){
        alert("DATA.header.status : " + data.Header.Status);
        alert("DATA.header.FailureReason : " + data.Header.FailureReason);
        alert("DATA.header.DataElements : " + data.Header.DataElements);
        alert("DATA.elements : " + data.Elements);

    }).error(function(data, status, headers, config) {
        alert(data + " : " + status + " : " + headers + " : " + config);
    });

};

此代碼有效,它在警報對話框中顯示正確的數據:

Data.header.status:成功

Data.header.FailureReason:無

Data.header.DetailElements:2

Data.Elements:逗號分隔的字符串值,即 NhAdminTree、用戶名

我認為您想要做的是在 JSON 字符串返回 XMLHttpRequest 時將其轉回 object - 對嗎?

如果是這樣,您需要評估字符串以將其轉換為 JavaScript object - 請注意,這可能是不安全的,因為您相信 JSON 字符串不是惡意的因此執行它。 最好你可以使用 jQuery 的parseJSON

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM