Как изменить URL-адрес encode с помощью php?

#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, является правильным, и, пожалуйста, используйте функцию в вашем файле, где, как и при использовании приведенных ниже кодов подключения, вы не столкнетесь с какими-либо проблемами, это безопасный метод, но ничто не безопасно в Интернете, хотя вы можете использоватьэто.