Я какое-то время возился с JSON , просто выкладывал его в виде текста, и это никому не повредило (насколько я знаю), но я бы хотел начать делать что-то должным образом.
Я видел , поэтому многие подразумевали «стандарты» для типа контента JSON:
application/json
application/x-javascript
text/javascript
text/x-javascript
text/x-json
Но какой из них правильный или лучший? Я понял, что между ними существуют разные проблемы с безопасностью и поддержкой браузера.
Я знаю, что есть похожий вопрос: Какой тип MIME, если JSON возвращается через REST API? , но я бы хотел получить более точный ответ.
Для текста JSON:
application/json
тип среды MIME для текста JSON
application/json
. Кодировка по умолчанию является UTF-8. (Источник: RFC 4627 ).
Для JSONP (выполнимый JavaScript) с обратным вызовом:
application/javascript
Вот некоторые сообщения в блоге, которые были упомянуты в комментариях, которые релевантны.
При вызове веб-сервисов ASP.NET от клиентского, необходимо использовать application/json
, чтобы это работало. Я полагаю, что это - то же для jQuery и Расширение платформы.
Конечно, правильный тип мультимедиа MIME для JSON - application / json
, но необходимо понимать, какой тип данных ожидается в вашем приложении.
Например, я использую Ext GWT , и ответ сервера должен иметь вид text / html но содержит данные JSON.
Клиентская сторона, прослушиватель формы Ext GWT
uploadForm.getForm().addListener(new FormListenerAdapter()
{
@Override
public void onActionFailed(Form form, int httpStatus, String responseText)
{
MessageBox.alert("Error");
}
@Override
public void onActionComplete(Form form, int httpStatus, String responseText)
{
MessageBox.alert("Success");
}
});
В случае использования типа ответа application / json браузер предлагает мне сохранить файл.
Исходный код на стороне сервера фрагмент с использованием Spring MVC
return new AbstractUrlBasedView()
{
@SuppressWarnings("unchecked")
@Override
protected void renderMergedOutputModel(Map model, HttpServletRequest request,
HttpServletResponse response) throws Exception
{
response.setContentType("text/html");
response.getWriter().write(json);
}
};
VALUES
для SQL Server 2005 (это поддерживается с 2008), – Damien_The_Unbeliever 15 June 2011 в 19:09