Im integrating Lightspeed API to my website like POS system. I currently getting the value file_get_contents(), but when Im trying to load it array I gives my the error 4 of json_last_error().
Here is my codes:
$maps_url = "http://cloud-docs.merchantos.com/API/Account/797/Item/?itemID=1";
$maps_json = file_get_contents($maps_url);
//print_r($maps_json);
$maps_array = json_decode(stripslashes($maps_json), true);
echo $data = $maps_array['Item']['systemSku'];
switch (json_last_error()) {
case JSON_ERROR_NONE:
echo ' - No errors';
break;
case JSON_ERROR_DEPTH:
echo ' - Maximum stack depth exceeded';
break;
case JSON_ERROR_STATE_MISMATCH:
echo ' - Underflow or the modes mismatch';
break;
case JSON_ERROR_CTRL_CHAR:
echo ' - Unexpected control character found';
break;
case JSON_ERROR_SYNTAX:
echo ' - Syntax error, malformed JSON';
break;
case JSON_ERROR_UTF8:
echo ' - Malformed UTF-8 characters, possibly incorrectly encoded';
break;
default:
echo ' - Unknown error';
break;
}
json_last_error();
Let me rephrase it then:
The shown URL does not retrieve JSON.
It pulls XML.
Therefore json_decode fails.
Hence there's no usable data in $maps_url.
Which is also why ['Item']['systemSku'] won't work.
(And stripslashes would have made no sense in there anyway).
So, investigate the API you're using. Figure out if there is a JSON variant available. Else throw away your code, and instead use a XML traversal frontend, such as SimpleXML.
As mario has said, $maps_url receives XML.
Check out xml_parse_into_struct for help with XML to array conversion.
Related
I am trying to use PHP's json_decode function to get data from the database (phpmyadmin)(the type is set to text) and set it on the page This is the code that i got:
$belangrijkespecs = $productClass->get('belangrijkeSpecs');
$belangrijkespecs = json_decode($belangrijkespecs);
var_dump($belangrijkespecs);
This code outputs
NULL
And when I echo the $productClass->get('belangrijkeSpecs') it outputs:
{"Beeldschermdiagonaal":"10,1 inch (25,7 cm)","Beeldresolutie":"1920 x 1200","Batterijduur":"Tot 12 uur","Gewicht":"525 g","Opslag":"32 GB"}
When I passed this in an online JSON decode website than I get the right array (from the website https://3v4l.org/IHKZZ):
array (
'Beeldschermdiagonaal' => '10,1 inch (25,7 cm)',
'Beeldresolutie' => '1920 x 1200',
'Batterijduur' => 'Tot 12 uur',
'Gewicht' => '525 g',
'Opslag' => '32 GB',
)
When i try json_last_error() with this code:
switch (json_last_error()) {
case JSON_ERROR_NONE:
echo ' - No errors';
break;
case JSON_ERROR_DEPTH:
echo ' - Maximum stack depth exceeded';
break;
case JSON_ERROR_STATE_MISMATCH:
echo ' - Underflow or the modes mismatch';
break;
case JSON_ERROR_CTRL_CHAR:
echo ' - Unexpected control character found';
break;
case JSON_ERROR_SYNTAX:
echo ' - Syntax error, malformed JSON';
break;
case JSON_ERROR_UTF8:
echo ' - Malformed UTF-8 characters, possibly incorrectly encoded';
break;
default:
echo ' - Unknown error';
break;
}
It outputs
- Syntax error, malformed JSON
And if i just use echo json_last_error() it outputs : 4.
i have already tried :
$belangrijkespecs = str_replace("/", "", $belangrijkespecs);
and
$belangrijkespecs = rtrim($belangrijkespecs, "\0");
and
$belangrijkespecs = stripslashes($belangrijkespecs);
the output of var_dump $productClass->get('belangrijkeSpecs') :
string(240) "{"Beeldschermdiagonaal":"10,1 inch (25,7 cm)","Beeldresolutie":"1920 x 1200","Batterijduur":"Tot 12 uur","Gewicht":"525 g","Opslag":"32 GB"
The output of echo addcslashes($belangrijkespecs, '\0..\37!#\177..\377') is:
{"\;\Beeldschermdiagonaal"\;\:"\;\1\0,\1 inch (\2\5,\7 cm)"\;,"\;\Beeldresolutie"\;\:"\;\1\9\2\0 x \1\2\0\0"\;,"\;\Batterijduur"\;\:"\;\Tot \1\2 uur"\;,"\;\Gewicht"\;\:"\;\5\2\5 g"\;,"\;\Opslag"\;\:"\;\3\2 \G\B"\;}
And when i do
$belangrijkespecs = stripslashes($belangrijkespecs); before json_decode it still dosnt work...
Also tried:
$belangrijkespecs = preg_replace('/\\\\/', '', $belangrijkespecs);
But it did not work.
The structure of this 'belangrijkeSpecs' = http://prntscr.com/lvnsbh
I have looked on the internet but the answers that were given did not help me.
So my question is:
How can i get a array from the json encoded string
( $productClass->get('belangrijkeSpecs') )
and I expect an array as a return from the json_decode();
The awnser was that i escaped the string before i did the json_decode. And because i did that there where a lot of backslashes.
Thanks to #Matthijs i found it
Welp, I see quite a few hits on this, but none seem to answer my question.
I have a REST method that returns this JSON:
This is the exact string in the $result variable, below:
{"people":{"people":{"new_user":{"id":7,"name":"Marvin","lang":"en","read_token":1,"write_token":11,"last_access":"2018-06-17 17:00:02","writeable":true,"surname":"Martian","middle_name":"D","given_name":"Marvin","nickname":"Angry Little Fella","payload":"<?xml version="1.0" encoding="utf-8"?>
<!-- Generator: Adobe Illustrator 22.1.0, SVG Export Plug-In . SVG Version: 6.00 Build 0)  -->
<svg version="1.1"
	 id="svg27333" xmlns:cc="http://creativecommons.org/ns#" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:svg="http://www.w3.org/2000/svg"
	 xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 156.8 219.3"
	 style="enable-background:new 0 0 156.8 219.3;" xml:space="preserve">
<style type="text/css">
	.st0{fill:#FFE86E;}
	.st1{fill:none;stroke:#231F20;stroke-width:1.25;}
	.st2{fill:#E8AE10;}
	.st3{fill:#59AD40;}
	.st4{fill:#231F20;}
	.st5{fill:#FFFFFF;}
</style>
<g id="layer1" transform="translate(340.20937,-112.70377)">
	<g id="g27114" transform="matrix(2.6484014,0,0,2.6484014,1262.4331,-1306.9513)">
		<path id="path10040" class="st0" d="M-564.7,551.4c0.1,0,2.2-7.3,3.3-9c0,0-1.3-0.7-2.3-1c0,0,0.3-0.7,0.4-1c0,0-1.1-0.7-2.8-1
			c0,0,0.2-0.9,0.3-1.1c0,0-4.2-1.6-8.3-1c0,0,0-0.5,0-0.7c0,0-5.5-1.1-9.5,1.3c0,0,0.1,0.7,0.1,0.9c0,0-1.3,0.2-2.3,0.6
			c0,0-0.1-0.3-0.2-0.6c0,0-3.8,1.6-5,4.6c0,0,2,3.9,3,8C-588,551.6-569,552-564.7,551.4"/>
		<path id="path10044" class="st1" d="M-564.7,551.4c0.1,0,2.2-7.3,3.3-9c0,0-1.3-0.7-2.3-1c0,0,0.3-0.7,0.4-1c0,0-1.1-0.7-2.8-1
			c0,0,0.2-0.9,0.3-1.1c0,0-4.2-1.6-8.3-1c0,0,0-0.5,0-0.7c0,0-5.5-1.1-9.5,1.3c0,0,0.1,0.7,0.1,0.9c0,0-1.3,0.2-2.3,0.6
			c0,0-0.1-0.3-0.2-0.6c0,0-3.8,1.6-5,4.6c0,0,2,3.9,3,8C-588,551.6-569,552-564.7,551.4L-564.7,551.4z"/>
		<path id="path10048" class="st2" d="M-566.4,561.6c0,0,2.6-5.1,3-6.3c0,0,0.6-0.9,0.4-3c0,0,0-1-2.7-1.9c0,0-11.4-3.8-22.5,0.2
			c0,0-0.7,0.2-1.2,1.4c0,0-0.4,0.9-0.7,2c0,0-0.1,0.7,0.3,1.6c0,0,2.2,4.3,4,6.6C-585.7,562.1-569.6,563.5-566.4,561.6"/>
		<path id="path10052" class="st1" d="M-566.4,561.6c0,0,2.6-5.1,3-6.3c0,0,0.6-0.9,0.4-3c0,0,0-1-2.7-1.9c0,0-11.4-3.8-22.5,0.2
			c0,0-0.7,0.2-1.2,1.4c0,0-0.4,0.9-0.7,2c0,0-0.1,0.7,0.3,1.6c0,0,2.2,4.3,4,6.6C-585.7,562.1-569.6,563.5-566.4,561.6
			L-566.4,561.6z"/>
		<path id="path10056" class="st2" d="M-573.9,560.4c0,0,0-1.7,0-2.6c0,0,0.1-1.5-0.9-1.7c0,0-1.3-0.6-2.5,0.1c0,0-0.7,0.3-0.6,1.7
			c0,0,0,2.3,0,2.8C-577.8,560.6-574.8,561.5-573.9,560.4"/>
		<path id="path10060" class="st1" d="M-573.9,560.4c0,0,0-1.7,0-2.6c0,0,0.1-1.5-0.9-1.7c0,0-1.3-0.6-2.5,0.1c0,0-0.7,0.3-0.6,1.7
			c0,0,0,2.3,0,2.8C-577.8,560.6-574.8,561.5-573.9,560.4L-573.9,560.4z"/>
		<path id="path10064" class="st3" d="M-550.3,575.4c0,0-5.7-16.1-26.2-15.9c0,0-19-0.9-25.6,18.6
			C-602.1,578.2-574,569.2-550.3,575.4"/>
		<path id="path10068" class="st1" d="M-550.3,575.4c0,0-5.7-16.1-26.2-15.9c0,0-19-0.9-25.6,18.6
			C-602.1,578.2-574,569.2-550.3,575.4z"/>
		<path id="path10072" class="st3" d="M-552.6,599.5c0,0,5-0.6,5.6-3.1c0,0,0.4-0.5,0.1-1.8c0,0,0.8-6.6,0.2-13.2c0,0-0.4-2-2.3-4.5
			c0,0-8.7-13.7-28.6-13c0,0-17.8,0-26.1,16.2c0,0-0.9,1.3-0.9,3.8c0,0-0.2,4.4,1.3,11.2c0,0-0.7,2.5,3,3.8c0,0,1.1,0.3,1.9,0.4
			c0,0,1.2,0.2,2.1,0.3c0,0,1.2,6.6-5.9,10.2c0,0,3.7,6.6,5.5,8.8h2.5c0,0,5.7-5.2,11-7c0,0,15.9-3.8,20.5-1.2c0,0,4.5,5,5.8,7.7
			c0,0,1.4-0.1,2.4-0.1c0,0,5-6.4,6.8-8.6C-547.6,609.3-552.7,606.3-552.6,599.5"/>
		<path id="path10076" class="st1" d="M-552.6,599.5c0,0,5-0.6,5.6-3.1c0,0,0.4-0.5,0.1-1.8c0,0,0.8-6.6,0.2-13.2c0,0-0.4-2-2.3-4.5
			c0,0-8.7-13.7-28.6-13c0,0-17.8,0-26.1,16.2c0,0-0.9,1.3-0.9,3.8c0,0-0.2,4.4,1.3,11.2c0,0-0.7,2.5,3,3.8c0,0,1.1,0.3,1.9,0.4
			c0,0,1.2,0.2,2.1,0.3c0,0,1.2,6.6-5.9,10.2c0,0,3.7,6.6,5.5,8.8h2.5c0,0,5.7-5.2,11-7c0,0,15.9-3.8,20.5-1.2c0,0,4.5,5,5.8,7.7
			c0,0,1.4-0.1,2.4-0.1c0,0,5-6.4,6.8-8.6C-547.6,609.3-552.7,606.3-552.6,599.5z"/>
		<path id="path10080" class="st4" d="M-552.5,590.8c0,0,0.4,22.1-21.7,22.9c0,0-22.8,2-21.8-25.3c0,0,4.5-6.1,20.9-6.8
			C-575.2,581.7-561.2,581.1-552.5,590.8"/>
		<path id="path10084" class="st1" d="M-552.5,590.8c0,0,0.4,22.1-21.7,22.9c0,0-22.8,2-21.8-25.3c0,0,4.5-6.1,20.9-6.8
			C-575.2,581.7-561.2,581.1-552.5,590.8L-552.5,590.8z"/>
		<path id="path10088" class="st1" d="M-552.5,590.8c0,0,3.3,3.8,2.7,5.1c0,0-0.4,1.1-2.4,1.3"/>
		<path id="path10092" class="st1" d="M-596.1,588.5c0,0-2.2,2.1-3.5,4.7c0,0-1.1,2.1-0.2,3.2c0,0,0.6,1.1,3.2,1.2"/>
		<path id="path10096" class="st1" d="M-598.9,592.1c0,0,2.2,3,2.7,7.5"/>
		<path id="path10100" class="st1" d="M-594.3,601.3c0,0,0.3,4.8-5.1,8.4c0,0,3.9,6.7,5.2,8.9"/>
		<path id="path10104" class="st1" d="M-602.1,609.8c0,0,2.1-0.1,2.8-0.1"/>
		<path id="path10108" class="st1" d="M-603.2,595c0,0,1.1-6,8.5-10.9c0,0,7-5.6,19.6-5.5c0,0,17.2-0.8,27,13c0,0,1.2,1.5,1.3,3.1"
			/>
		<path id="path10112" class="st1" d="M-555.2,602.3c0,0,0.9,4.1,4.1,6.9c0,0-4.6,7.1-5.7,8.7"/>
		<path id="path10116" class="st1" d="M-547.6,609.3c0,0-2.3-0.2-3.4-0.2"/>
		<path id="path10120" class="st1" d="M-552.6,599.6c0,0,0.3-4.6,1.5-6.9"/>
		<path id="path10124" class="st1" d="M-563.4,555.3c0,0-1.6-3.1-13.4-3c0,0-9.9,0.3-13.3,2.5"/>
		<path id="path10128" class="st4" d="M-563.7,540.5c0,0-1.2,2.9-1.8,4.5c0,0,0.9-1.4,1.9-3.3C-563.6,541.7-563.6,540.5-563.7,540.5
			"/>
		<path id="path10132" class="st4" d="M-566.4,539.3c-0.3,1-0.8,2.4-1.3,4.8c0.4-0.7,0.6-1.2,1.7-4.4
			C-565.9,539.7-566.1,538.4-566.4,539.3"/>
		<path id="path10136" class="st4" d="M-574.4,537c-0.1,1.1-0.1,3.9-0.1,5.3c0,0,0.4-1.3,0.6-4.9
			C-573.9,537.4-574.2,536.9-574.4,537"/>
		<path id="path10140" class="st4" d="M-583.3,538.1c0,0,0.4,3.8,0.5,4.8c0,0-0.5-1.1-1-3.8C-583.7,539.1-583.4,538-583.3,538.1"/>
		<path id="path10144" class="st4" d="M-586.2,539.3c0,0,1.4,4.1,2,5.4c0,0-0.4-1.9-1.4-5.3C-585.6,539.4-586.2,539.1-586.2,539.3"
			/>
		<path id="path10148" class="st5" d="M-587.4,583.7c0,0-1.1,5.6,0.1,12.2c0,0,1.7,10.8,6.9,10.5c0,0,4.5,0,4.5-12.8
			c0,0-0.1-7.7-2-11.7C-578,581.9-582.8,582-587.4,583.7"/>
		<path id="path10152" class="st1" d="M-587.4,583.7c0,0-1.1,5.6,0.1,12.2c0,0,1.7,10.8,6.9,10.5c0,0,4.5,0,4.5-12.8
			c0,0-0.1-7.7-2-11.7C-578,581.9-582.8,582-587.4,583.7L-587.4,583.7z"/>
		<path id="path10156" class="st5" d="M-571.8,581.9c0,0-1.8,4.1-1.6,12c0,0-0.1,11.3,4.4,11.8c0,0,5,0.9,6.4-10.6
			c0,0,1.1-6.9-0.1-11.3C-562.8,583.9-567.7,582-571.8,581.9"/>
		<path id="path10160" class="st1" d="M-571.8,581.9c0,0-1.8,4.1-1.6,12c0,0-0.1,11.3,4.4,11.8c0,0,5,0.9,6.4-10.6
			c0,0,1.1-6.9-0.1-11.3C-562.8,583.9-567.7,582-571.8,581.9z"/>
		<path id="path10324" class="st1" d="M-579,559.7c-1.4-2.8-0.8-6.4,3.6-6c4,0.4,3.4,3.3,3.1,6.1
			C-572.3,559.8-574.6,559.4-579,559.7z"/>
		<path id="path10360" class="st4" d="M-570.4,597.6c0.6,0,1.2-1.1,1.3-2.5c0.1-1.4-0.4-2.6-1-2.6c-0.6,0-1.2,1.1-1.3,2.5
			C-571.5,596.4-571.1,597.6-570.4,597.6"/>
		<path id="path10364" class="st1" d="M-570.4,597.6c0.6,0,1.2-1.1,1.3-2.5c0.1-1.4-0.4-2.6-1-2.6c-0.6,0-1.2,1.1-1.3,2.5
			C-571.5,596.4-571.1,597.6-570.4,597.6z"/>
		<path id="path10368" class="st4" d="M-578.7,597.7c0.6,0,1.2-1.1,1.3-2.5c0.1-1.4-0.4-2.6-1-2.6c-0.6,0-1.2,1.1-1.3,2.5
			C-579.8,596.5-579.3,597.6-578.7,597.7"/>
		<path id="path10372" class="st1" d="M-578.7,597.7c0.6,0,1.2-1.1,1.3-2.5c0.1-1.4-0.4-2.6-1-2.6c-0.6,0-1.2,1.1-1.3,2.5
			C-579.8,596.5-579.3,597.6-578.7,597.7z"/>
	</g>
</g>
</svg>
","payload_type":"image\/svg+xml;base64","associated_login":{"id":11,"name":"Marvin","lang":"en","login_id":"Marvin","write_token":11,"last_access":"2018-06-17 17:00:02","writeable":true,"user_object_id":7,"security_tokens":[11],"password":"6f2T8rK4"}}}}}
Yeah, it's big and fugly, but it is completely valid.
When I feed it to JSONLint, I get a nice green bar and well-formatted JSON:
{
"people": {
"people": {
"new_user": {
"id": 7,
"name": "Marvin",
"lang": "en",
"read_token": 1,
"write_token": 11,
"last_access": "2018-06-17 16:56:49",
"writeable": true,
"surname": "Martian",
"middle_name": "D",
"given_name": "Marvin",
"nickname": "Angry Little Fella",
"payload": "<?xml version="1.0" encoding="utf-8"?>
<!-- Generator: Adobe Illustrator 22.1.0, SVG Export Plug-In . SVG Version: 6.00 Build 0)  -->
<svg version="1.1"
	 id="svg27333" xmlns:cc="http://creativecommons.org/ns#" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:svg="http://www.w3.org/2000/svg"
	 xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 156.8 219.3"
	 style="enable-background:new 0 0 156.8 219.3;" xml:space="preserve">
<style type="text/css">
	.st0{fill:#FFE86E;}
	.st1{fill:none;stroke:#231F20;stroke-width:1.25;}
	.st2{fill:#E8AE10;}
	.st3{fill:#59AD40;}
	.st4{fill:#231F20;}
	.st5{fill:#FFFFFF;}
</style>
<g id="layer1" transform="translate(340.20937,-112.70377)">
	<g id="g27114" transform="matrix(2.6484014,0,0,2.6484014,1262.4331,-1306.9513)">
		<path id="path10040" class="st0" d="M-564.7,551.4c0.1,0,2.2-7.3,3.3-9c0,0-1.3-0.7-2.3-1c0,0,0.3-0.7,0.4-1c0,0-1.1-0.7-2.8-1
			c0,0,0.2-0.9,0.3-1.1c0,0-4.2-1.6-8.3-1c0,0,0-0.5,0-0.7c0,0-5.5-1.1-9.5,1.3c0,0,0.1,0.7,0.1,0.9c0,0-1.3,0.2-2.3,0.6
			c0,0-0.1-0.3-0.2-0.6c0,0-3.8,1.6-5,4.6c0,0,2,3.9,3,8C-588,551.6-569,552-564.7,551.4"/>
		<path id="path10044" class="st1" d="M-564.7,551.4c0.1,0,2.2-7.3,3.3-9c0,0-1.3-0.7-2.3-1c0,0,0.3-0.7,0.4-1c0,0-1.1-0.7-2.8-1
			c0,0,0.2-0.9,0.3-1.1c0,0-4.2-1.6-8.3-1c0,0,0-0.5,0-0.7c0,0-5.5-1.1-9.5,1.3c0,0,0.1,0.7,0.1,0.9c0,0-1.3,0.2-2.3,0.6
			c0,0-0.1-0.3-0.2-0.6c0,0-3.8,1.6-5,4.6c0,0,2,3.9,3,8C-588,551.6-569,552-564.7,551.4L-564.7,551.4z"/>
		<path id="path10048" class="st2" d="M-566.4,561.6c0,0,2.6-5.1,3-6.3c0,0,0.6-0.9,0.4-3c0,0,0-1-2.7-1.9c0,0-11.4-3.8-22.5,0.2
			c0,0-0.7,0.2-1.2,1.4c0,0-0.4,0.9-0.7,2c0,0-0.1,0.7,0.3,1.6c0,0,2.2,4.3,4,6.6C-585.7,562.1-569.6,563.5-566.4,561.6"/>
		<path id="path10052" class="st1" d="M-566.4,561.6c0,0,2.6-5.1,3-6.3c0,0,0.6-0.9,0.4-3c0,0,0-1-2.7-1.9c0,0-11.4-3.8-22.5,0.2
			c0,0-0.7,0.2-1.2,1.4c0,0-0.4,0.9-0.7,2c0,0-0.1,0.7,0.3,1.6c0,0,2.2,4.3,4,6.6C-585.7,562.1-569.6,563.5-566.4,561.6
			L-566.4,561.6z"/>
		<path id="path10056" class="st2" d="M-573.9,560.4c0,0,0-1.7,0-2.6c0,0,0.1-1.5-0.9-1.7c0,0-1.3-0.6-2.5,0.1c0,0-0.7,0.3-0.6,1.7
			c0,0,0,2.3,0,2.8C-577.8,560.6-574.8,561.5-573.9,560.4"/>
		<path id="path10060" class="st1" d="M-573.9,560.4c0,0,0-1.7,0-2.6c0,0,0.1-1.5-0.9-1.7c0,0-1.3-0.6-2.5,0.1c0,0-0.7,0.3-0.6,1.7
			c0,0,0,2.3,0,2.8C-577.8,560.6-574.8,561.5-573.9,560.4L-573.9,560.4z"/>
		<path id="path10064" class="st3" d="M-550.3,575.4c0,0-5.7-16.1-26.2-15.9c0,0-19-0.9-25.6,18.6
			C-602.1,578.2-574,569.2-550.3,575.4"/>
		<path id="path10068" class="st1" d="M-550.3,575.4c0,0-5.7-16.1-26.2-15.9c0,0-19-0.9-25.6,18.6
			C-602.1,578.2-574,569.2-550.3,575.4z"/>
		<path id="path10072" class="st3" d="M-552.6,599.5c0,0,5-0.6,5.6-3.1c0,0,0.4-0.5,0.1-1.8c0,0,0.8-6.6,0.2-13.2c0,0-0.4-2-2.3-4.5
			c0,0-8.7-13.7-28.6-13c0,0-17.8,0-26.1,16.2c0,0-0.9,1.3-0.9,3.8c0,0-0.2,4.4,1.3,11.2c0,0-0.7,2.5,3,3.8c0,0,1.1,0.3,1.9,0.4
			c0,0,1.2,0.2,2.1,0.3c0,0,1.2,6.6-5.9,10.2c0,0,3.7,6.6,5.5,8.8h2.5c0,0,5.7-5.2,11-7c0,0,15.9-3.8,20.5-1.2c0,0,4.5,5,5.8,7.7
			c0,0,1.4-0.1,2.4-0.1c0,0,5-6.4,6.8-8.6C-547.6,609.3-552.7,606.3-552.6,599.5"/>
		<path id="path10076" class="st1" d="M-552.6,599.5c0,0,5-0.6,5.6-3.1c0,0,0.4-0.5,0.1-1.8c0,0,0.8-6.6,0.2-13.2c0,0-0.4-2-2.3-4.5
			c0,0-8.7-13.7-28.6-13c0,0-17.8,0-26.1,16.2c0,0-0.9,1.3-0.9,3.8c0,0-0.2,4.4,1.3,11.2c0,0-0.7,2.5,3,3.8c0,0,1.1,0.3,1.9,0.4
			c0,0,1.2,0.2,2.1,0.3c0,0,1.2,6.6-5.9,10.2c0,0,3.7,6.6,5.5,8.8h2.5c0,0,5.7-5.2,11-7c0,0,15.9-3.8,20.5-1.2c0,0,4.5,5,5.8,7.7
			c0,0,1.4-0.1,2.4-0.1c0,0,5-6.4,6.8-8.6C-547.6,609.3-552.7,606.3-552.6,599.5z"/>
		<path id="path10080" class="st4" d="M-552.5,590.8c0,0,0.4,22.1-21.7,22.9c0,0-22.8,2-21.8-25.3c0,0,4.5-6.1,20.9-6.8
			C-575.2,581.7-561.2,581.1-552.5,590.8"/>
		<path id="path10084" class="st1" d="M-552.5,590.8c0,0,0.4,22.1-21.7,22.9c0,0-22.8,2-21.8-25.3c0,0,4.5-6.1,20.9-6.8
			C-575.2,581.7-561.2,581.1-552.5,590.8L-552.5,590.8z"/>
		<path id="path10088" class="st1" d="M-552.5,590.8c0,0,3.3,3.8,2.7,5.1c0,0-0.4,1.1-2.4,1.3"/>
		<path id="path10092" class="st1" d="M-596.1,588.5c0,0-2.2,2.1-3.5,4.7c0,0-1.1,2.1-0.2,3.2c0,0,0.6,1.1,3.2,1.2"/>
		<path id="path10096" class="st1" d="M-598.9,592.1c0,0,2.2,3,2.7,7.5"/>
		<path id="path10100" class="st1" d="M-594.3,601.3c0,0,0.3,4.8-5.1,8.4c0,0,3.9,6.7,5.2,8.9"/>
		<path id="path10104" class="st1" d="M-602.1,609.8c0,0,2.1-0.1,2.8-0.1"/>
		<path id="path10108" class="st1" d="M-603.2,595c0,0,1.1-6,8.5-10.9c0,0,7-5.6,19.6-5.5c0,0,17.2-0.8,27,13c0,0,1.2,1.5,1.3,3.1"
			/>
		<path id="path10112" class="st1" d="M-555.2,602.3c0,0,0.9,4.1,4.1,6.9c0,0-4.6,7.1-5.7,8.7"/>
		<path id="path10116" class="st1" d="M-547.6,609.3c0,0-2.3-0.2-3.4-0.2"/>
		<path id="path10120" class="st1" d="M-552.6,599.6c0,0,0.3-4.6,1.5-6.9"/>
		<path id="path10124" class="st1" d="M-563.4,555.3c0,0-1.6-3.1-13.4-3c0,0-9.9,0.3-13.3,2.5"/>
		<path id="path10128" class="st4" d="M-563.7,540.5c0,0-1.2,2.9-1.8,4.5c0,0,0.9-1.4,1.9-3.3C-563.6,541.7-563.6,540.5-563.7,540.5
			"/>
		<path id="path10132" class="st4" d="M-566.4,539.3c-0.3,1-0.8,2.4-1.3,4.8c0.4-0.7,0.6-1.2,1.7-4.4
			C-565.9,539.7-566.1,538.4-566.4,539.3"/>
		<path id="path10136" class="st4" d="M-574.4,537c-0.1,1.1-0.1,3.9-0.1,5.3c0,0,0.4-1.3,0.6-4.9
			C-573.9,537.4-574.2,536.9-574.4,537"/>
		<path id="path10140" class="st4" d="M-583.3,538.1c0,0,0.4,3.8,0.5,4.8c0,0-0.5-1.1-1-3.8C-583.7,539.1-583.4,538-583.3,538.1"/>
		<path id="path10144" class="st4" d="M-586.2,539.3c0,0,1.4,4.1,2,5.4c0,0-0.4-1.9-1.4-5.3C-585.6,539.4-586.2,539.1-586.2,539.3"
			/>
		<path id="path10148" class="st5" d="M-587.4,583.7c0,0-1.1,5.6,0.1,12.2c0,0,1.7,10.8,6.9,10.5c0,0,4.5,0,4.5-12.8
			c0,0-0.1-7.7-2-11.7C-578,581.9-582.8,582-587.4,583.7"/>
		<path id="path10152" class="st1" d="M-587.4,583.7c0,0-1.1,5.6,0.1,12.2c0,0,1.7,10.8,6.9,10.5c0,0,4.5,0,4.5-12.8
			c0,0-0.1-7.7-2-11.7C-578,581.9-582.8,582-587.4,583.7L-587.4,583.7z"/>
		<path id="path10156" class="st5" d="M-571.8,581.9c0,0-1.8,4.1-1.6,12c0,0-0.1,11.3,4.4,11.8c0,0,5,0.9,6.4-10.6
			c0,0,1.1-6.9-0.1-11.3C-562.8,583.9-567.7,582-571.8,581.9"/>
		<path id="path10160" class="st1" d="M-571.8,581.9c0,0-1.8,4.1-1.6,12c0,0-0.1,11.3,4.4,11.8c0,0,5,0.9,6.4-10.6
			c0,0,1.1-6.9-0.1-11.3C-562.8,583.9-567.7,582-571.8,581.9z"/>
		<path id="path10324" class="st1" d="M-579,559.7c-1.4-2.8-0.8-6.4,3.6-6c4,0.4,3.4,3.3,3.1,6.1
			C-572.3,559.8-574.6,559.4-579,559.7z"/>
		<path id="path10360" class="st4" d="M-570.4,597.6c0.6,0,1.2-1.1,1.3-2.5c0.1-1.4-0.4-2.6-1-2.6c-0.6,0-1.2,1.1-1.3,2.5
			C-571.5,596.4-571.1,597.6-570.4,597.6"/>
		<path id="path10364" class="st1" d="M-570.4,597.6c0.6,0,1.2-1.1,1.3-2.5c0.1-1.4-0.4-2.6-1-2.6c-0.6,0-1.2,1.1-1.3,2.5
			C-571.5,596.4-571.1,597.6-570.4,597.6z"/>
		<path id="path10368" class="st4" d="M-578.7,597.7c0.6,0,1.2-1.1,1.3-2.5c0.1-1.4-0.4-2.6-1-2.6c-0.6,0-1.2,1.1-1.3,2.5
			C-579.8,596.5-579.3,597.6-578.7,597.7"/>
		<path id="path10372" class="st1" d="M-578.7,597.7c0.6,0,1.2-1.1,1.3-2.5c0.1-1.4-0.4-2.6-1-2.6c-0.6,0-1.2,1.1-1.3,2.5
			C-579.8,596.5-579.3,597.6-578.7,597.7z"/>
	</g>
</g>
</svg>
",
"payload_type": "image\/svg+xml;base64",
"associated_login": {
"id": 11,
"name": "Marvin",
"lang": "en",
"login_id": "Marvin",
"write_token": 11,
"last_access": "2018-06-17 16:56:49",
"writeable": true,
"user_object_id": 7,
"security_tokens": [11],
"password": "TuqWG+%y"
}
}
}
}
}
Nevertheless, feeding this JSON to PHP 7.2.1's json_decode() function keeps returning a JSON_ERROR_SYNTAX error (bad syntax).
I think the issue may be with the data in the SVG file, but that is valid Base64 data. It should be fine in JSON.
I tried all the various solutions mentioned in other posts, but still no dice.
Any ideas?
UPDATE: Here's the PHP code that I run it through:
echo('RESULT:<pre>');
var_dump(json_decode($result));
switch (json_last_error()) {
case JSON_ERROR_NONE:
echo ' - No errors';
break;
case JSON_ERROR_DEPTH:
echo ' - Maximum stack depth exceeded';
break;
case JSON_ERROR_STATE_MISMATCH:
echo ' - Underflow or the modes mismatch';
break;
case JSON_ERROR_CTRL_CHAR:
echo ' - Unexpected control character found';
break;
case JSON_ERROR_SYNTAX:
echo ' - Syntax error, malformed JSON';
break;
case JSON_ERROR_UTF8:
echo ' - Malformed UTF-8 characters, possibly incorrectly encoded';
break;
default:
echo ' - Unknown error';
break;
}
echo('</pre>');
That code, in my server/laptop, is what's exposing it.
UPDATE 2: This is the dump from my cURL routine, showing the response:
string(10159) "HTTP/1.1 200 OK
Date: Sun, 17 Jun 2018 17:29:35 GMT
Server: Apache
X-Powered-By: PHP/7.2.1
Content-Length: 10007
Content-Type: application/json
{"people":{"people":{"new_user":{"id":7,"name":"Marvin","lang":"en","read_token":1,"write_token":11,"last_access":"2018-06-17 17:29:35","writeable":true,"surname":"Martian","middle_name":"D","given_name":"Marvin","nickname":"Angry Little Fella","payload":"<REMOVED FOR BREVITY>","payload_type":"image\/svg+xml;base64","associated_login":{"id":11,"name":"Marvin","lang":"en","login_id":"Marvin","write_token":11,"last_access":"2018-06-17 17:29:35","writeable":true,"user_object_id":7,"security_tokens":[11],"password":"1Jq6$oT0"}}}}}"
OK. I wanted to let y'all know what happened. It ain't an answer, but it will be the one I greencheck.
I took off and nuked it from orbit, and now it works.
I have to assume that I did something that sent invisible characters that didn't make it into copy and paste, so the JSONLint never saw them. I'll bet if I had cURLed or wgetted straight from the test harness, it would have borked.
This is a warning to me: Don't get too feisty with the CLI. I'm maybe not as hot at this stuff as I'd like to think.
Thanks for the help, folks.
Fetching BLOB from mysql
$sql = "SELECT data as datajson FROM tablename";
$res=$obj->_executeQuery($sql);
$res=$obj->getAll($res);
$blobdata = $res[0]['datajson'];
My json data from BLOB looks like this
[{"name":"propose","value":"Propose~sample"},
{"name":"expenseamount","value":"Expense Amount~15246"},
{"name":"paymenttype","value":"Payment Type~ Cash"},
{"name":"img0","value":"/9j/4AAQSkZHIjks........61A/3qBo/9k="},
{"name":"img1","value":"NO"}]
Now
{"name":"img0","value":"/9j/4AAQSkZHIjks........61A/3qBo/9k="}
This pair is a base 64 string which is included in my BLOB. And when i did json_decode($blobdata); i am getting null
The exact base64 string can be found in JSFIDDLE
I have added json_last_error(); in my code
switch (json_last_error()) {
case JSON_ERROR_NONE:
echo ' - No errors';
break;
case JSON_ERROR_DEPTH:
echo ' - Maximum stack depth exceeded';
break;
case JSON_ERROR_STATE_MISMATCH:
echo ' - Underflow or the modes mismatch';
break;
case JSON_ERROR_CTRL_CHAR:
echo ' - Unexpected control character found';
break;
case JSON_ERROR_SYNTAX:
echo ' - Syntax error, malformed JSON';
break;
case JSON_ERROR_UTF8:
echo ' - Malformed UTF-8 characters, possibly incorrectly encoded';
break;
default:
echo ' - Unknown error';
break;
}
Which returns - Syntax error, malformed JSON and
json_decode does not work, since this is not a proper json
I want the details other than img0 and img1
1 . Now how do i remove the last two pairs (img0, img1) BEFORE json_decode, so that this becomes valid json.
2 . Or how to convert the base64 string to become proper json
UPDATE
This is how BLOB data is storing in mysql
foreach($_REQUEST as $key=>$value)
{
$raw_data[] = array('name' => $key, 'value' => $value);
}
$json = json_encode($raw_data);
$sql="INSERT INTO tablename (data) VALUES ('$json')";
I am trying to get post details using JSON in wordpress. In my plugin following is the json_decode part. But it returns null.
$post_count = intval($instance['post_count']);
$eng_posts= #json_decode(file_get_contents("http://athavaneng.com/?page_id=206861&posts_per_page=".$post_count), true);
switch (json_last_error()) {
case JSON_ERROR_NONE:
echo ' - No errors';
break;
case JSON_ERROR_DEPTH:
echo ' - Maximum stack depth exceeded';
break;
case JSON_ERROR_STATE_MISMATCH:
echo ' - Underflow or the modes mismatch';
break;
case JSON_ERROR_CTRL_CHAR:
echo ' - Unexpected control character found';
break;
case JSON_ERROR_SYNTAX:
echo ' - Syntax error, malformed JSON';
break;
case JSON_ERROR_UTF8:
echo ' - Malformed UTF-8 characters, possibly incorrectly encoded';
break;
default:
echo ' - Unknown error';
break;
}
In the above code I get a JSON_ERROR_SYNTAX error. But actually when I test the returning JSON data of http://athavaneng.com/?page_id=206861 URL on the http://jsonlint.com. It says that "Valid JSON".
Why is that? What is the problem here?
The responding server is sending 3 strange chars before it starts the json output. By doing this:
$var = file_get_contents("http://athavaneng.com/?page_id=206861&posts_per_page=1");
for($i=0; $i<10; $i++) {
echo $var[$i] . " : " . ord($var[$i]) . "<br />";
}
you will get something like this:
ï : 239
» : 187
¿ : 191
{ : 123
" : 34
1 : 49
" : 34
: : 58
{ : 123
" : 34
the first three chars (239,187 and 191) should not been printed by the server. As a workaround you should be able to parse it after stripping the first three chars.
I am able to parse your json with the following code, which beginns reading at character 3:
$var = file_get_contents("http://athavaneng.com/?page_id=206861&posts_per_page=1", false, NULL, 3);
var_export(json_decode($var));
Can't seem to find the solution to this, I want to load json data from a view variable like this
$this->json = $this->load->view('/jsonfiles/page.json','',true);
Outputting
var_dump(json_decode($this->json,true));
= NULL
The View seems to be rendering the .json file incorrectly, for the json_decode to fail. (maybe not incorrectly, but in a different format), Ive already tried to utf8_encode, no luck
JSON Variable within the page.json
[
{
"page" : {
"name" : "PageNameHere",
"date" : true
}
}
]
Or is there an alternative to doing this?
UPDATE: Yes it works when its an actual string in the variable like this
$this->json = '[{"page":{"name":"PageNameHere","date":true}}]';
var_dump(json_decode($this->json,true));
SOLUTION: So I've decided to figure this out one, and by my mistake, I had a "," comma in the last part of my JSON, which wasn't in this thread, I shorten the JSON for topic, but I found it, using this neat error switch, able to find JSON rendering errors
switch (json_last_error()) {
case JSON_ERROR_NONE:
echo ' - No errors';
break;
case JSON_ERROR_DEPTH:
echo ' - Maximum stack depth exceeded';
break;
case JSON_ERROR_STATE_MISMATCH:
echo ' - Underflow or the modes mismatch';
break;
case JSON_ERROR_CTRL_CHAR:
echo ' - Unexpected control character found';
break;
case JSON_ERROR_SYNTAX:
echo ' - Syntax error, malformed JSON';
break;
case JSON_ERROR_UTF8:
echo ' - Malformed UTF-8 characters, possibly incorrectly encoded';
break;
default:
echo ' - Unknown error';
break;
}
My Issue was labeled as "Syntax error, malformed JSON"