I have a string in a json format, but this is giving invalid json format as i am querying it via php loops
{"a":"" works our ‘T’ logo into an intricately perforated pattern. logo — pattern. Height: .36"" (.9 cm) Length: .29"" (.7 cm) " " }
I need the output as
{"a":"works our ‘T’ logo into an intricately perforated pattern. logo †pattern. Height: .36 (.9 cm) Length: .29 (.7 cm)"}
(i think this should be the correct format)
I have tried str_replace ,but it is removing quotes from the start and end as well, and trim() method also removed all the double quotes in the string.
<?php
$a = "" works our ‘T’ logo into an intricately perforated pattern. logo — pattern. Height: .36"" (.9 cm) Length: .29"" (.7 cm) " " ;
echo str_replace('"',"",$a);
?>
and i m getting this error:
Line : 2, Error type : 4
Message : syntax error, unexpected 'works' (T_STRING)
Note: this value is fetched from the DB and i need it to post to some api so that they can get all the values from our api. and i really dnt want to make any changes in our database or our backend from where this value is coming.
Hint or little solution would help i think.
//To highlight more on what i m exactly doing with the json
//see the below code.
<?php
ini_set('max_execution_time', 0);
require __DIR__ . '/app/Mage.php';
umask(0);
Mage::app();
$collection = Mage::getModel('catalog/product')->getCollection()->addAttributeToSelect("name");
foreach($collection as $product){
$product_name = strip_tags($product->getName()); //get name of the product
$result = array();
foreach ($products as $product1) {
$label = array_reduce(
$someattrbute,
function ($carry, $item) use ($product1) {
return $carry . $product1->getAttributeText($item) . ' ';
},
''
);
$result[trim($label)] = $product1->getQty();
}
$product_sizeandquantity = json_encode($result); //result
$products_data.= "{";
$products_data.= '"product_name"'.":".'"'.$product_name.'",';
$products_data.= '"product_stock"'.":".'['.$product_sizeandquantity.'],';
$products_data.= "},";
$products_data = rtrim($products_data, ',');
$products_data.= "]";
//echo $products_data;
$url = 'https://www.yourdomain.com/products';
$api_key = 'mykey';
$sec_key = 'secretkey';
$data='scapi_key='.urlencode($api_key).'&scsecret_key='.urlencode($sec_key)."&products=".urlencode($products_data);
//echo $data;
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS,$data);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt($ch, CURLOPT_HTTPHEADER, array(
'Content-Type: application/x-www-form-urlencoded')
);
$response = curl_exec($ch);
curl_close($ch);
$arr = json_decode($response, true);
echo $arr;
?>
And this is the json i m getting and this is only for one product, but there are many,as it is foreach loop:
[{"product_name":"Flats", "product_stock":[{"38":"1.0000"}]}]
I think that this is valid json, but still want to know what can be done to pass it through the post request of curl in the above code, as error shows that its a json invalid error.
Note: Some of the products also has the height and sizes and content containing double quotes as shown above.
Related
I am a newbie developer trying to learn web development. I am currently working on this project where articles from a website get shared automatically to a viber public chat. I am facing this problem where I cannot put the URL in the media. I think this is because its json. I am not sure what I am doing wrong here. I have included.
<?php
$Tid = "-1";
if (isset($_GET['id'])) {
$Tid = $_GET['id'];
}
$url = 'https://chatapi.viber.com/pa/post';
$jsonData='{
"auth_token":"4750f56f26a7d2ed-f6b44b76f03d039a-9601b6c9d0d46813",
"from": "K9/C2Vz12r+afcwZaexiCg==",
"type":"url",
"media": "$thisID"
// I want to use $thisID as shown above. But when I
do so this error appears [ {"status":3,"status_message":"'media' field value is not a valid url."} ]
// When I use any full form url like https://google.com it works fine
}';
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $jsonData);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json'));
$result = curl_exec($ch);
curl_close($ch);
?>
This would work as you are using a single quoted literal.
"media": "' . $thisID . '"
But you are always better to make a PHP array or Object and then use json_encode() to create the JSON String like this
$obj = new stdClass;
$obj->auth_token = "4750f56f26a7d2ed-f6b44b76f03d039a-9601b6c9d0d46813";
$obj->from = "K9/C2Vz12r+afcwZaexiCg==";
$obj->type = 'url';
$obj->media = $thisID;
$jsondata = json_encode($obj);
RESULT of echo $jsondata;
{"auth_token":"4750f56f26a7d2ed-f6b44b76f03d039a-9601b6c9d0d46813",
"from":"K9\/C2Vz12r+afcwZaexiCg==",
"type":"url",
"media":"-1"
}
This question already has an answer here:
How to extract and access data from JSON with PHP?
(1 answer)
Closed 4 years ago.
I am using the following code to pull data from an API with JSON results.
// Open connection
$ch = curl_init();
// Make the curl call
curl_setopt($ch, CURLOPT_USERPWD, $username . ":" . $password);
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json'));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
$head = curl_exec($ch);
$http_code = curl_getinfo($ch, CURLINFO_HTTP_CODE);
curl_close($ch);
$data = json_decode($head,true);
foreach($data as $item) {
$name = $item['name'];
$description = $item['description'];
echo "NAME: $name DESCRIPTION: $description";
}
If I use print_r($head) I see all of the results so I know url, username, password is good, however the echo statement at the end of the code is not producing results.
Here is a sample of what the JSON looks like when I print_r($head). Some of it at least.
{"events":[{"eventId":5183191,"name":"The Rhythm Rockets - FREE","description":"Summer Concert Series - The Rhythm Rockets . .\nFREE. Look for a YELLOW balloon. Bring a chair. PLEASE BE ON TIME (6:00 PM!) TO SIT WITH THE GROUP. Allow time for street parking. Expect a crowd. Meetup at 6pm - Showtime is 7pm. Food, wine and beer will be on sale.\nIn case of inclement weather, concerts will be held indoors at the Lincoln Center, 935 Maple Avenue. For weather updates, call[masked] after 5:30 pm. If moved inside, there is no way we can sit together.","primaryImage":{"smallImageUrl":"https://domainnamestorage.blob.core.windows.net/portalimages/portalimages/71021444-d72d-456c-a419-36b61ead5259.small.png","mediumImageUrl":"https://domainnamestorage.blob.core.windows.net/portalimages/portalimages/71021444-d72d-456c-a419-36b61ead5259.medium.png","largeImageUrl":"https://domainnamestorage.blob.core.windows.net/portalimages/portalimages/71021444-d72d-456c-a419-36b61ead5259.large.png"},"categories":[{"categoryId":2,"parentCategoryId":null,"name":"Performing Arts"},{"categoryId":12,"parentCategoryId":null,"name":"Food & Drink"},{"categoryId":17,"parentCategoryId":2,"name":"Music"},{"categoryId":75,"parentCategoryId":12,"name":"Drinks"},{"categoryId":100,"parentCategoryId":17,"name":"Concerts"}],"location":{"latitude":41.792683,"longitude":-88.011765,"city":"Downers Grove","state":"IL","address":"1000 Grove St","country":"United States","locationName":"Fishel Park"},"instances":[{"startDateTime":"2018-08-21T18:00:00Z","endDateTime":null,"hasTime":true,"allDay":false}],"price":{"lowerPrice":null,"upperPrice":null,"free":false,"description":null},"lastUpdatedDate":"2018-07-26T02:20:49.686Z","popularity":null,"interest":50,"links":[{"isSponsor":false,"name":"Meetup","linkUrl":"https://www.meetup.com/Im-Not-Dead-Yet-50-plus/events/252406255/","logoUrl":null},{"isSponsor":true,"name":"I'm Not Dead Yet --- 50+ Meetup","linkUrl":"http://Meetup.com/Im-Not-Dead-Yet-50-plus","logoUrl":null},{"isSponsor":true,"name":"I'm Not Dead Yet --- 50+ Meetup","linkUrl":"http://Meetup.com/Im-Not-Dead-Yet-50-plus","logoUrl":null}],"previousEventIds":[],"seriesStart":"2018-08-21T18:00:00Z","seriesEnd":null,"url":"http://portal.domainname.com/m/FireVite#!/details/THE-RHYTHM-ROCKETS-FREE/5183191/2018-08-21T18","handPicked":false,"customField":null,"contact":{"organization":null,"name":null,"email":null,"phone":null},"media":null}
After your decode, $data will have an array called events with each element being the array you are trying to look at. try:
foreach ($data['events'] as $item)...
print_r() does not make sense forstring, but only for array and object.
it might be rather alike this (and maybe you have to use $data['events'] instead)
when using $data = json_decode($response); it would be $data->events:
$data = json_decode($response, true);
// die('<pre>'.print_r($data, true).'</pre>');
foreach($data['events'] as $key => $item) {
// $event_id = $data['events'][$key]['eventId'];
$event_id = $item['eventId'];
// $name = $data['events'][$key]['name'];
$name = $item['name'];
// $desc = $data['events'][$key]['description'];
$desc = $item['description'];
echo "KEY: $key, ID: $event_id, NAME: $name, DESCRIPTION: $desc";
}
those inline comments just indicate, what is actually being accessed.
This is my first time using web service. My PHP server get the json data from .net server where it is encoded to base64.
The problem now is, i failed to read each attribute inside the data:
Array ( [JSONDataResult] => {"file":"iVBORw0KGgoAAAANSUhEUgAAALUAAAEZCAYAAADR+mSIAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAABhuSURBVHhe7ZiBcuM4smz3\/3\/6PkrPjCgfppBMFWB53DgRx2whs4raMWJ7dv938H8\/KVGdjkR1qrNx+13ehftTU9w889V+vVOHqySq05GoTnU2br\/Lu3B\/aoqbZ77ar3fqcJVEdToS1anOxu13eRfuT01x88xX+\/VOHa6SqE5HojrV2bj9Lu\/C\/akpbp75ar\/eeT2cids\/O6cp6Xzad6zeR1PS+bSfovYfz+vhTNz+2TlNSefTvmP1PpqSzqf9FLX\/eF4PZ+L2z85pSjqf9h2r99GUdD7tp6j9x\/N6OBO3f3ZOU9L5tO9YvY+mpPNpP0XtP57XwwpzJ3E5Wd0n6fyn+93c4eZdTlyfuZOo\/HheDyvMncTlZHWfpPOf7ndzh5t3OXF95k6i8uN5PawwdxKXk9V9ks5\/ut\/NHW7e5cT1mTuJyo\/n9bDC3ElcTlb3STr\/6X43d7h5lxPXZ+4kKj+e18MKcydJc0pUZyRRnSr56ZwSl5O07+A+StLcSVR+PK+HFeZOkuaUqM5IojpV8tM5JS4nad\/BfZSkuZOo\/HheDyvMnSTNKVGdkUR1quSnc0pcTtK+g\/soSXMnUfnxvB5WmDtJmlOiOiOJ6lTJT+eUuJykfQf3UZLmTqLy43k9rDB3EpcT1\/90TtjvSlyewn2UqM5IkuZOovLjeT2sMHcSlxPX\/3RO2O9KXJ7CfZSozkiS5k6i8uN5PawwdxKXE9f\/dE7Y70pcnsJ9lKjOSJLmTqLy43k9rDB3EpcT1\/90TtjvSlyewn2UqM5IkuZOovLjeT2cSbqffZqidqw0ZfU8c7qa1e9T+4\/n9XAm6X72aYrasdKU1fPM6WpWv0\/tP57Xw5mk+9mnKWrHSlNWzzOnq1n9PrX\/eF4PZ5LuZ5+mqB0rTVk9z5yuZvX71P7j+f1wtWTn\/1a+2q936nCVZOf\/Vr7ar3fqcJVk5\/9Wvtqvd+pwlWTn\/1a+2uc7nz8\/iPpSldk5JapTJS53uPk0p6v56ffd4ePfwv1DmZ1TojpV4nKHm09zupqfft8dPv4t3D+U2TklqlMlLne4+TSnq\/np993h49\/C\/UOZnVOiOlXicoebT3O6mp9+3x2O7zH+UswpUZ2RDjVTJWn+23X8tj5J512fOf3qXA8rzClRnZEONVMlaf7bdfy2PknnXZ85\/epcDyvMKVGdkQ41UyVp\/tt1\/LY+Seddnzn96lwPK8wpUZ2RDjVTJWn+23X8tj5J512fOX12nj8D1JLK7NzZxe1zeQr3OYnLyew+cydRnSp5J7+2DGpJZXbu7OL2uTyF+5zE5WR2n7mTqE6VvJNfWwa1pDI7d3Zx+1yewn1O4nIyu8\/cSVSnSt7Jry2DWlKZnTu7uH0uT+E+J3E5md1n7iSqUyXv5Mfz+2Gqw\/WZOx1qpiNRnSpRnSpRnapDzVRJmtPZqHckfu3Q4V0drs\/c6VAzHYnqVInqVInqVB1qpkrSnM5GvSPxa4cO7+pwfeZOh5rpSFSnSlSnSlSn6lAzVZLmdDbqHYlfO3R4V4frM3c61ExHojpVojpVojpVh5qpkjSns1HvSHzueP6ciHpJxeWO2fPU0e1T4nLCflfi8i7pfvbps\/P8ORH1korLHbPnqaPbp8TlhP2uxOVd0v3s02fn+XMi6iUVlztmz1NHt0+Jywn7XYnLu6T72afPzvPnRNRLKi53zJ6njm6fEpcT9rsSl3dJ97NPn53nz4IqjXD9bp7CfalEdaoO11+dE9d3eYrbx5wS1ak+O8+fBVUa4frdPIX7UonqVB2uvzonru\/yFLePOSWqU312nj8LqjTC9bt5CvelEtWpOlx\/dU5c3+Upbh9zSlSn+uw8fxZUaYTrd\/MU7kslqlN1uP7qnLi+y1PcPuaUqE712Xn+nIh6SYW5MyWdZ99JVGck+ek8lbicuD5z6lB9PxWiXlJh7kxJ59l3EtUZSX46TyUuJ67PnDpU30+FqJdUmDtT0nn2nUR1RpKfzlOJy4nrM6cO1fdTIeolFebOlHSefSdRnZHkp\/NU4nLi+sypQ\/WP5\/fD1aaoHSOJy7v89H6a4uaZU4eaGdlF7Tue3w9Xm6J2jCQu7\/LT+2mKm2dOHWpmZBe173h+P1xtitoxkri8y0\/vpylunjl1qJmRXdS+4\/n9cLUpasdI4vIuP72fprh55tShZkZ2UfsuW1miRHWqKWpH1ZH2Hd19nHemqB0jieqMJC53uPl38kuLJUpUp5qidlQdad\/R3cd5Z4raMZKozkjicoebfye\/tFiiRHWqKWpH1ZH2Hd19nHemqB0jieqMJC53uPl38kuLJUpUp5qidlQdad\/R3cd5Z4raMZKozkjicoebfyfPv4WBL+lKXE7SvoP76KdR3ynRoWaqxOUOzlPF9N+CenFH4nKS9h3cRz+N+k6JDjVTJS53cJ4qpv8W1Is7EpeTtO\/gPvpp1HdKdKiZKnG5g\/NUMf23oF7ckbicpH0H99FPo75TokPNVInLHZyniuN8XHI5Sftd+L7UFLWjSlQn0aFmqkR1Eh2r+3c49oyXupyk\/S58X2qK2lElqpPoUDNVojqJjtX9Oxx7xktdTtJ+F74vNUXtqBLVSXSomSpRnUTH6v4djj3jpS4nab8L35eaonZUieokOtRMlahOomN1\/w6XLXwJJd3cwXlKVGckcTlhnzrUTGKK2jGSpLmTqM5IxeVUDVZJN3dwnhLVGUlcTtinDjWTmKJ2jCRp7iSqM1JxOVWDVdLNHZynRHVGEpcT9qlDzSSmqB0jSZo7ieqMVFxO1WCVdHMH5ylRnZHE5YR96lAziSlqx0iS5k6iOiMVl9M7QyPcfJrTLmpnInF5Srov7ZN0nn1KVCfRofqXKVVKcPNpTruonYnE5SnpvrRP0nn2KVGdRIfqX6ZUKcHNpzntonYmEpenpPvSPknn2adEdRIdqn+ZUqUEN5\/mtIvamUhcnpLuS\/sknWefEtVJdKh+\/k8BcOmnJapTJapTJaqzUqI6VYea+U2+w3tTBfVFPilRnSpRnSpRnZUS1ak61Mxv8h3emyqoL\/JJiepUiepUieqslKhO1aFmfpPv8N5UQX2RT0pUp0pUp0pUZ6VEdaoONfObfIfLlFpcJS53zJ6nDtfv5g7Opzpcnzl1pH3CeUpUp\/rsPH8WVLFKXO6YPU8drt\/NHZxPdbg+c+pI+4TzlKhO9dl5\/iyoYpW43DF7njpcv5s7OJ\/qcH3m1JH2CecpUZ3qs\/P8WVDFKnG5Y\/Y8dbh+N3dwPtXh+sypI+0TzlOiOtWvzvWwwtxJ0jw1Re0Y6XD91Tlh30nSnJJP5Mfzelhh7iRpnpqidox0uP7qnLDvJGlOySfy4\/n\/P5wS5k6S5qkpasdIh+uvzgn7TpLmlHwiP57XwwpzJ0nz1BS1Y6TD9VfnhH0nSXNKPpEfz++H1JH2iZtnTlPcfJrTlO58Ct9HSTd3cJ6+wzGnl5060j5x88xpiptPc5rSnU\/h+yjp5g7O03c45vSyU0faJ26eOU1x82lOU7rzKXwfJd3cwXn6DsecXnbqSPvEzTOnKW4+zWlKdz6F76Okmzs4T9\/hmNPLTh1qZqYpakc1xc0z7+r4dJ\/5at\/hmNPLTh1qZqYpakc1xc0z7+r4dJ\/5at\/hmNPLTh1qZqYpakc1xc0z7+r4dJ\/5at\/hmNPLTh1qZqYpakc1xc0z7+r4dJ\/5at\/BTs14SeXT+9inDjVTJaozkricdPuUpDl1zOjbKTXU4dP72KcONVMlqjOSuJx0+5SkOXXM6NspNdTh0\/vYpw41UyWqM5K4nHT7lKQ5dczo2yk11OHT+9inDjVTJaozkricdPuUpDl1zOgfz++HqQ41M1OiOlXictLtO8nsnDpm95mn3uHo6eG7OtTMTInqVInLSbfvJLNz6pjdZ556h6Onh+\/qUDMzJapTJS4n3b6TzM6pY3afeeodjp4evqtDzcyUqE6VuJx0+04yO6eO2X3mqXc4enr4rqSbE\/adRHWqn2b193H7mVOiOiO7uH0qP57fD1NJNyfsO4nqVD\/N6u\/j9jOnRHVGdnH7VH48vx+mkm5O2HcS1al+mtXfx+1nTonqjOzi9qn8eH4\/TCXdnLDvJKpT\/TSrv4\/bz5wS1RnZxe1TuX2rGkrgPCWqU3WomZEO13c5Wd13cB91qJmRDtd3ucK23lla4TwlqlN1qJmRDtd3OVndd3AfdaiZkQ7Xd7nCtt5ZWuE8JapTdaiZkQ7XdzlZ3XdwH3WomZEO13e5wrbeWVrhPCWqU3WomZEO13c5Wd13cB91qJmRDtd3ueLojYeYU5LmqUR1qilqR0cyO6dd1M5qitoxkrhccfTGQ8wpSfNUojrVFLWjI5md0y5qZzVF7RhJXK44euMh5pSkeSpRnWqK2tGRzM5pF7WzmqJ2jCQuVxy98RBzStI8lahONUXt6Ehm57SL2llNUTtGEpcrjl425PrMnSTNU7us3pdKVGemRHWqKWpH9Q5HLxtyfeZOkuapXVbvSyWqM1OiOtUUtaN6h6OXDbk+cydJ89Quq\/elEtWZKVGdaoraUb3D0cuGXJ+5k6R5apfV+1KJ6syUqE41Re2o3uHo6eF3dXT7lLicsJ9KVKdKPp07uvPE7Utz+tXR4bs6un1KXE7YTyWqUyWfzh3deeL2pTn96ujwXR3dPiUuJ+ynEtWpkk\/nju48cfvSnH51dPiujm6fEpcT9lOJ6lTJp3NHd564fWlOvzrXwxHsdyXdnLBPu7h9P507HWqm6nB95l0Vx7kvVdjvSro5YZ92cft+Onc61EzV4frMuyqOc1+qsN+VdHPCPu3i9v107nSomarD9Zl3VRznvlRhvyvp5oR92sXt++nc6VAzVYfrM++quJy6IebOFLVj5GzUO0Y61Ew1JZ1nn3ZJ97l+N39wOXVDzJ0pasfI2ah3jHSomWpKOs8+7ZLuc\/1u\/uBy6oaYO1PUjpGzUe8Y6VAz1ZR0nn3aJd3n+t38weXUDTF3pqgdI2ej3jHSoWaqKek8+7RLus\/1u\/mD9n8q9xKXr4bvp0R1qsTlDs7TFLWjI3E5YZ8S1Ul87nj+bKCWVly+Gr6fEtWpEpc7OE9T1I6OxOWEfUpUJ\/G54\/mzgVpacflq+H5KVKdKXO7gPE1ROzoSlxP2KVGdxOeO588GamnF5avh+ylRnSpxuYPzNEXt6EhcTtinRHUSnzuePwuqmJiSzrOfmqJ2VInqVB1pfzbu\/cxTieokKi6najAxJZ1nPzVF7agS1ak60v5s3PuZpxLVSVRcTtVgYko6z35qitpRJapTdaT92bj3M08lqpOouJyqwcSUdJ791BS1o0pUp+pI+7Nx72eeSlQnUXGc+1KFfUpUJ5G4nMzuM18tcTnp9ilRnY7knfx4Xg9HsE+J6iQSl5PZfearJS4n3T4lqtORvJMfz+vhCPYpUZ1E4nIyu898tcTlpNunRHU6knfy43k9HME+JaqTSFxOZveZr5a4nHT7lKhOR\/JO7v9TLkZ9qZlwv5OozsgUN+9y4vrMU4nLHen8nX7+LSZz50t24H4nUZ2RKW7e5cT1macSlzvS+Tv9\/FtM5s6X7MD9TqI6I1PcvMuJ6zNPJS53pPN3+vm3mMydL9mB+51EdUamuHmXE9dnnkpc7kjn7\/SP8++l1RKXp3BfKvl07nDzzKlDzYwk3Zzc6R\/n30urJS5P4b5U8unc4eaZU4eaGUm6ObnTP86\/l1ZLXJ7Cfank07nDzTOnDjUzknRzcqd\/nH8vrZa4PIX7Usmnc4ebZ04damYk6ebkTv8496UObj9z6nD9NHcSlzs4T4nqVMns3Jmidoy8w9HLhxLcfubU4fpp7iQud3CeEtWpktm5M0XtGHmHo5cPJbj9zKnD9dPcSVzu4DwlqlMls3Nnitox8g5HLx9KcPuZU4frp7mTuNzBeUpUp0pm584UtWPkHY7eeIi5k7icsO8kqjOSqE6VqE5H4nKyuk84v1qi8uN5PawwdxKXE\/adRHVGEtWpEtXpSFxOVvcJ51dLVH48r4cV5k7icsK+k6jOSKI6VaI6HYnLyeo+4fxqicqP5\/WwwtxJXE7YdxLVGUlUp0pUpyNxOVndJ5xfLVH58bweVpg7STd3uPnZOXX8tj7hvNPh+t38DsfceAlzJ+nmDjc\/O6eO39YnnHc6XL+b3+GYGy9h7iTd3OHmZ+fU8dv6hPNOh+t38zscc+MlzJ2kmzvc\/OycOn5bn3De6XD9bn6HY268hLmTzM6dXdTOahe1s+Ns1DtGkm5O2KeK43xcYu4ks3NnF7Wz2kXt7Dgb9Y6RpJsT9qniOB+XmDvJ7NzZRe2sdlE7O85GvWMk6eaEfao4zscl5k4yO3d2UTurXdTOjrNR7xhJujlhnyqOc1\/qMHt\/d186n\/ZT3H6XO9J59lOJ6lSJy4nqH8\/r4Uxm7+\/uS+fTforb73JHOs9+KlGdKnE5Uf3jeT2cyez93X3pfNpPcftd7kjn2U8lqlMlLieqfzyvhzOZvb+7L51P+yluv8sd6Tz7qUR1qsTlRPWP5\/fD1RLVqRLVSeyS7kv7jnTf7D5zSlxO2Kd3OHp6eJVEdapEdRK7pPvSviPdN7vPnBKXE\/bpHY6eHl4lUZ0qUZ3ELum+tO9I983uM6fE5YR9eoejp4dXSVSnSlQnsUu6L+070n2z+8wpcTlhn97hXmuz+Q9xXP7NZrPZbDabzWbzH2PFv8jv\/3Gwecn5f51U7l6Y2b2EFTs3f4TH5eAFmX1ZV1zAFTs3f4TzctRLwgvz+Hx6Us\/UeaX2mD14J6uf1dzmH+a8EK8uCS\/MO9mMHQ9Uxs5mYy8KL43Lqieqd9LJmG82T9QlUmcnd7PKuzvuZOxsNvLiqMtzcjervLvjTsbOZiMvzqsznj\/guerWs3p+8k5WP6u5zWaz2Ww2v5b9V\/fmz7Ev9ebP8epSP86ZnZ9V9uA8rxl76jNnNpsW6jLVM\/55lFXOz6\/OH4yyzeZt1EV6nFVP2E2zUecBP282b6Eu0qvLNbqEd7JR5wE\/bzZvoS7Sq8s1uoSj7IHaeaez2cQ8LlL15NVZRX3mzIk6ezCa2Ww2m81m8+eof\/W\/+leAV+cP3Myruc1mOaPLN7qcKnOfN5sfYXRp67PyKht9fvy5utks49UFO89V\/iobfXbdzWYa6nLdvYyj7EHS3WymoS7X44yeuKxyN9tspuIu1yh3F7V+dt3NZhruco1ylT3OTiv1nNlm859kX+TNn2Nf6s2PMfrXgTNT+Sh7oLI6o\/IHo2yzsZwX59XlqtTPo+zkcXanV3H5ZnObO5dp1Hl1eV+dK0bZZhNz50KpC3pKzrPRTJJtNjHuEiX5qz8rRl03u9kMGV2gO5eLl5O+ombsjeY2G8urC3T3\/N1e\/Xx352Yz5HFx6Mkoe\/DqvKKy0dwo22w2m82n2f\/tvJlC\/ev+05dqX+rNFHiRPnmx9qXeTMFd6sfn08r5uWavelUyytXZZmNRF+nEZa+6nKuMeu\/s22wuPC5MtTL6nGbVE9U7qX32NpshowvDrH6+m83YsdlEjC5PculeZTN2bDYR7vI88tPK6LPKqpW72Waz2Ww2mz\/F6K\/5O5niztwoU7w7t\/nH4EWon+9k7Dy4M3eiMnYevDu32cjLcqIuzZ2z1TtP1Nlm8+1ivHuRRnMrdp6os80\/jrs4yUV6nFdP2OfnB3fO7s5t\/mFWXqTaeXfnu3Obf5RXl2HGRXI77u58d27zD\/K4CLRy55y5Oqu8yuu5yyv1XOWbzWaz2Wx+Feqv6vOs\/nV+evLq\/ORTmWKUbf4gry5IJe18KmPnwSjb\/FFGF+Ek7fx0dqLOTkbZ5o\/x+GUrK\/z8YNT56exEnZ2Mss0f487leNWpklH+KlO9k1F2os5ORtnmj3HncqQXiIy6NRu9d5SdqLOTUbb5Y9y5HOkFqox67j31s+s+UGcno2zzx7hzOd65QKdklD0Y5a+yes58lG02m81ms\/kI6q\/jevYq33+Nb34t6aUeZZvNr6BzqTebX8njkipP6p9P1Nlm82twl\/bVBd4Xe\/NrefdSP9gXe\/MrSS\/1KNtsfgXppX7wONsXerPZbDabTYPRv06cmcpH2QOV1RmVP1BZPWP24NX5g3ezzX+U85f56hdeqZ9H2cnj7E6v4vKT2hu9491s8we48wsddV5dkFfnilFWcTvr53ezzR\/gzi9UXYJTcp6NZpKsorJXc6PPrrv5j+N+oUn+6s+KUVfN3jlTn6snqrf5Q4x+oXd+2bws9BU1Y0\/N3TlTnZOaJXOb\/yCvfqF3z9\/t1c9JtzKr92pu8x\/j8YukJ6PswavzispGcy57xau5V+cnLt9sNpvNZrPZbDabzWaz2Ww2m81M\/ve\/\/wclQxXDBQHQjQAAAABJRU5ErkJggg==","fileSize":"8484","returnCode":"0"} )
There are 3 columns:
file
fileSize
returnCode
I have tried to get data using Object, Array or json but always failed.
//$json = json_decode($data, true); //array
//$json = json_decode($data); //object
//echo $result; //JSONDataResult
Below is one of the FAILED method. The full process coding:
<?php
if (isset($_GET['submit'])) {
$project_code = $_GET['project_code'];
$url = "http://1.2.3.4/to/file/process";
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($curl, CURLOPT_BINARYTRANSFER, 1);
curl_setopt($curl, curlopt_httpheader, array ("Content-type:application/json"));
$result = curl_exec($curl);
curl_close($curl);
$data = file_get_contents($url);
$json = json_decode($data, true); //array
//$json = json_decode($data); //object
//echo $result; //JSONDataResult
//print_r($json);
foreach ($json as $key => $value) {
if (!is_array($value)) {
//always goes here
echo "not array: ".$key . '=>' . $value . '<br/>';
} else {
foreach ($value as $key => $val) {
echo "is array: ".$key . '=>' . $val . '<br/>';
}
}
}
}
?>
Guys help me to read the content. I do not mind using which method as long as i can read each column inside the content. Many-many thank you.
[jangankecamsaya]
Assuming the data you posted in the question is the output of print_r($json);, it is clear that $json is an array that contains only one value (the big JSON) associated to the key JSONDataResult. It basically looks like this:
$json = array('JSONDataResult' => '{"file":"iVBORw0KGgoAAAANSUhEUgAAALUAAAEZCAYAAADR+mSIAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAABhuSURBVHhe7ZiBcuM4smz3\/3\/6PkrPjCgfppBMFWB53DgRx2whs4raMWJ7dv938H8\/KVGdjkR1qrNx+13ehftTU9w889V+vVOHqySq05GoTnU2br\/Lu3B\/aoqbZ77ar3fqcJVEdToS1anOxu13eRfuT01x88xX+\/VOHa6SqE5HojrV2bj9Lu\/C\/akpbp75ar\/eeT2cids\/O6cp6Xzad6zeR1PS+bSfovYfz+vhTNz+2TlNSefTvmP1PpqSzqf9FLX\/eF4PZ+L2z85pSjqf9h2r99GUdD7tp6j9x\/N6OBO3f3ZOU9L5tO9YvY+mpPNpP0XtP57XwwpzJ3E5Wd0n6fyn+93c4eZdTlyfuZOo\/HheDyvMncTlZHWfpPOf7ndzh5t3OXF95k6i8uN5PawwdxKXk9V9ks5\/ut\/NHW7e5cT1mTuJyo\/n9bDC3ElcTlb3STr\/6X43d7h5lxPXZ+4kKj+e18MKcydJc0pUZyRRnSr56ZwSl5O07+A+StLcSVR+PK+HFeZOkuaUqM5IojpV8tM5JS4nad\/BfZSkuZOo\/HheDyvMnSTNKVGdkUR1quSnc0pcTtK+g\/soSXMnUfnxvB5WmDtJmlOiOiOJ6lTJT+eUuJykfQf3UZLmTqLy43k9rDB3EpcT1\/90TtjvSlyewn2UqM5IkuZOovLjeT2sMHcSlxPX\/3RO2O9KXJ7CfZSozkiS5k6i8uN5PawwdxKXE9f\/dE7Y70pcnsJ9lKjOSJLmTqLy43k9rDB3EpcT1\/90TtjvSlyewn2UqM5IkuZOovLjeT2cSbqffZqidqw0ZfU8c7qa1e9T+4\/n9XAm6X72aYrasdKU1fPM6WpWv0\/tP57Xw5mk+9mnKWrHSlNWzzOnq1n9PrX\/eF4PZ5LuZ5+mqB0rTVk9z5yuZvX71P7j+f1wtWTn\/1a+2q936nCVZOf\/Vr7ar3fqcJVk5\/9Wvtqvd+pwlWTn\/1a+2uc7nz8\/iPpSldk5JapTJS53uPk0p6v56ffd4ePfwv1DmZ1TojpV4nKHm09zupqfft8dPv4t3D+U2TklqlMlLne4+TSnq\/np993h49\/C\/UOZnVOiOlXicoebT3O6mp9+3x2O7zH+UswpUZ2RDjVTJWn+23X8tj5J512fOf3qXA8rzClRnZEONVMlaf7bdfy2PknnXZ85\/epcDyvMKVGdkQ41UyVp\/tt1\/LY+Seddnzn96lwPK8wpUZ2RDjVTJWn+23X8tj5J512fOX12nj8D1JLK7NzZxe1zeQr3OYnLyew+cydRnSp5J7+2DGpJZXbu7OL2uTyF+5zE5WR2n7mTqE6VvJNfWwa1pDI7d3Zx+1yewn1O4nIyu8\/cSVSnSt7Jry2DWlKZnTu7uH0uT+E+J3E5md1n7iSqUyXv5Mfz+2Gqw\/WZOx1qpiNRnSpRnSpRnapDzVRJmtPZqHckfu3Q4V0drs\/c6VAzHYnqVInqVInqVB1qpkrSnM5GvSPxa4cO7+pwfeZOh5rpSFSnSlSnSlSn6lAzVZLmdDbqHYlfO3R4V4frM3c61ExHojpVojpVojpVh5qpkjSns1HvSHzueP6ciHpJxeWO2fPU0e1T4nLCflfi8i7pfvbps\/P8ORH1korLHbPnqaPbp8TlhP2uxOVd0v3s02fn+XMi6iUVlztmz1NHt0+Jywn7XYnLu6T72afPzvPnRNRLKi53zJ6njm6fEpcT9rsSl3dJ97NPn53nz4IqjXD9bp7CfalEdaoO11+dE9d3eYrbx5wS1ak+O8+fBVUa4frdPIX7UonqVB2uvzonru\/yFLePOSWqU312nj8LqjTC9bt5CvelEtWpOlx\/dU5c3+Upbh9zSlSn+uw8fxZUaYTrd\/MU7kslqlN1uP7qnLi+y1PcPuaUqE712Xn+nIh6SYW5MyWdZ99JVGck+ek8lbicuD5z6lB9PxWiXlJh7kxJ59l3EtUZSX46TyUuJ67PnDpU30+FqJdUmDtT0nn2nUR1RpKfzlOJy4nrM6cO1fdTIeolFebOlHSefSdRnZHkp\/NU4nLi+sypQ\/WP5\/fD1aaoHSOJy7v89H6a4uaZU4eaGdlF7Tue3w9Xm6J2jCQu7\/LT+2mKm2dOHWpmZBe173h+P1xtitoxkri8y0\/vpylunjl1qJmRXdS+4\/n9cLUpasdI4vIuP72fprh55tShZkZ2UfsuW1miRHWqKWpH1ZH2Hd19nHemqB0jieqMJC53uPl38kuLJUpUp5qidlQdad\/R3cd5Z4raMZKozkjicoebfye\/tFiiRHWqKWpH1ZH2Hd19nHemqB0jieqMJC53uPl38kuLJUpUp5qidlQdad\/R3cd5Z4raMZKozkjicoebfyfPv4WBL+lKXE7SvoP76KdR3ynRoWaqxOUOzlPF9N+CenFH4nKS9h3cRz+N+k6JDjVTJS53cJ4qpv8W1Is7EpeTtO\/gPvpp1HdKdKiZKnG5g\/NUMf23oF7ckbicpH0H99FPo75TokPNVInLHZyniuN8XHI5Sftd+L7UFLWjSlQn0aFmqkR1Eh2r+3c49oyXupyk\/S58X2qK2lElqpPoUDNVojqJjtX9Oxx7xktdTtJ+F74vNUXtqBLVSXSomSpRnUTH6v4djj3jpS4nab8L35eaonZUieokOtRMlahOomN1\/w6XLXwJJd3cwXlKVGckcTlhnzrUTGKK2jGSpLmTqM5IxeVUDVZJN3dwnhLVGUlcTtinDjWTmKJ2jCRp7iSqM1JxOVWDVdLNHZynRHVGEpcT9qlDzSSmqB0jSZo7ieqMVFxO1WCVdHMH5ylRnZHE5YR96lAziSlqx0iS5k6iOiMVl9M7QyPcfJrTLmpnInF5Srov7ZN0nn1KVCfRofqXKVVKcPNpTruonYnE5SnpvrRP0nn2KVGdRIfqX6ZUKcHNpzntonYmEpenpPvSPknn2adEdRIdqn+ZUqUEN5\/mtIvamUhcnpLuS\/sknWefEtVJdKh+\/k8BcOmnJapTJapTJaqzUqI6VYea+U2+w3tTBfVFPilRnSpRnSpRnZUS1ak61Mxv8h3emyqoL\/JJiepUiepUieqslKhO1aFmfpPv8N5UQX2RT0pUp0pUp0pUZ6VEdaoONfObfIfLlFpcJS53zJ6nDtfv5g7Opzpcnzl1pH3CeUpUp\/rsPH8WVLFKXO6YPU8drt\/NHZxPdbg+c+pI+4TzlKhO9dl5\/iyoYpW43DF7njpcv5s7OJ\/qcH3m1JH2CecpUZ3qs\/P8WVDFKnG5Y\/Y8dbh+N3dwPtXh+sypI+0TzlOiOtWvzvWwwtxJ0jw1Re0Y6XD91Tlh30nSnJJP5Mfzelhh7iRpnpqidox0uP7qnLDvJGlOySfy4\/n\/P5wS5k6S5qkpasdIh+uvzgn7TpLmlHwiP57XwwpzJ0nz1BS1Y6TD9VfnhH0nSXNKPpEfz++H1JH2iZtnTlPcfJrTlO58Ct9HSTd3cJ6+wzGnl5060j5x88xpiptPc5rSnU\/h+yjp5g7O03c45vSyU0faJ26eOU1x82lOU7rzKXwfJd3cwXn6DsecXnbqSPvEzTOnKW4+zWlKdz6F76Okmzs4T9\/hmNPLTh1qZqYpakc1xc0z7+r4dJ\/5at\/hmNPLTh1qZqYpakc1xc0z7+r4dJ\/5at\/hmNPLTh1qZqYpakc1xc0z7+r4dJ\/5at\/hmNPLTh1qZqYpakc1xc0z7+r4dJ\/5at\/BTs14SeXT+9inDjVTJaozkricdPuUpDl1zOjbKTXU4dP72KcONVMlqjOSuJx0+5SkOXXM6NspNdTh0\/vYpw41UyWqM5K4nHT7lKQ5dczo2yk11OHT+9inDjVTJaozkricdPuUpDl1zOgfz++HqQ41M1OiOlXictLtO8nsnDpm95mn3uHo6eG7OtTMTInqVInLSbfvJLNz6pjdZ556h6Onh+\/qUDMzJapTJS4n3b6TzM6pY3afeeodjp4evqtDzcyUqE6VuJx0+04yO6eO2X3mqXc4enr4rqSbE\/adRHWqn2b193H7mVOiOiO7uH0qP57fD1NJNyfsO4nqVD\/N6u\/j9jOnRHVGdnH7VH48vx+mkm5O2HcS1al+mtXfx+1nTonqjOzi9qn8eH4\/TCXdnLDvJKpT\/TSrv4\/bz5wS1RnZxe1TuX2rGkrgPCWqU3WomZEO13c5Wd13cB91qJmRDtd3ucK23lla4TwlqlN1qJmRDtd3OVndd3AfdaiZkQ7Xd7nCtt5ZWuE8JapTdaiZkQ7XdzlZ3XdwH3WomZEO13e5wrbeWVrhPCWqU3WomZEO13c5Wd13cB91qJmRDtd3ueLojYeYU5LmqUR1qilqR0cyO6dd1M5qitoxkrhccfTGQ8wpSfNUojrVFLWjI5md0y5qZzVF7RhJXK44euMh5pSkeSpRnWqK2tGRzM5pF7WzmqJ2jCQuVxy98RBzStI8lahONUXt6Ehm57SL2llNUTtGEpcrjl425PrMnSTNU7us3pdKVGemRHWqKWpH9Q5HLxtyfeZOkuapXVbvSyWqM1OiOtUUtaN6h6OXDbk+cydJ89Quq\/elEtWZKVGdaoraUb3D0cuGXJ+5k6R5apfV+1KJ6syUqE41Re2o3uHo6eF3dXT7lLicsJ9KVKdKPp07uvPE7Utz+tXR4bs6un1KXE7YTyWqUyWfzh3deeL2pTn96ujwXR3dPiUuJ+ynEtWpkk\/nju48cfvSnH51dPiujm6fEpcT9lOJ6lTJp3NHd564fWlOvzrXwxHsdyXdnLBPu7h9P507HWqm6nB95l0Vx7kvVdjvSro5YZ92cft+Onc61EzV4frMuyqOc1+qsN+VdHPCPu3i9v107nSomarD9Zl3VRznvlRhvyvp5oR92sXt++nc6VAzVYfrM++quJy6IebOFLVj5GzUO0Y61Ew1JZ1nn3ZJ97l+N39wOXVDzJ0pasfI2ah3jHSomWpKOs8+7ZLuc\/1u\/uBy6oaYO1PUjpGzUe8Y6VAz1ZR0nn3aJd3n+t38weXUDTF3pqgdI2ej3jHSoWaqKek8+7RLus\/1u\/mD9n8q9xKXr4bvp0R1qsTlDs7TFLWjI3E5YZ8S1Ul87nj+bKCWVly+Gr6fEtWpEpc7OE9T1I6OxOWEfUpUJ\/G54\/mzgVpacflq+H5KVKdKXO7gPE1ROzoSlxP2KVGdxOeO588GamnF5avh+ylRnSpxuYPzNEXt6EhcTtinRHUSnzuePwuqmJiSzrOfmqJ2VInqVB1pfzbu\/cxTieokKi6najAxJZ1nPzVF7agS1ak60v5s3PuZpxLVSVRcTtVgYko6z35qitpRJapTdaT92bj3M08lqpOouJyqwcSUdJ791BS1o0pUp+pI+7Nx72eeSlQnUXGc+1KFfUpUJ5G4nMzuM18tcTnp9ilRnY7knfx4Xg9HsE+J6iQSl5PZfearJS4n3T4lqtORvJMfz+vhCPYpUZ1E4nIyu898tcTlpNunRHU6knfy43k9HME+JaqTSFxOZveZr5a4nHT7lKhOR\/JO7v9TLkZ9qZlwv5OozsgUN+9y4vrMU4nLHen8nX7+LSZz50t24H4nUZ2RKW7e5cT1macSlzvS+Tv9\/FtM5s6X7MD9TqI6I1PcvMuJ6zNPJS53pPN3+vm3mMydL9mB+51EdUamuHmXE9dnnkpc7kjn7\/SP8++l1RKXp3BfKvl07nDzzKlDzYwk3Zzc6R\/n30urJS5P4b5U8unc4eaZU4eaGUm6ObnTP86\/l1ZLXJ7Cfank07nDzTOnDjUzknRzcqd\/nH8vrZa4PIX7Usmnc4ebZ04damYk6ebkTv8496UObj9z6nD9NHcSlzs4T4nqVMns3Jmidoy8w9HLhxLcfubU4fpp7iQud3CeEtWpktm5M0XtGHmHo5cPJbj9zKnD9dPcSVzu4DwlqlMls3Nnitox8g5HLx9KcPuZU4frp7mTuNzBeUpUp0pm584UtWPkHY7eeIi5k7icsO8kqjOSqE6VqE5H4nKyuk84v1qi8uN5PawwdxKXE\/adRHVGEtWpEtXpSFxOVvcJ51dLVH48r4cV5k7icsK+k6jOSKI6VaI6HYnLyeo+4fxqicqP5\/WwwtxJXE7YdxLVGUlUp0pUpyNxOVndJ5xfLVH58bweVpg7STd3uPnZOXX8tj7hvNPh+t38DsfceAlzJ+nmDjc\/O6eO39YnnHc6XL+b3+GYGy9h7iTd3OHmZ+fU8dv6hPNOh+t38zscc+MlzJ2kmzvc\/OycOn5bn3De6XD9bn6HY268hLmTzM6dXdTOahe1s+Ns1DtGkm5O2KeK43xcYu4ks3NnF7Wz2kXt7Dgb9Y6RpJsT9qniOB+XmDvJ7NzZRe2sdlE7O85GvWMk6eaEfao4zscl5k4yO3d2UTurXdTOjrNR7xhJujlhnyqOc1\/qMHt\/d186n\/ZT3H6XO9J59lOJ6lSJy4nqH8\/r4Uxm7+\/uS+fTforb73JHOs9+KlGdKnE5Uf3jeT2cyez93X3pfNpPcftd7kjn2U8lqlMlLieqfzyvhzOZvb+7L51P+yluv8sd6Tz7qUR1qsTlRPWP5\/fD1RLVqRLVSeyS7kv7jnTf7D5zSlxO2Kd3OHp6eJVEdapEdRK7pPvSviPdN7vPnBKXE\/bpHY6eHl4lUZ0qUZ3ELum+tO9I983uM6fE5YR9eoejp4dXSVSnSlQnsUu6L+070n2z+8wpcTlhn97hXmuz+Q9xXP7NZrPZbDabzWbzH2PFv8jv\/3Gwecn5f51U7l6Y2b2EFTs3f4TH5eAFmX1ZV1zAFTs3f4TzctRLwgvz+Hx6Us\/UeaX2mD14J6uf1dzmH+a8EK8uCS\/MO9mMHQ9Uxs5mYy8KL43Lqieqd9LJmG82T9QlUmcnd7PKuzvuZOxsNvLiqMtzcjervLvjTsbOZiMvzqsznj\/guerWs3p+8k5WP6u5zWaz2Ww2v5b9V\/fmz7Ev9ebP8epSP86ZnZ9V9uA8rxl76jNnNpsW6jLVM\/55lFXOz6\/OH4yyzeZt1EV6nFVP2E2zUecBP282b6Eu0qvLNbqEd7JR5wE\/bzZvoS7Sq8s1uoSj7IHaeaez2cQ8LlL15NVZRX3mzIk6ezCa2Ww2m81m8+eof\/W\/+leAV+cP3Myruc1mOaPLN7qcKnOfN5sfYXRp67PyKht9fvy5utks49UFO89V\/iobfXbdzWYa6nLdvYyj7EHS3WymoS7X44yeuKxyN9tspuIu1yh3F7V+dt3NZhruco1ylT3OTiv1nNlm859kX+TNn2Nf6s2PMfrXgTNT+Sh7oLI6o\/IHo2yzsZwX59XlqtTPo+zkcXanV3H5ZnObO5dp1Hl1eV+dK0bZZhNz50KpC3pKzrPRTJJtNjHuEiX5qz8rRl03u9kMGV2gO5eLl5O+ombsjeY2G8urC3T3\/N1e\/Xx352Yz5HFx6Mkoe\/DqvKKy0dwo22w2m82n2f\/tvJlC\/ev+05dqX+rNFHiRPnmx9qXeTMFd6sfn08r5uWavelUyytXZZmNRF+nEZa+6nKuMeu\/s22wuPC5MtTL6nGbVE9U7qX32NpshowvDrH6+m83YsdlEjC5PculeZTN2bDYR7vI88tPK6LPKqpW72Waz2Ww2mz\/F6K\/5O5niztwoU7w7t\/nH4EWon+9k7Dy4M3eiMnYevDu32cjLcqIuzZ2z1TtP1Nlm8+1ivHuRRnMrdp6os80\/jrs4yUV6nFdP2OfnB3fO7s5t\/mFWXqTaeXfnu3Obf5RXl2HGRXI77u58d27zD\/K4CLRy55y5Oqu8yuu5yyv1XOWbzWaz2Wx+Feqv6vOs\/nV+evLq\/ORTmWKUbf4gry5IJe18KmPnwSjb\/FFGF+Ek7fx0dqLOTkbZ5o\/x+GUrK\/z8YNT56exEnZ2Mss0f487leNWpklH+KlO9k1F2os5ORtnmj3HncqQXiIy6NRu9d5SdqLOTUbb5Y9y5HOkFqox67j31s+s+UGcno2zzx7hzOd65QKdklD0Y5a+yes58lG02m81ms\/kI6q\/jevYq33+Nb34t6aUeZZvNr6BzqTebX8njkipP6p9P1Nlm82twl\/bVBd4Xe\/NrefdSP9gXe\/MrSS\/1KNtsfgXppX7wONsXerPZbDabTYPRv06cmcpH2QOV1RmVP1BZPWP24NX5g3ezzX+U85f56hdeqZ9H2cnj7E6v4vKT2hu9491s8we48wsddV5dkFfnilFWcTvr53ezzR\/gzi9UXYJTcp6NZpKsorJXc6PPrrv5j+N+oUn+6s+KUVfN3jlTn6snqrf5Q4x+oXd+2bws9BU1Y0\/N3TlTnZOaJXOb\/yCvfqF3z9\/t1c9JtzKr92pu8x\/j8YukJ6PswavzispGcy57xau5V+cnLt9sNpvNZrPZbDabzWaz2Ww2m81M\/ve\/\/wclQxXDBQHQjQAAAABJRU5ErkJggg==","fileSize":"8484","returnCode":"0"}');
A call to json_decode($json['JSONDataResult'], TRUE) decodes the big string into an array like this:
array(
'file' => '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',
'fileSize' => 8484,
'returnCode' => 0,
);
The value of file is encoded using base64. The complete code should look like this:
// Decode the JSON
$fileInfo = json_decode($json, TRUE);
// Decode the file content
$content = base64_decode($fileInfo['file']);
// Visually inspect its the decoded file content
print_r($content); // Congratulations, it's a PNG!
// Put the content in a file
file_put_contents('...the file path here...', $content);
// Use getimagesize() to learn about the image type
// an rename the file using the correct termination.
Btw, the value of fileSize is the length of the file field, i.e. the content encoded using base64, not the length of the actual PNG file on disk (as I would expect).
You tried to
$json = json_decode($data[0], true); //array
???
(mind the access on the first field on $data)
I wached a youtube video and came across these codes.
my php file index.php
<?php
//initialize session
$ch = curl_init();
//set the URL
$url = "http://localhost:81/data.php"
//set options
curl_setopt($ch, CURLOPT_URL,$url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HEADER, 0);
//execution
$json=curl_exec($ch);
//close
curl_close($ch);
//decode the json
$json=json_decode($json, true);
//loop through the results
for($i=0;$i<['Metadata']['TotalResults'];$i++){
echo "JSON : <b>First Name = </b>". $json['Result'][$i]["FirstName"]." , <b>Last Name = </b>".$json['Result'][$i]["LastName"];
}
?>
my json file data.php
<?php
//metadata which will contain how many resukts we have
$meta_array['TotalResults'] = 1;
$metadata = '{"Metadata" : ';
$metadata .= json_encode($meta_array). ',';
//the data
$array["FirstName"] = 'Gary';
$array["LastName"] = 'George';
$data[] = $array;
//json encode the array
$json_encoded = utf8_encode(json_encode($data));
echo $metadata . ' "Result" : '.$json_encoded. '}' ;
exit();
?>
I am continuously getting the above mentioned error.
I am new to jason and curl.
please help me to solve my problem.
thanks in advance :)
I can't see any semicolon after the url.
$url = "http://localhost:81/data.php";
^ it is missing
In your code block you are using $i<['Metadata']['TotalResults'] at loop. Here you are missing the variable name that is eventually your array name. An example could be:
$i<$your_array['Metadata']['TotalResults']
I'm having an extrange issue when receiving parameters from a POST cURL request. No matter how I encode it (json, url, rawurl, utf8, base64...) before POSTing it, I am not able to perform any decoding operation through the array elements, via loop. I'm giving you the details.
From the consuming controller, in some other php (Yii) app, I build my request like this:
private function callTheApi($options)
{
$url = "http://api.call.com/url/api";
$params = array( 'api_key' => $this->api_key,
'domain' => $this->domain,
'date' => $options['date'],
'keys' => $options['keys'] // This is an array
);
// Following some good advice from Daniel Vandersluis here:
// http://stackoverflow.com/questions/3772096/posting-multidimensional-array-with-php-and-curl
if (is_array($params['keys'])
{
foreach ($params['keys'] as $id => $name)
{
$params['keys[' . $id . ']'] = $name;
}
unset($params['keys']);
}
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: multipart/form-data; charset=utf-8'));
curl_setopt($ch, CURLOPT_TIMEOUT, 120);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_POST, TRUE);
curl_setopt($ch, CURLOPT_POSTFIELDS, $params);
curl_setopt($ch, CURLOPT_USERAGENT,
"Mozilla/5.0 (Windows; U; Windows NT 5.0; en; rv:1.9.0.4) "
. "Gecko/2009011913 Firefox/3.0.6");
$output = curl_exec($ch);
$error = curl_errno($ch);
$error_text = curl_error($ch);
curl_close($ch);
if (!$output || $error != 0)
die("<br><hr>Problems...<br>"
. "Line:" . __LINE__ . " dataExtractor.php<br>"
. "Error: " . $error . " - " . $error_text . "<hr>"
. $url . "<hr>");
sleep(1);
return json_decode($output, true);
}
And in the api itself, this is the function:
public function api()
{
$params = $_POST;
foreach($params as $k=>$v){
if($k=='domain') $domain = $v;
if($k=='date') $date = $v;
if($k=='api_key') $api_key = $v;
if($k=='keys') $keys = $v;
}
echo json_encode($keys);
// All my logic would be here, after parsing the array correctly.
}
Ok, now for the problems:
If i leave everything like stated before, it works. I have my $keys array in the api, and I can use it however I want. The "echo json_encode($keys)" sentence returns the array ALMOST as it should be. But the problem is some values of the array are corrupted in the cURL operation. Values such as spanish characters á, é ,í, ó, ú OR ü are simply not present in the array_values.
If some key in the $keys array was spanish word "alimentación" in the original array, once it's been cURLed to the api, it becomes "alimentacin". There, the ó is not there anymore.
So, my chances are encoding each value in the array to a safely transferred value, so that I can decode it later. But what do you know, I can't.
I've tried urlencoding, rawurlencoding, json_encoding, base64_encoding... each value of the array. And if I return the received array from the api, it contains the encoded values all right. BUT.
If I loop the array in the api for decoding, and then try to return it, no matter what decoding function I'm applying to its values, the output is ALWAYS "NULL".
I have no clue what I'm doing wrong here. Not even close.
So any help would be much appreciated. Thanks in advance, community.
When you create cUrl params array you should know that keys cannot be utf8.
And when you add some parameters in foreach loop
$params['keys[' . $id . ']'] = $name;
$id can be utf8 character.
To avoid that I recommend you to use json_encode
$params = array(
'api_key' => $this->api_key,
'domain' => $this->domain,
'date' => $options['date'],
'keys' => json_encode($options['keys']) // This is an array
);
In your api in this case you should change nothing.