Eu acho que o que muita gente quer fazer é analisar as seqüências de datas JSON. Existe uma boa chance de você vir para esta página converter uma data JSON JavaScript em uma data Java.
Para mostrar a aparência de uma sequência de datas JSON:
var d=new Date();
var s = JSON.stringify(d);
document.write(s);
document.write("<br />"+d);
"2013-12-14T01:55:33.412Z"
Fri Dec 13 2013 17:55:33 GMT-0800 (PST)
A sequência de datas JSON é 2013-12-14T01: 55: 33.412Z.
As datas não são cobertas pelas especificações JSON, por exemplo, mas o acima é um formato ISO 8601 muito específico, enquanto o ISO_8601 é muito maior e esse é um mero subconjunto, embora muito importante.
Consulte http://www.json.org
Consulte http://en.wikipedia.org/wiki/ISO_8601
Consulte http://www.w3.org/TR/NOTE-datetime
Por acaso, escrevi um analisador JSON e um analisador PLIST, que usam ISO-8601, mas não os mesmos bits.
/*
var d=new Date();
var s = JSON.stringify(d);
document.write(s);
document.write("<br />"+d);
"2013-12-14T01:55:33.412Z"
Fri Dec 13 2013 17:55:33 GMT-0800 (PST)
*/
@Test
public void jsonJavaScriptDate() {
String test = "2013-12-14T01:55:33.412Z";
Date date = Dates.fromJsonDate ( test );
Date date2 = Dates.fromJsonDate_ ( test );
assertEquals(date2.toString (), "" + date);
puts (date);
}
Eu escrevi duas maneiras de fazer isso no meu projeto. Um padrão, um rápido.
Novamente, a sequência de datas JSON é uma implementação muito específica da ISO 8601 ....
(Postei a outra na outra resposta, que deve funcionar para datas PLIST, que são um formato ISO 8601 diferente).
A data JSON é a seguinte:
public static Date fromJsonDate_( String string ) {
try {
return new SimpleDateFormat ( "yyyy-MM-dd'T'HH:mm:ss.SSSXXX").parse ( string );
} catch ( ParseException e ) {
return Exceptions.handle (Date.class, "Not a valid JSON date", e);
}
}
Os arquivos PLIST (ASCII não GNUNext) também usam a ISO 8601, mas não milissegundos, portanto ... nem todas as datas da ISO-8601 são iguais. (Pelo menos ainda não encontrei um que use milis e o analisador que vi pular o fuso horário OMG).
Agora, a versão rápida (você pode encontrá-la no Boon).
public static Date fromJsonDate( String string ) {
return fromJsonDate ( Reflection.toCharArray ( string ), 0, string.length () );
}
Observe que Reflection.toCharArray usa inseguro, se disponível, mas o padrão é string.toCharArray, se não estiver.
(Você pode tirá-lo do exemplo substituindo Reflection.toCharArray (string) por string.toCharArray ()).
public static Date fromJsonDate( char[] charArray, int from, int to ) {
if (isJsonDate ( charArray, from, to )) {
int year = CharScanner.parseIntFromTo ( charArray, from + 0, from + 4 );
int month = CharScanner.parseIntFromTo ( charArray, from +5, from +7 );
int day = CharScanner.parseIntFromTo ( charArray, from +8, from +10 );
int hour = CharScanner.parseIntFromTo ( charArray, from +11, from +13 );
int minute = CharScanner.parseIntFromTo ( charArray, from +14, from +16 );
int second = CharScanner.parseIntFromTo ( charArray, from +17, from +19 );
int miliseconds = CharScanner.parseIntFromTo ( charArray, from +20, from +23 );
TimeZone tz = TimeZone.getTimeZone ( "GMT" );
return toDate ( tz, year, month, day, hour, minute, second, miliseconds );
} else {
return null;
}
}
O isJsonDate é implementado da seguinte maneira:
public static boolean isJsonDate( char[] charArray, int start, int to ) {
boolean valid = true;
final int length = to -start;
if (length != JSON_TIME_LENGTH) {
return false;
}
valid &= (charArray [ start + 19 ] == '.');
if (!valid) {
return false;
}
valid &= (charArray[ start +4 ] == '-') &&
(charArray[ start +7 ] == '-') &&
(charArray[ start +10 ] == 'T') &&
(charArray[ start +13 ] == ':') &&
(charArray[ start +16 ] == ':');
return valid;
}
Enfim ... meu palpite é que muitas pessoas que vêm aqui .. podem estar procurando a JSON Date String e, embora seja uma data ISO-8601, é uma data muito específica que precisa de uma análise muito específica.
public static int parseIntFromTo ( char[] digitChars, int offset, int to ) {
int num = digitChars[ offset ] - '0';
if ( ++offset < to ) {
num = ( num * 10 ) + ( digitChars[ offset ] - '0' );
if ( ++offset < to ) {
num = ( num * 10 ) + ( digitChars[ offset ] - '0' );
if ( ++offset < to ) {
num = ( num * 10 ) + ( digitChars[ offset ] - '0' );
if ( ++offset < to ) {
num = ( num * 10 ) + ( digitChars[ offset ] - '0' );
if ( ++offset < to ) {
num = ( num * 10 ) + ( digitChars[ offset ] - '0' );
if ( ++offset < to ) {
num = ( num * 10 ) + ( digitChars[ offset ] - '0' );
if ( ++offset < to ) {
num = ( num * 10 ) + ( digitChars[ offset ] - '0' );
if ( ++offset < to ) {
num = ( num * 10 ) + ( digitChars[ offset ] - '0' );
}
}
}
}
}
}
}
}
return num;
}
Consulte https://github.com/RichardHightower/boon O
Boon possui um analisador PLIST (ASCII) e um analisador JSON.
O analisador JSON é o analisador Java JSON mais rápido que eu conheço.
Independentemente verificado pelos caras Gatling Performance.
https://github.com/gatling/json-parsers-benchmark
Benchmark Mode Thr Count Sec Mean Mean error Units
BoonCharArrayBenchmark.roundRobin thrpt 16 10 1 724815,875 54339,825 ops/s
JacksonObjectBenchmark.roundRobin thrpt 16 10 1 580014,875 145097,700 ops/s
JsonSmartBytesBenchmark.roundRobin thrpt 16 10 1 575548,435 64202,618 ops/s
JsonSmartStringBenchmark.roundRobin thrpt 16 10 1 541212,220 45144,815 ops/s
GSONStringBenchmark.roundRobin thrpt 16 10 1 522947,175 65572,427 ops/s
BoonDirectBytesBenchmark.roundRobin thrpt 16 10 1 521528,912 41366,197 ops/s
JacksonASTBenchmark.roundRobin thrpt 16 10 1 512564,205 300704,545 ops/s
GSONReaderBenchmark.roundRobin thrpt 16 10 1 446322,220 41327,496 ops/s
JsonSmartStreamBenchmark.roundRobin thrpt 16 10 1 276399,298 130055,340 ops/s
JsonSmartReaderBenchmark.roundRobin thrpt 16 10 1 86789,825 17690,031 ops/s
Possui o analisador JSON mais rápido para fluxos, leitores, bytes [], char [], CharSequence (StringBuilder, CharacterBuffer) e String.
Veja mais benchmarks em:
https://github.com/RichardHightower/json-parsers-benchmark