当我在base64中加密时,加密的值是正确的,我可以看到我想要的结果的正常值,当我使用函数解码base64(base64_decode)时出现问题。
在结果中,最后出现 ÃÜ 或 7 之类的字符。我设置了两种情况以及我正在使用的所有代码
请问你能帮帮我吗?我将页面中隐含的所有代码发送给您...
==================================================== =================================
情况1:
细绳:
CIF_NIF::multiline++++1--2++aaaa--bbbbbb
base64_encoded:
Q0lGX05JRjo6bXVsdGlsaW5lKysrKzEtLTIrK2FhYWEtLWJiYmJiYg==
base64_decoded:
CIF_NIF::multiline++++1--2++aaaa--bbbbbb ÃÜ
==================================================== =================================
案例二:
细绳:
VALOR::varchar++bool
base64_encoded:
VkFMT1I6OnZhcmNoYXIrK2Jvb2w=
base64_decoded:
VALOR::varchar++bool7
==================================================== =================================
AJAX 调用:
$.ajax({
url: _ajax_url,
type: "GET",
async: true,
data: {
info: data
},
contentType: "application/json; charset=utf-8",
//dataType: "jsonp",
success: function (data, textStatus) {....
}
});
==================================================== =================================
PHP代码:
编码函数...
return base64_encode($res);
当我在资源管理器中 echo de return 时,结果是我之前设置的值。
解码功能...
return base64_encode($res);
当我在资源管理器中 echo de return 时,结果是我之前设置的值。
$string_b64 以 base64 值编码,您可以在之前设置实际值...
$string = base64_decode($string_b64);
==================================================== =================================我添加你我的php页面的标题:
header("Cache-Control: no-cache, must-revalidate"); //HTTP 1.1
header("Pragma: no-cache"); //HTTP 1.0
header("Expires: Sat, 26 Jul 1997 05:00:00 GMT"); // Date in the past
header('Content-Type: text/html; charset=ISO-8859-1');
我不知道它是否暗示 base64_de 代码中的罕见行为。
功能代码为:
public static function encrypting($array) {
$res = "";
$delimiter = array("||", "::", "++", "--");
if (is_array($array)) {
$gen = "";
//echo implode(">", $array[0]);
//echo count($array);
foreach($array as $clave = > $valor) {
$aux = [];
if ($gen != "") $gen. = $delimiter[0];
foreach($valor as $v) {
if (is_array($v)) {
array_push($aux, implode($delimiter[3], $v));
} else {
array_push($aux, $v);
}
}
$gen = "$clave$delimiter[1]".implode($delimiter[2], $aux);
}
$res = $gen;
} else $res = $array;
return base64_encode($res);
//return $res;
}
public static function decrypting($string_b64) {
$res = [];
$string = imap_base64($string_b64);
echo $string;
$delimiter = array("||", "::", "++", "--");
$pas1 = explode($delimiter[0], $string);
foreach($pas1 as $valor1) {
$i = 0;
$pas2 = explode($delimiter[1], $valor1);
$aux = [];
$pas3 = explode($delimiter[2], $pas2[1]);
foreach($pas3 as $valor2) {
if (strpos($valor2, $delimiter[3]) > 0) $aux[] = explode($delimiter[3], $valor2);
else $aux[] = trim($valor2);
}
$res[$pas2[0]] = $aux;
}
return $res;
}
==================================================== ================================= 使用示例:
$personalitzats1 = array("CIF_NIF" => array(false, "", "Aquest Camp es personalitzat...."));
$value = encrypting($personalitzats1)
decrypting($value);
问题在于解密时我回显了 base64_decode 之后的值,并且是字符出现的时候。
我已将页面保存为ISO : cp1252编码(标准)我不认为这是问题所在。
如果我使用像http://www.opinionatedgeek.com/dotnet/tools/base64decode/这样的外部网页并在 textarea 中设置值 Q0lGX05JRjo6bXVsdGlsaW5lKysrKzEtLTIrK2FhYWEtLWJiYmJiYg== 结果是正确的。