it-roy-ru.com

AJAX: проверить, является ли строка JSON?

Мой JavaScript иногда падает на этой строке:

var json = eval('(' + this.responseText + ')');

Сбои возникают, когда аргумент eval() не является JSON. Есть ли способ проверить, является ли строка JSON, прежде чем делать этот вызов?

Я не хочу использовать фреймворк - есть ли способ заставить эту работу использовать только eval()? (Есть веская причина, я обещаю.)

77
Nick Heiner

Если вы включите JSON parser из json.org, вы можете использовать его функцию parse () и просто обернуть его в try/catch, например так:

try
{
   var json = JSON.parse(this.responseText);
}
catch(e)
{
   alert('invalid json');
}

Что-то подобное, вероятно, будет делать то, что вы хотите.

147
inkedmn

Ее альтернатива jQuery ...

try
{
  var jsonObject = jQuery.parseJSON(yourJsonString);
}
catch(e)
{
  // handle error 
}
21
RayLoveless

Я настоятельно рекомендую вам использовать javascript JSON library для сериализации в и из JSON. eval() - это угроза безопасности, которую никогда не следует использовать, если вы абсолютно не уверены, что ее вход очищен и безопасен.

Имея библиотеку JSON, просто оберните вызов к его эквиваленту parse() в блок try/catch для обработки ввода не-JSON:

try
{
  var jsonObject = JSON.parse(yourJsonString);
}
catch(e)
{
  // handle error 
}
14
Håvard S

Promise вместо Try-catch:

npm install is-json-promise ; //for NodeJS environment.

ИЛИ ЖЕ 

String.IsJSON = (candidate) => 
   new Promise(
     (resolve, reject) => resolve(JSON.parse(candidate))
    ) 
;

Случаи применения :

String.IsJSON(`iam here`)
   .then((object) => console.info(object))
   .catch((error) => alert('Waww, i cannot be JSON')) ; // promise will run catch

или же 

String.IsJSON(`{"welcome":"Hello"}`)
   .then((object) => console.info(object)) // promise will run "then"
   .catch((error) => alert('Waww, i cannot be JSON')) ; 
7
Abdennour TOUMI

Может быть, это поможет: С помощью этого кода вы можете получить непосредственно ваши данные ...

<!DOCTYPE html>
<html>
<body>

<h3>Open console, please, to view result!</h3>
<p id="demo"></p>

<script>
var tryJSON = function (test) {
	try {
	    JSON.parse(test);
	}
	catch(err) {
    	// maybe you need to escape this… (or not)
	    test = '"'+test.replace(/\\?"/g,'\\"')+'"';
	}
	eval('test = '+test);
	console.debug('Try json:', test);
};

// test with string…
var test = 'bonjour "mister"';
tryJSON(test);
// test with JSON…
var test = '{"fr-FR": "<p>Ceci est un texte en français !</p>","en-GB": "<p>And here, a text in english!</p>","nl-NL": "","es-ES": ""}';
tryJSON(test);
</script>

</body>
</html>

0
Dujardin Emmanuel

Ниже приведена функция, вы можете попробовать:

String.prototype.isJson = function () {
  try {
      JSON.parse(this.toString());
      return true;
  } catch (ex) {
      return false;
  }
};
0
Musa Kurt

Проблема зависимости от подхода try-catch заключается в том, что JSON.parse('123') = 123 не вызовет исключения. Поэтому, в дополнение к try-catch, нам нужно проверить тип следующим образом:

function isJsonStr(str) {
    var parsedStr = str;
    try {
        parsedStr = JSON.parse(str);
    } catch (e) {
        return false;
    }
    return typeof parsedStr == 'object'
}
0
Hesham Yassin

Существует небольшая библиотека, которая проверяет типы JavaScript: is.js

is.json({foo: 'bar'});
=> true

// functions are returning as false
is.json(toString);
=> false

is.not.json([]);
=> true

is.all.json({}, 1);
=> false

is.any.json({}, 2);
=> true

// 'all' and 'any' interfaces can also take array parameter
is.all.json([{}, {foo: 'bar'}]);
=> true

На самом деле is.js - это гораздо больше, чем некоторые, достойные упоминания:

var obj = document.createElement('div');
is.domNode(obj);
=> true

is.error(new Error());
=> true

is.function(toString);
=> true

is.chrome();
=> true if current browser is chrome


0
Ramazan Polat