网站开发 · 2025年4月23日

解决ecshop虚拟卡出现星号问题

在所有的ecshop的版本当中,网站搬家或者使用LINUX主机,虚拟物品卡号密码全部变成***很突然。没有进行任何后台改动。添加新产品的卡密也是如此
解决ecshop虚拟卡出现星号问题插图

分析ecshop,我们发现


发现是/admin/virtual_card.php里 有关于星号 看程序后 发现是由include/lib_code.php关于加密解密函数控制的。


virtual_card.php 控制的
代码
如下

  1.   foreach ($all AS $key => $row)
  2.     {
  3.         if ($row[‘crc32’] == 0 || $row[‘crc32’] == crc32(AUTH_KEY))
  4.         {
  5.             $row[‘card_sn’]       = decrypt($row[‘card_sn’]);
  6.             $row[‘card_password’] = decrypt($row[‘card_password’]);
  7.         }
  8.         elseif ($row[‘crc32’] == crc32(OLD_AUTH_KEY))
  9.         {
  10.             $row[‘card_sn’]       = decrypt($row[‘card_sn’], OLD_AUTH_KEY);
  11.             $row[‘card_password’] = decrypt($row[‘card_password’], OLD_AUTH_KEY);
  12.         }
  13.         else
  14.         {
  15.             $row[‘card_sn’]       = ‘***’;
  16.             $row[‘card_password’] = ‘***’;
  17.         }

复制代码
深入分析后发现

  1. $row[‘crc32’] == 0 || $row[‘crc32’] == crc32(AUTH_KEY))

复制代码
以及

  1. ($row[‘crc32’] == crc32(OLD_AUTH_KEY))

复制代码
主要是判断
数据库
中得crc32字段和经过crc32加密的字符串是否一致


但是发现


数据
库中的crc32字符串和crc32加密的字符串
 完全不一样
所以导致了 出现卡号和卡密为星号的问题


比如我们加密字符串
设置
的是456  数据库中的crc32 显示为 2147483647  而
我们
直接代码crc32出来的值为 2980627313 所以导致了 卡号显示为三个***

其实该问题以linux 时间戳问题引起,解决办法很简单


UPDATE virtual_card SET crc32 = ‘0’