我将JSON.stringify创建的字符串作为参数传递给另一个通过JSON.parse来破坏它的函数,但是解析函数生成错误。
字符串化的JSON是由Xero API(会计软件包)通过Service_JSON(PHP pear包)创建的JSON对象的一部分 - 它验证正常。
JSON.parse似乎在任何'字符。
问题1:stringify不会转义特殊字符,如新行和单引号吗?
问题2:我不希望在JSON.parse中解析没有错误的JSON.stringifyed字符串而不会出错,因为它们是彼此的赞美/反对函数吗?
编辑:
重复编码如下:
function PANDA_INVOICING_JS_save_invoice_add(theWindowID,loadPopupFrom) {
var theForm = $('#'+theWindowID+'_form');
var theFrameID = Date.parse(new Date());
$.ajax({
url: '?module=invoicing&action=save_invoices_add&window_uid='+theWindowID,
method: 'post',
data: theForm.serialize(),
}).done(function(result) {
var theJSON = result;
if (loadPopupFrom) {
var theURL = '?module=invoicing&action=display_invoices_details&invoice_id='+theInvoiceID+'&loadfrom='+loadPopupFrom+'&window_uid='+theFrameID;
} else {
var theURL = '?module=invoicing&action=display_invoices_details&invoice_id='+theInvoiceID;
}
/**
* XERO Allocate Credit
*/
var loadfunctions = false;
if (APP_JS_check_nestedobjects(theJSON,'data','xero_data','response')) {
if ($.isNumeric(theJSON.data.xero_data.credits.availablecredit) && theJSON.data.xero_data.credits.availablecredit > 0) {
var theXEROdata = JSON.stringify(theJSON.data.xero_data);
var loadfunctions = [
{
functionname: 'PANDA_PLUGIN_JS_xero_credit_notify',
'arguments': '####__WINDOWID__####,\''+theXEROdata+'\',\''+theURL+'\''
}
];
}
}
/* Load the new invoice */
APP_JS_frame((loadPopupFrom) ? true : false, theURL,loadfunctions);
}
});
/**
* Return true
*/
return true;
}
在APP_JS_frame中传递给这段代码(是的:eval是邪恶的,但在这种情况下是必需的,没有用户数据是eval' d):
if (typeof(loadfunctions)=='object') {
for (i=0;i<loadfunctions.length;i++) {
if (! loadfunctions[i].functionname) continue; //if functionname is not defined move on
if (loadfunctions[i].arguments) {
arguments = $PHP_JS.str_replace('####__WINDOWID__####',theFrameID,loadfunctions[i].arguments)
} else {
arguments = '';
}
eval(loadfunctions[i].functionname + '('+arguments+')');
}
}
然后通过这个实际抛出错误的函数:
function PANDA_PLUGIN_JS_xero_credit_notify(theFrameID, theXerodata, theURL) {
/* Parse JSON and set variables */
theXerodata = theXerodata.escapeJSON();
theXerodata = JSON.parse(theXerodata);
}
escapeJSON()如下:
String.prototype.escapeJSON = function() {
return this.replace(/[\\]/g, '\\\\')
.replace(/[\b]/g, '\\b')
.replace(/[\f]/g, '\\f')
.replace(/[\n]/g, '\\n')
.replace(/[\r]/g, '\\r')
.replace(/[\t]/g, '\\t')
.replace(/[']/g, "\\'");
};
至于实际的xeroData字符串 - 它应该是什么 - 因为JSON.stringify应该为JSON.parse生成有效的JSON使用 - 对吗?但是为了数据,这里是JSON:
{
"xero_data": {
"invoices": {
"invoice_id": "4323",
"invoice_balance": "123.00",
"date_invoice": "2016-11-20",
"contact_id": "2558",
"contact_name": "Person, Test"
},
"response": {
"return_code": 200,
"xero_response": {
"Id": "dedb737c-ce42-433f-aa2b-02478b839bbf",
"Status": "OK",
"ProviderName": "PANDA-Developer",
"DateTimeUTC": "2016-11-19T23:28:28.6858694Z",
"Invoices": {
"Invoice": {
"Contact": {
"ContactID": "b1e95873-81b2-44f6-b46a-3d4df44ef602",
"ContactStatus": "ACTIVE",
"Name": "Test Person",
"FirstName": "Test",
"LastName": "Person",
"EmailAddress": "emailaddress",
"Addresses": {
"Address": [{
"AddressType": "STREET"
}, {
"AddressType": "POBOX",
"AddressLine1": "P.O. Box",
"City": "Town",
"Region": "Otago",
"PostalCode": "1201",
"Country": "New Zealand"
}]
},
"Phones": {
"Phone": [{
"PhoneType": "DEFAULT"
}, {
"PhoneType": "DDI"
}, {
"PhoneType": "FAX"
}, {
"PhoneType": "MOBILE"
}]
},
"UpdatedDateUTC": "2016-11-19T02:49:47.58",
"IsSupplier": "false",
"IsCustomer": "true"
},
"Date": "2016-11-20T00:00:00",
"DueDate": "2016-11-30T00:00:00",
"ExpectedPaymentDate": "2016-11-30T00:00:00",
"Status": "AUTHORISED",
"LineAmountTypes": "Inclusive",
"LineItems": {
"LineItem": {
"Description": "Test Data '\n \n - new line\n - new line",
"UnitAmount": "123.00",
"TaxType": "OUTPUT2",
"TaxAmount": "16.04",
"LineAmount": "123.00",
"AccountCode": "260",
"Quantity": "1.0000",
"DiscountRate": "0.00",
"LineItemID": "a4c2da16-4d94-42d6-ae37-e3091901b79b"
}
},
"SubTotal": "106.96",
"TotalTax": "16.04",
"Total": "123.00",
"UpdatedDateUTC": "2016-11-19T23:28:28.607",
"CurrencyCode": "NZD",
"Type": "ACCREC",
"InvoiceID": "cdb5b8e9-afac-4f72-b74b-d9b292295c34",
"InvoiceNumber": "PANDA4323",
"Reference": "test 34",
"AmountDue": "123.00",
"AmountPaid": "0.00",
"SentToContact": "false",
"CurrencyRate": "1.000000",
"TotalDiscount": "0.00"
}
}
}
},
"credits": {
"0": {
"Type": "creditnote",
"UUID": "345d423e-58a6-4e05-8ae5-33da4e886bb9",
"CreditNoteNumber": "CN-0041",
"RemainingCredit": 182.65
},
"availablecredit": 182.65
}
}
}