普雷斯塔商店注册时出错


Presta Shop errors on registration

最近我为我的客户进行了SEO优化,我不得不在服务器上更改一些内容,例如使用PHP 7和Presta Shop管理面板来启用缓存和SEO链接。我不使用 Presta Shop,也不熟悉它,但其中一些更改破坏了代码中的某些内容。当新用户尝试注册时,它会收到该错误:

Fatal error: Uncaught Error: Access to undeclared static property: Validate::$data in /home/unikalna/public_html/classes/ObjectModel.php:1032 Stack trace: #0 /home/unikalna/public_html/controllers/front/AuthController.php(406): ObjectModelCore->validateController() #1 /home/unikalna/public_html/controllers/front/AuthController.php(252): AuthControllerCore->processSubmitAccount() #2 /home/unikalna/public_html/classes/controller/Controller.php(171): AuthControllerCore->postProcess() #3 /home/unikalna/public_html/classes/Dispatcher.php(373): ControllerCore->run() #4 /home/unikalna/public_html/index.php(28): DispatcherCore->dispatch() #5 {main} thrown in /home/unikalna/public_html/classes/ObjectModel.php on line 1032

而且,如果它已经注册并试图购买东西。

版本 :P restaShop™ 1.6.0.6

已解决:Presta Shop 1.6 不适用于 PHP 7

/home/unikalna/public_html/classes/ObjectModel.php:1032

旧代码

if (!empty($value) || $value === '0' || ($field == 'postcode' && $value == '0')) {
    if (isset($data['validate']) && !Validate::$data['validate']($value) && (!empty($value) || $data['required'])) {
                $errors[$field] = '<b>'.self::displayFieldName($field, get_class($this), $htmlentities).'</b> '.Tools::displayError('is invalid.');
            } else {
                if (isset($data['copy_post']) && !$data['copy_post']) {
                    continue;
                }
                if ($field == 'passwd') {
                    if ($value = Tools::getValue($field)) {
                        $this->{$field} = Tools::encrypt($value);
                    }
                } else {
                    $this->{$field} = $value;
                }
            }
        }

替换为以下代码块

新代码

if (!empty($value) || $value === '0' || ($field == 'postcode' && $value == '0')) {
   if (isset($data['validate']) && !call_user_func('Validate::'.$data['validate'],$value) && (!empty($value) || $data['required'])) {
    $errors[$field] = '<b>'.self::displayFieldName($field, get_class($this), $htmlentities).'</b> '.Tools::displayError('is invalid.');
            } else {
                if (isset($data['copy_post']) && !$data['copy_post']) {
                    continue;
                }
                if ($field == 'passwd') {
                    if ($value = Tools::getValue($field)) {
                        $this->{$field} = Tools::encrypt($value);
                    }
                } else {
                    $this->{$field} = $value;
                }
            }
        }