• Welcome to the Chevereto user community!

    Here users from all over the world gather around to learn the latest about Chevereto and contribute with ideas to improve the software.

    Please keep in mind:

    • This community is user driven. Be polite with other users.
    • We recommend purchasing a Chevereto license to participate in this community.
    • Purchase a Community Subscription to get even faster ticket response times.
  • Chevereto Support CLST

    Support response

    Support checklist

    • Got a Something went wrong message? Read this guide and provide the actual error. Do not skip this.
    • Confirm that the server meets the System Requirements
    • Check for any available Hotfix - your issue could be already reported/fixed
    • Read documentation - It will be required to Debug and understand Errors for a faster support response

Get "Can't get target upload source info" when uploading image use base64 by api

supersky07

Chevereto Noob
▶🚶‍Reproduction steps
  1. get my demo image base64
  2. encode it [CODE title="encoded base64"]ZGF0YTppbWFnZS9wbmc7YmFzZTY0LGlWQk9SdzBLR2dvQUFBQU5TVWhFVWdBQUFFWUFBQUJHQ0FZQUFBRUdLZElTQUFBQUFYTlNSMElBcnM0YzZRQUFFT05KUkVGVWVBSHRQQXQwbE1XNU0vTS9OMDhnSkFTMGlMZ2JvZ3UwQ2tMbEZSNHFCZHNEY3IzYWk2K2psbDZ0UlcvTmFkWEF0ZkVvWUxtdG50b2k0TDIxTDZvZXJTaDZVYlNLSVFFa0VnUkR3aXRKZ2ZMSUV4THkyUC85ei8xbWNjTy9tOTNON3JMWmVzNWx6dG44OC9qbW0yKytmK1o3emZ4QktDU3BPOXczaDFRaEVsclIvci9TaCszLzhhMUJvZldKbDVWeU53MzB4c3EycTJaM2JKRS9HYjZxRnJQS3hpZTkvc1pCOHpUVXNVWDZuR0EwbnJpS0dyYjZiQ1VzRGNOWDFrNGVQRS92OXZjT29IVU93ZXBjTStxRDJnTndxRzI1ZDFkdjRhdE1IeFpRaXEvV3QzdGFRd0dEeXZvTzk1cWdpdEFDY1B1L0E3TUxiWXU5VEQvMzlESXZ0QmQvOHBIeGM3SUcwNDhSVW5zWmlTbGFuUDljN1d0czZNSHpOSVZjZHFmeWNkYlQrOFB5SXgybEQ1Vm4xS2YxTnJMaFZQWENpQkVaeVdocFhlYTFRbWtLWWliREp2RWtxSTUxNkIwdXREY3IwOTBlZXZJdjhudzVqUzRldWtDN0MwK3Vpd29mRGtkdlhkZlB4OUdXWldNdlRLaTNKVGdUZGdSYVBZWWlCek9DdThBMEpoM3AwODgvVnpZRmVQMHY5WFpRYlQ5dzA5c0NjdjZhTndxTFZXZ0xKTFBTODJMZ2hST2xvbUJWMDErbDM4T0dmS2lscFA4cEJKQTBsWGl0MW5mRXBWMmJaV1I5NXFGOVNHU0FiQlE4cVE3REtya3QwSkU5YllJcmg4eFYveEgxdlRzN0pKSVBTMUVBRWZEdFpaanlFbGJHQmpjcy81ZlZMWUcydUovNmRuZUh1VFB5RG9vWm9WYnVhYXQ3M3kxRjY5Qm5tVHVCdFIzdVA3VnZFYys2TDZQWnlqYjNuYzQyWno0aWI5UUtkMVhIKzlKNFdNb0NCMUl5OXpZZDRXdjdMa0NHTENJbDh2VDZpWXFKUmpJZ3kwYnZSMExBMnBPU3drNkhmbDRRY1VOcVBtdStQTFBoQStmb3ZMTVF5SnNHUmNMVXZxSkIyZTUrQUdQY1J6RHhIUlVqQjh0SWFwSFNlVGUrN3VEeEFLS09wOFpSeGJpd0NWazlSdnFEc0VrQ0lFamQ3djZDMm1nUG55bElaMXZmRlJHbDZCajhDTVlPcUY3d3Zoa21qZHMzSXpUa2U5cWJ4TkJwRjNUMnA3YkhyeDNlRnp4NkRVNUhIL0kyeGV0ekY2bzEzQWNOZjhhbEtKaitLUDJaNHFXMW8vTHRUcUdSVHl1cSsyazRXTXRDdDBQOUJRYWNCOHB4d21MdnNTWW80L0J2eDZJb2JhN3lScHF6QitTQmlVejZ6dzJwVGxIeEhMenE1dEp4bzZNTkYzSHZxT1h1QSt3MSttQ3RZTjF1b0xXZ0hTS2tpRWdrWHBxV2Y5ZTVISm5IeU9qQk55dHQxczRJT0tKWGc4VlRSSGNYVUNaWG9rR0czWURST2dUYTJIYkpGcVd6TnJ3eHc2UmZ3bUlZS2JuSVlFVzExNlJOci85eEFDNmVaMExFK0xaNUh1VUZ1dnJNVzJrL3hKTDFoOERPRVRoa1ozNVArejVuNHpmNEcvb0tndjRJaS9pT29uVWtITmxpWVg0TUVxelZBVUlZUEVhWWlQdXkzN0Z0UENsYS93RnRBK04yZHN0UHZma0RPa2lxa2NlOFpnS21LOGY1WDBkTWROcndEdGtDQjZONXJseFUvMUYvbllKa25iSEQvUmdJeW5zTWk5NlZPYXVoSnJRenoyRy9odEtmK1dZZkJSTUsyMlBRZTRiY29vRzRwT3RDMjFqWnJ2VHMxM1Y2MEJTc3BSbmZQdHJNNnZ6RTBFb1AxVTM2NXpOdnk5dVFnTHhnYkc4OVV6cit1cHpTNnBNTUtEUXg2UldxN1VKaENFVm1hRjJnRE1iMHhwWk5kQ3lIc01ML2E3Zkd4dGQwZkJOUkt6eC9WelZhZS9ZOWVTSVY2UDlRUkhuTHBybTZacDFvTExsbVhnQkJzcDVNbGdQK1c5a3VOQ205SG0zTWFPOGFoSE1sR2YyTlNLNnNNYklMZS9QdjdKa2xjbGhuQmhNOEVSZ0dtNGV2UEJCa1hTU0RJTk9pSXpORWdqaXdCOUlFZ256ZCtDYTVsUjREVitwVkhrL2NZOEFnV0N0MzM1WTlYeE01R1NOVElWT0VxWWMrUzhiZ29UaHlWdFNjWU9QNUZaUUNlbGkzbHdsVDZqTVlYRnk3U2RmOUN2dVIwQUVpbGVHVlQ0VzJPeExhVFpHUSt1dHRlN1lkY1VsRzdNbDI1SHBObEwrTUNQRjFiWWo1TllXYndPa1M3MFo0QmJjRzJ0akN6SXdRQUFqQVJIc21wQ2pCUHRrQUxrc05zWEdRUHJKaHU5S0RoVG0wS3JJUEVJMlloRG5qSy9lODZKTFFVdDJ5bnhIejBHL0IraHBOdTlBbklLWFR1QVRNQjBaa3dzU3d6cTJieG1SbTU5aHJRWWpOZ1JqSjdjSzBJeFdzUHRHVU1ESGFkczlib29RWFFTU2lCZVJYc3lUZ2NhRFhFQWZtSC9iV2doQ0lQeVc2WnA0U0JiU290VnZJN1BwQTNnSHVMdCswUVp4czIzU3IzYVZyOFpOeHZrZENuR0hHdFNIYUU1UzNYSHVZMG1RSk5BZ3lPL2pwZVhmN0trd0RmVmVlVVFjK1hYd3BiczdBaHNGTTE1OTZJZU9zWXA0bmhBMEpIaGJDMmVZYllKeHZBMkYvYjN4a25JY09zbWRpUVFBTW9Mb1BUUktHcTEwRVhEL0xZUVFEUGMyR1NSN01sSWthQzY1UW1JUmVVd0JKeXpMdkYwREx0VXkrWkVnRWRTRXhmVVRwSGwrZ1BlWFAwOHV1dnFMMXlYRkZLUi80LzlXQU1hMFpNRTBma1NUODY0UTRBNDQ2dnU1d1RPUEV1SnVveVNMc0hBZ0NNRWRqb2drTUs4UWtzZ0RFeEpwaUpPWThPb2dGem5UTnFOc1dLM0ptOVRPQ1lrMjl4S2dWQmFNNVlqOFAyM1MwTksxK2ZEZ0VHQk1CZ3RqUHVuaXlMRng3b0U3bUNaS2UraklpUzlTS3E3NkRLRjVCZUxKZW5ITGs1VUEvdndRR3BiZFprbEFEQ05SY2ltbFpvREhjazlyVVlDcWd2MSs0dm9FNmkzQm5FSWNnaW1pdlo5eWp0VjZSdGZGS2VjRVNVYUR6VHg3enBjbGZabGNCUVV2QnljcklXMUZ6ZjZCek1wOU5KZVBIK3Q2M1B3TFhWelpWdENCbmtmWVQ3cHpHQkNWUGVJNityR1AwTDJuVmczeEF5RFZzWUxCUDdvTzQxK3ZKSklMaE9sbzZTcFo1dXQrMDZTQllEckxnd3B0YWZ5OHQ0UVhDcWR0R2V3aHo1RHYzazc4eGtlNU1QTUYzT012SnlLZnJtUTg0M1dLWU5PS0hvaGZCSmpvTGUvVU9nbUhWREoydHBUTXYwcGtNbTdZN3k4bkltNWhXQm84Q0FRQWJsWUhJR0FRU1l5OVJGYnBMTzhWWDlmVFlTMXpnYmpMM05oMnNmRW5TUmlXREFDZU9FU3RxcWpEQmV3U1lPSEFlRGg5d1IrNi9HUjhLRWlITS91RmRSZlUzc05oTHpxMTZpWGlGbU5QNU80U3lTbXZPT3BFa016OXNSYzFFdW42QzBOYlJMV2ZQc0pid0J0Nm5LZlJoTm9aL2E3TnpMV0JUQjJveHptUXRNTTRrYy9Cd3VOVENyc1ZEYjZLZEVOditMOVd3WjhzejYxOWljTDFDVDV4YWQxMjRqbjNxTUg0VDZtcjcxRHNxV1BEWlVleVRkUlVkK1NOVXNsOVE2aVVtcURaQ3dVYjJRamhqUHh5aE9haGFuZXRaR284cVlKM2pJZ1pjMlllWkFvdzFHUkFvU0xxaXREbXlDZXZXd1ZpSmNNS0IrbkFXTCtVVDRrRFVWZDhmeGhNLzgwNXlDYmlTQ1RITnNyZmtyYWk5cUlDa1g4NzBOMmk0ZG5CUmNKWk1La0Z0K00wSk1MeSswL2lFZDNVNDJGanI0aWFtdEJRUkZodzgrc0Q0QXFmUysyckEreUJ1VXdiaGt2ZGlKY0FKbHdneE5ydGtjZVgwenVOU2lIMExGM0cyQU1mR2NwaFdPUWVKTlI4M01ReXg2ck9QNng1aGIxY1Blb0FwVldabThodzVQZVMybm1jaHBwd2p1ckpYeGtxQUV5NmhCY3pXQzlwZFlCdTYzWWJTOFUxQ3R0bG9OSEhMWVNIL1dOTnBNUnpvUCs4Y0pOWjhRc1FFa0pzNzNXL0R5ZmRDREs5TFUybWJTYzA1R1RPT1ZnZmE0MzFlRkRIeERoYUEvL1RUbWZ3Tndxa2ZnRW56S1B3S21iWEpUcWRad3BDSDB4Ynd6eEN6eDFmRGVTZFR6Q2xQS1dVTTNYbTVTek5kZjVWY2VENEM4YVFiYUMvbnNwL2gwb1R5MXEyY2htVVR1NzRORm5BM2Z3c3ljSWtnb05Gd0FRS0JNYnBPbmw3M0kyQld5dlJjeWhpamJCODlFdHRrSHpCbE1DejFzb1pHYWU3Z0tyeFNFbEV4dS93QnpvdC9WVERGWWxuVVVIVlVQT0p1dkVFN3AxUktNdmFvS2pyVVpZclg1ODJxN1U3RjhrbEk0aVZDR0tiY0MxSUdYQWRRNk9ldHUzUG5EL2tDN1dOTTBTRXNxY0tlWVl4aFA2WmZkSnNLNlRKK3NlbFZ1a0hLNVNZb0Nqb3RwK0hDTEY3L3owVEdUcVJQU2hqamw5YVVqb0luSWh6YWd3NHJsOE1pR1FNbnhCRnBaZ3dER1g5OTA1bzBHV0FQK0NFcEhSMnhRNUliVXJhVlF1bHVMUEcrbENHUWg3cjFDekZ0Snd6VHZkQldQR0pWYlVJcXpva3JrZncvalRHTTJOYVNxNGZEOWJLVm9JSVdRbkVRWlVzTDQyWjRiQ0NtOFhUdTZzTmRpVXpxVXA5TEhFZzlCNUs2bGJUeU1lT0pZTjFvR0xGZmVrekdsSG1JV2xpSzliWnJ6dEhqeWNESGNNUVZDT2x2VUlxdGFYQ2EvU3QyTXphVmlZRDZzbm51QUl6NTlXU01reGtzVkFyWGhZcXhSWGJEcmNLa3JrdzRiTEF0YWkrRTZGT3hQa0F2b2Q4VkF4cUNvTEtaQk04cWkrdkdETmdlRUJVZzFmTE1JeFZOVDNobml5SytFUzZXaGRmTlRvNUd5VU84bUVDRTQvVmhLMnVxMWUwZWRqa3Q3a1RCVDBNenl5eWdMK3F5RG1MTUNmQmw4aXo1Y1FKdU1pL2dIRGg1UVdndi9BYWRSc2FPd29TdlhrRWNjanBCNUVtbWppOG1zWHRpcG0zdkJ4d0plYzM2dG9KNzBkREdQNkM5QllqdUFTeGdSRm9tL1lkdG9WOEkwK3JYT3BubFp3eXRtaUJvU3VmcmtvZ1hNV0RUUXA4WW5QbEV4N3V1UStwcFBBeUVtOGdKYU1DQzloZkRySGo2TnIvaitwajNFYS9NbzU1Qms2MDJjNng2ZzYyalg0b2lXb09xUEd0ODVmVDV0Qm4xeFF3blR6OGNuNjRwNTZva21SVENDVUsxZExreHVYVnR4clBncSt3bTRMdUlPZWZmTXRzYW5UOGZCNzRNUFdCcDF2d1J2N3J3OVVBOHhLVWE5dlN5c1JNRmpONFRDYzVYVFJOUkdTRU41dElPbDZYdEl5S0NBTkxESXg3MHZhV2Y0dmE1WE9ReHVPRStWdHBhUDQrb0x0OExzRklLRlI4OUk0MFNaeld0Uy84TGVDZkY3QUNVK1RLTUxlekhYSmNldi9sT3IwRUNPZGk4Zk94VnFaNWt2T09CMnpGTFFHZzNYTm5NWi9OaERyeC9QdkJITTZsL2Zwa3VzcVo1WGZxalloNlpwU20yQmJMd1ptVzJleEY0L0hnNmd3WloxTnIya1duQXdaZ25FQUlJUndoRERxRUJGekx4bGVIYXYwNTFJS3M5TEl3UkxiRmpVVXFvRnhIN0RJakFiZ3p3aE9BcmlXWGhlK0Fpa2lYRFZzcjBXbmVqZHJJWUFQd1hiOE1oekJBNUZpOTVZZGh6K3o4TzEvNTFxc3M3VXZnN0NHTzh5eHpTY0lrZENlc21hckVPcDkrdk5OSGxjaHJKaGxYVElSSDhLcDgrODhodWRZZG5nV1hiNzBMRm1zRjMrbmFLUTh3clRxM0xHaVZuV3NWZ0prd0N0SEFCRUo4RTdyN1doanZYWGZuY3NZUXVVSVVqYmlEcjhKdHZzanNnQ3c0K1daZ3psT09Yd2d0ZkNKb3hEK3A4bU9MeWMyZklMeTY3MThlaFc5UmRva0RjaGtiaHMxMnVDRTg1Zk1xdmxlU3BkWnRCdjBzYWQzSTF6K09mSUovWUNKK3JJdFdnelhBSi9lODJvU1pZbHcvQlRaR29oNklET2NtTHdYMzFxa1BzOUxrVXZoVFlDVnRsbVdGUUdZNHpGK1pLK0Q3WU4reHFoUllheGUrMVk3NHk0QjREQkkvUlQwZkpKaStDZVUrbmcwazJHZ3cxSGdJQ1NxTEVnUnpqMmJuR3hkb3hEQWNFeXBsMWxWQ0NGZFBKSTlvSWNsaURBUHdtMDdMTCtPTU5sZnp0cU0vdG9sN0dPRWZDcy94YmhjbVFpNUlqNEFqNHQxeitxbG9Xa2t4cVdKTEpRU2ZOc2VURmFmVzdBTzc3c2NDR1pVd3NIZnVEQVJXSklLWmJBYmM3K2dOTnFCMnNWUVNmakNUVU41Wk95V1VNcGV5aURSd0ZuaC9hZitlaHp5S05oYXpZWU5qWFF5eHg4RFROSkR1cXNaRndDZW9TQjc3aVFIU3pNQVZzWXJjRjA4ek1hV0I1ZTBGdFdmRDkyUmUvRVdwMmxjYng2Zk5Ba1BsUFkwemo0OWQ0T1k1OEl2SjRtUE1TQnlNb0RTeFZuMjdYZ3BxZkE3RVgvOWVDQXpINWFEaFR4aGgxVzhGOFhxTERRRDRmYWQrWTFXRHh2a01RNU10bXZsZTR4SHdjdUNOMk9GL3UvcFoyb3ppTDUybStvYUVHVjFGZGVUajRaTmVGZHlLU1BRcmdnMmprVTV5SVh6RXQ2NGZuMmpYUWh0aC81VGpTVUdDbkFBaDF0Zmt1RStDYThuSk93cStBcC90Z0pQaGsxNmVNTWVEQ3JrWGdlRUY0OHU1di9IdlBPS3VMZkJmaXdqYTczaHFhbUhNSFBtK24yWUxtWkM1c3VSKytJNWlpOThDRmNCdXZEWVVkcUhKZnFnWnFKTUNybEhudWcyOW9YMkZCTC9CWFBoT3l5RjBuZml0aTF4QzhHRTVjSnJEZFF5eTBvK3NzZnUzeUgvbStRUlh5R3NnZ04yd3B3ekxzdWE2WkRaOE9JSGxCcUZQS0dEWXlmUU54NmpEUDB4eVBmaVpJV0dDeElGV0JLN2tZZFVJZWcwOEgveUVFRmpKUVp1bjJPUWl6bHNBVkxmOTE0Q0RLQjdpUWNzYUV6b2QrVmpoS004MXhFRlM2d29aSU55ZWlCbDRVcXZIRWc0MmhzS2tzL3grNjFnYUlLM0F0MGdBQUFBQkpSVTVFcmtKZ2dnPT0=[/CODE]
  3. post it to the api with key and format
😢Unexpected result

Response status is 400, and the error text is "Can't get target upload source info"

📃Error log message

chevereto_1 | [Sun Mar 01 14:47:29.960338 2020] [php7:notice] [pid 17] [client 172.19.0.1:51356] Can't get target upload source info
chevereto_1 | 172.19.0.1 - - [01/Mar/2020:14:47:29 +0000] "POST /api/1/upload HTTP/1.0" 400 607 "-" "-"
 
Your base64 string is corrupted. You can check it here: https://codebeautify.org/base64-to-image-converter


Thank you for reply. The base64 code above is encoded.

I have read the source code, the code will decode it. And then write it to the file. So I give the encoded one.

Now I decode the encoded base64 code by `base64_decode` function, and get the code below.

[CODE title="base64 code"][/CODE]
 
Your base64 string is corrupted. You can check it here: https://codebeautify.org/base64-to-image-converter

here is the code in 'routes.api.php'

[CODE title="api code"]// From _GET source should be urlencoded base64
if(!G\timing_safe_compare(base64_encode(base64_decode($source)), $source)){
throw new Exception('Invalid base64 string.', 120);
}

// Set the API temp file
$api_temp_file = @tempnam(sys_get_temp_dir(), 'chvtemp');

if(!$api_temp_file or !@is_writable($api_temp_file)) {
throw new UploadException("Can't get a tempnam.", 200);
}

$fh = fopen($api_temp_file, 'w');
stream_filter_append($fh, 'convert.base64-decode', STREAM_FILTER_WRITE);
if(!@fwrite($fh, $source)) {
throw new Exception('Invalid base64 string.', 130);
} else {
// Since all the validations works with $_FILES, we're going to emulate it.
$source = array(
'name' => G\random_string(12).'.jpg',
'type' => 'image/jpeg',
'tmp_name' => $api_temp_file,
'error' => 'UPLOAD_ERR_OK',
'size' => '1'
);
}[/CODE]

If I pass the original base64 code, it will throw the exception ` throw new Exception('Invalid base64 string.', 120);`
 
Thank you for reply. The base64 code above is encoded.

I have read the source code, the code will decode it. And then write it to the file. So I give the encoded one.

Now I decode the encoded base64 code by `base64_decode` function, and get the code below.

[CODE title="base64 code"][/CODE]

@Rodolfo

is this a wrong base64 string?
 
Back
Top