Я использую массив, который я кодирую в json, а не в BASE64, сохраняю его в Cookie, чтобы позже получить.
Фактическая строка:
{"insert":0,"delete":0}
В PHP у меня есть:
$Sync = json_encode($update);
setcookie('Sync',strtr(base64_encode($Sync), '+/', '-_'), 0, "/");
Cookie хранится как:
eyJpbnNlcnQiOjEsImRlbGV0ZSI6MH0%3D
Этот последний «% 3D» должен быть «=», чтобы заполнить оставшуюся часть base64, поэтому nad возвращает странные символы, но я не могу понять это правильно. Есть идеи?
заранее спасибо
В документах на php.net (http://php.net/manual/en/function.base64-encode.php#103849) верхний комментарий содержит две функции, которые должны вам помочь (также как и в вашей реализации :))
Для тех, кто заинтересован в кодировке варианта base64url, вы можете использовать эту пару функций:
<?php function base64url_encode($data) { return rtrim(strtr(base64_encode($data), '+/', '-_'), '='); } function base64url_decode($data) { return base64_decode(str_pad(strtr($data, '-_', '+/'), strlen($data) % 4, '=', STR_PAD_RIGHT)); } ?>
В вашей реализации, похоже, вам нужно обернуть
strtr(base64_encode($Sync), '+/', '-_'), 0, "/")
с rtrim
, вот так:
rtrim(strtr(base64_encode($Sync), '+/', '-_'), 0, "/"), '=')
Результаты: https://3v4l.org/5D1Mk
Других решений пока нет …