Возврат ответа JSON из сервлета на страницу Javascript/JSP
Я думаю (на самом деле я знаю!) Я делаю что-то неправильно Здесь я пытаюсь заполнить некоторые значения в 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 возвращается нормально, но его строка. Любые советы очень ценятся. Я также открываю для использования googles Gson, но не имею слишком много знаний об этом.
3 ответов
Он работает! Я должен был строить JSONArray
of JSONObject
s, а затем добавьте массив в окончательный "адреса"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. Надеюсь, это поможет кому-то еще в будущем. Спасибо за вашу помощь Марсель
я использовал 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);
сервлет возвращает этот объект JSON, как показано ниже:
response.setContentType("application/json");
response.getWriter().write(jsonReturn.toString());
этот сервлет вызывается из браузера с помощью AngularJs, как показано ниже
$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);
});
};
этот код работал и он показывает правильные данные в диалоговом окне предупреждение:
данные.заголовок.статус: успех
данные.заголовок.FailureReason : Нет
данные.заголовок.DetailElements: 2
данные.Элементы : Кома отдельные строковые значения, т. е. NhAdminTree, userName
Я думаю, что вы хотите превратить строку JSON обратно в объект, когда она вернется в ваш XMLHttpRequest - правильно?
Если это так, то вам нужно оценку строка, чтобы превратить ее в объект JavaScript-обратите внимание, что это может быть небезопасно, поскольку Вы доверяете, что строка JSON не является вредоносной и поэтому выполняет ее. Предпочтительно вы можете использовать jQuery parseJSON