XENON is based on JSON variant_json
But in the process of using JSON, I encountered a problem - this problem must have been encountered by everyone, that is: JSON does not define the transmission method of date and time.
Although json2.js has added support for Date functions and ISO-8601 date/time formats in an update in March this year, the support for dates in various commonly used development tools is still varied and strange. , there is no unity at all.
Moreover, in addition to date/time, sometimes we also need support for some classes or functions, which are not supported by JSON.
Some people may ask after seeing this: Since JSON is not supported, why not use other data description/transmission methods?
The reason is that JSON itself is a functional subset of JavaScript (its reference standard is ECMAScript), and anyone with a little knowledge of JavaScript can easily utilize JSON.
The easiest way to parse JSON is to directly use the eval function to execute it as JavaScript code. JSON is often used to pass between different applications on the Internet, so directly pass in the received JSON content. The eval function is very risky, so the format of JSON is strictly specified in the RFC document, and methods for testing its security are given.
This check method prohibits the function from running.
In short, because JSON is "occasionally" inconvenient to use, I started to use my brain to extend JSON.
After referring to RFC-4627, json2.js and some common JavaScript syntax shaders, I found that: although json2.js already has support for date/time, it uses grammatical analysis model, which means that if you don’t have a certain understanding of grammatical analysis, it is difficult to expand it; even if I have a little knowledge of grammatical analysis, it is not easy to expand it. , let alone future maintenance.
So I decided to use the simpler regular expression filtering method recommended in RFC-4627.
The basic implementation of this extension is as follows:
function Xenon(){}
var protoXenon = Xenon.prototype;
protoXenon.xeval = function(s){
var al = [], vl = [], ol = {};
function $(i, v){
// i = parseInt(i);
// return ol[i] || (ol[i] = v);
return ol. propertyIsEnumerable(i) ? ol[i] : (ol[i] = v);
}
for(var n in this)
if(this.propertyIsEnumerable(n) && typeof this[n] == 'function')
al.push(n), vl.push(this[n]);
return eval('0,function(' al '){return ' s ';}') .apply(this, vl);
};
protoXenon.safeXeval = function(s){
var T = this;
return (!/[^),:{}[]0 -9.- Eaeflnr-u nrt]/.test(
s.replace(/"(\.|[^"\])*"/g, '')
.replace(/([^ s:[,(] ?)(/g,function($0, $1){
// return T.propertyIsEnumerable($1) ? '' : $1 '(';
return T.propertyIsEnumerable($1) ? '' : '@';
})) || null) &&
this.xeval(s);
};
The basic usage is to create a xenon object , set a new member for it to enable the extension function.
You can add the extension function directly to the xenon object, or you can declare the function in the global scope and set the non-function type member value on the xenon object. >Example:
xenon.Array = 0;
xenon.$ = 0;
xenon.date = function(s){return new Date(s);};
var o = xenon.safeXeval('{ "list":Array(3,6,9),"created":$(1,date("Tue Jul 27 02:48:03 UTC 0800 2010")),"modified":$(1)}') ;
print(o.list);
print(o.created);
print(o.modified == o.created);
Note: This example cannot be executed directly as JScript.NET code. If you want to use it in JScript.NET, you must pass the string "unsafe" as the second parameter to the eval function.
Note 2: Adding "0," before the function keyword is for compatibility with the JScript engine used by IE - the current non-CLI version of the JScript engine cannot correctly understand the surrounding function definition in its eval implementation. The meaning of the parentheses will cause a syntax error.
Three function extensions are used in this example: Array is a JavaScript built-in function in the global scope; $ is a built-in function I implemented in XENON, which can reference the same object in multiple places; and date is a pair A wrapper for the Date constructor.
In the implementation of XENON, I did not allow it to support the new operator to create new objects. I did not find any reason to use new instead of directly using the extension function.
About the name: I originally planned to call it xJson, but then I thought it was a bit inferior, so I changed it to XEON (eXtensible ECMAScript Object Notation). Then I found that it seemed to be a registered trademark of Intel, so I added an extra N in the middle and it became XENON (eXtensible Native ECMAScript Object Notation). I looked it up in the dictionary and found that it was the name of a chemical element... so I just used it.
About security: In the process of designing the verification method, I tested as many character combinations as I could to avoid injection problems. But due to the lack of practical testing, and I am not good at things like grammatical analysis, it may not be absolutely safe. If anyone finds any security holes, please let me know so I can improve it.
When I have time in the future, I will make a simple function to convert ECMAScript objects to XENON; if I really have enough time, maybe I will also implement the conversion process including class names and constructors.

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

The combination of golangWebSocket and JSON: realizing data transmission and parsing In modern Web development, real-time data transmission is becoming more and more important. WebSocket is a protocol used to achieve two-way communication. Unlike the traditional HTTP request-response model, WebSocket allows the server to actively push data to the client. JSON (JavaScriptObjectNotation) is a lightweight format for data exchange that is concise and easy to read.

The Gson@Expose annotation can be used to mark whether a field is exposed (contained or not) for serialization or deserialization. The @Expose annotation can take two parameters, each parameter is a boolean value and can take the value true or false. In order for GSON to react to the @Expose annotation, we have to create a Gson instance using the GsonBuilder class and need to call the excludeFieldsWithoutExposeAnnotation() method, which configures Gson to exclude all fields without Expose annotation from serialization or deserialization. Syntax publicGsonBuilderexclud

MySQL5.7 and MySQL8.0 are two different MySQL database versions. There are some main differences between them: Performance improvements: MySQL8.0 has some performance improvements compared to MySQL5.7. These include better query optimizers, more efficient query execution plan generation, better indexing algorithms and parallel queries, etc. These improvements can improve query performance and overall system performance. JSON support: MySQL 8.0 introduces native support for JSON data type, including storage, query and indexing of JSON data. This makes processing and manipulating JSON data in MySQL more convenient and efficient. Transaction features: MySQL8.0 introduces some new transaction features, such as atomic

Performance optimization methods for converting PHP arrays to JSON include: using JSON extensions and the json_encode() function; adding the JSON_UNESCAPED_UNICODE option to avoid character escaping; using buffers to improve loop encoding performance; caching JSON encoding results; and considering using a third-party JSON encoding library.

Quick Start: Pandas method of reading JSON files, specific code examples are required Introduction: In the field of data analysis and data science, Pandas is one of the important Python libraries. It provides rich functions and flexible data structures, and can easily process and analyze various data. In practical applications, we often encounter situations where we need to read JSON files. This article will introduce how to use Pandas to read JSON files, and attach specific code examples. 1. Installation of Pandas

Annotations in the Jackson library control JSON serialization and deserialization: Serialization: @JsonIgnore: Ignore the property @JsonProperty: Specify the name @JsonGetter: Use the get method @JsonSetter: Use the set method Deserialization: @JsonIgnoreProperties: Ignore the property @ JsonProperty: Specify name @JsonCreator: Use constructor @JsonDeserialize: Custom logic

Use the json.MarshalIndent function in golang to convert the structure into a formatted JSON string. When writing programs in Golang, we often need to convert the structure into a JSON string. In this process, the json.MarshalIndent function can help us. Implement formatted output. Below we will explain in detail how to use this function and provide specific code examples. First, let's create a structure containing some data. The following is an indication

How to handle XML and JSON data formats in C# development requires specific code examples. In modern software development, XML and JSON are two widely used data formats. XML (Extensible Markup Language) is a markup language used to store and transmit data, while JSON (JavaScript Object Notation) is a lightweight data exchange format. In C# development, we often need to process and operate XML and JSON data. This article will focus on how to use C# to process these two data formats, and attach
