#php #url #decode #encode
#php #url #декодировать #кодировать
Вопрос:
Я разрабатываю проект, в котором мне нужно закодировать идентификатор, который я передаю, чтобы мой идентификатор не показывался пользователю. Итак, я разработал это, но я получаю сообщение об ошибке «Фатальная ошибка: невозможно повторно объявить encryptString() (ранее объявленную)» это отображается, когда я использую его с циклом, но без цикла он работает очень хорошо. Я вставляю коды в надежде, что вы сможете обнаружить в них какие-либо ошибки. Вот мой код
<div id="cars">
<?php
$sl_rp = "select * from $tb_products where status='active' order by id DESC";
$res_rp = mysqli_query($conn,$sl_rp);
if($res_rp){
$nums_rp = mysqli_num_rows($res_rp);
if($nums_rp > 0){
$i=0;
while($rows_rp = mysqli_fetch_assoc($res_rp)){
// $productid = $rows_rp['id'].'/'.'asdfghjklqweretyuiophjgbcfhdgvsf';
// $t_encode = base64_encode($productid);
$id = $rows_rp['id'];
function encryptString($plaintext, $password, $encoding = null) {
$iv = openssl_random_pseudo_bytes(16);
$ciphertext = openssl_encrypt($plaintext, "AES-256-CBC", hash('sha256', $password, true), OPENSSL_RAW_DATA, $iv);
$hmac = hash_hmac('sha256', $ciphertext.$iv, hash('sha256', $password, true), true);
return $encoding == "hex" ? bin2hex($iv.$hmac.$ciphertext) : ($encoding == "base64" ? base64_encode($iv.$hmac.$ciphertext) : $iv.$hmac.$ciphertext);
}
function decryptString($ciphertext, $password, $encoding = null) {
$ciphertext = $encoding == "hex" ? hex2bin($ciphertext) : ($encoding == "base64" ? base64_decode($ciphertext) : $ciphertext);
if (!hash_equals(hash_hmac('sha256', substr($ciphertext, 48).substr($ciphertext, 0, 16), hash('sha256', $password, true), true), substr($ciphertext, 16, 32))) return null;
return openssl_decrypt(substr($ciphertext, 48), "AES-256-CBC", hash('sha256', $password, true), OPENSSL_RAW_DATA, substr($ciphertext, 0, 16));
}
echo $enc = encryptString($id, "myPassword", "hex");
$i ;
?>
<div class="item">
<div class="teaser <?php if($i % 3 == 0){ echo "card-3"; }else if($i % 2 == 0){ echo "card-2"; }else{ echo "card-1"; } ?> transp with_padding big-padding margin_0">
<div class="media xxs-media-left">
<div class="media-left media-middle">
<div class="teaser_icon size_small big_wrapper">
<img src="upload_products/<?php echo $rows_rp['p_upload']; ?>" class="img-responsive img-center mar-top-5">
</div>
</div>
<div class="media-body media-middle">
<h4 class="text-white"><?php echo $rows_rp['pname']; ?></h4>
<a href="fill-details.php?product=<?php echo $enc; ?>" class="btn btn-default text-capitalize card_buttons">Order Now</a>
</div>
</div>
</div>
</div>
<?php
}
}
}
?>
</div>
Комментарии:
1. Объявите функцию вне цикла.
2. @ceejayoz хорошо, я пытаюсь сделать
3. Спасибо @ceejayoz, это сработало для меня, но могу я попросить вас еще об одной помощи??? Будет ли этот способ шифрования работать или он безопасен в использовании.
4. Я не знаю, какова цель кода, почему вы хотите зашифровать эти данные и т.д., так что на этот вопрос трудно ответить.
5. Я просто не хочу показывать значение id пользователю для этого
Ответ №1:
Сначала я хотел бы сказать, что предложение, предоставленное @ceejayoz, является правильным, и, пожалуйста, используйте функцию в вашем файле, где, как и при использовании приведенных ниже кодов подключения, вы не столкнетесь с какими-либо проблемами, это безопасный метод, но ничто не безопасно в Интернете, хотя вы можете использоватьэто.