У меня API Opencart 1.5.x, подключенный к мобильному приложению, мобильное приложение возвращает ошибку
Fatal error: Uncaught Error: Call to a member function get()
on null in /var/www/vhosts/example.com/httpdocs/api/wk_index.php:109
Stack trace:
0 [internal function]: error_handler(2, 'Cannot modify h...', '/var/www/vhosts...', 4389, Array)
1 /var/www/vhosts/example.com/httpdocs/api/lib/nusoap.php(4389): header('Server: NuSOAP ...', false)
2 /var/www/vhosts/example.com/httpdocs/api/lib/nusoap.php(3829): nusoap_server->send_response()
3 /var/www/vhosts/example.com/httpdocs/api/appserver.php(1776): nusoap_server->service('<?xml version="...')
4 {main} thrown in <b>/var/www/vhosts/example.com/httpdocs/api/wk_index.php</b> on line
109
Error example=NSXMLParserErrorexample Code=76 "(null)"
UserInfo={NSXMLParserErrorColumn=8, NSXMLParserErrorLineNumber=137,
NSXMLParserErrorMessage=Opening and ending tag mismatch: link line 0
and head }
Строка 109 в wk_index.php
if ($config->get('config_error_display')) {
echo '<b>' . $error . '</b>: ' . $errstr . ' in <b>' . $errfile . '</b> on line <b>' . $errline . '</b>';
}
Полный wk_index.Информация о php-файле
<?php
// Version
define('VERSION', '1.5.2.1');
// Configuration
require_once('../config.php');
require_once(DIR_SYSTEM . 'library/pagecache.php'); //PAGECACHE
$pagecache = new PageCache(); //PAGECACHE
if ($pagecache->ServeFromCache()) { //PAGECACHE
// exit here if we served this page from the cache //PAGECACHE
return; //PAGECACHE
} //PAGECACHE
// Install
// Startup
require_once(DIR_SYSTEM . 'startup.php');
// Application Classes
require_once(DIR_SYSTEM . 'library/customer.php');
require_once(DIR_SYSTEM . 'library/affiliate.php');
require_once(DIR_SYSTEM . 'library/currency.php');
require_once(DIR_SYSTEM . 'library/tax.php');
require_once(DIR_SYSTEM . 'library/weight.php');
require_once(DIR_SYSTEM . 'library/length.php');
require_once(DIR_SYSTEM . 'library/cart.php');
require_once(DIR_SYSTEM . 'library/user.php');
//to detect admin
//require_once($vqmod->modCheck(DIR_SYSTEM . 'library/user.php'));
// Registry
$registry = new Registry();
// Loader
$loader = new Loader($registry);
$registry->set('load', $loader);
// Config
$config = new Config();
$registry->set('config', $config);
// Database
$db = new DB(DB_DRIVER, DB_HOSTNAME, DB_USERNAME, DB_PASSWORD, DB_DATABASE);
$registry->set('db', $db);
// Store
if (isset($_SERVER['HTTPS']) && (($_SERVER['HTTPS'] == 'on') || ($_SERVER['HTTPS'] == '1'))) {
$store_query = $db->query("SELECT * FROM " . DB_PREFIX . "store WHERE REPLACE(`ssl`, 'www.', '') = '" . $db->escape('https://' . str_replace('www.', '', $_SERVER['HTTP_HOST']) . rtrim(dirname($_SERVER['PHP_SELF']), '/.\\') . '/') . "'");
} else {
$store_query = $db->query("SELECT * FROM " . DB_PREFIX . "store WHERE REPLACE(`url`, 'www.', '') = '" . $db->escape('http://' . str_replace('www.', '', $_SERVER['HTTP_HOST']) . rtrim(dirname($_SERVER['PHP_SELF']), '/.\\') . '/') . "'");
}
if ($store_query->num_rows) {
$config->set('config_store_id', $store_query->row['store_id']);
} else {
$config->set('config_store_id', 0);
}
// Settings
//$query = $db->query("SELECT * FROM " . DB_PREFIX . "setting WHERE store_id = '0' OR store_id = '" . (int)$config->get('config_store_id') . "' ORDER BY store_id ASC");
$query = $db->query("SELECT * FROM " . DB_PREFIX . "setting WHERE store_id = '0' ORDER BY store_id ASC");
foreach ($query->rows as $setting) {
if (!$setting['serialized']) {
$config->set($setting['key'], $setting['value']);
} else {
$config->set($setting['key'], unserialize($setting['value']));
}
}
if (!$store_query->num_rows) {
$config->set('config_url', HTTP_SERVER);
$config->set('config_ssl', HTTPS_SERVER);
}
// Url
$url = new Url($config->get('config_url'), $config->get('config_use_ssl') ? $config->get('config_ssl') : $config->get('config_url'));
$registry->set('url', $url);
// Log
$log = new Log($config->get('config_error_filename'));
$registry->set('log', $log);
function error_handler($errno, $errstr, $errfile, $errline) {
global $log, $config;
switch ($errno) {
case E_NOTICE:
case E_USER_NOTICE:
$error = 'Notice';
break;
case E_WARNING:
case E_USER_WARNING:
$error = 'Warning';
break;
case E_ERROR:
case E_USER_ERROR:
$error = 'Fatal Error';
break;
default:
$error = 'Unknown';
break;
}
if ($config->get('config_error_display')) {
echo '<b>' . $error . '</b>: ' . $errstr . ' in <b>' . $errfile . '</b> on line <b>' . $errline . '</b>';
}
if ($config->get('config_error_log')) {
$log->write('PHP ' . $error . ': ' . $errstr . ' in ' . $errfile . ' on line ' . $errline);
}
return true;
}
// Error Handler
set_error_handler('error_handler');
// Request
$request = new Request();
$registry->set('request', $request);
// Response
$response = new Response();
$response->addHeader('Content-Type: text/html; charset=utf-8');
$response->setCompression($config->get('config_compression'));
$registry->set('response', $response);
// Cache
$cache = new Cache();
$registry->set('cache', $cache);
// Session
$session = new Session();
$registry->set('session', $session);
// Language Detection
$languages = array();
$query = $db->query("SELECT * FROM " . DB_PREFIX . "language WHERE status = '1'");
foreach ($query->rows as $result) {
$languages[$result['code']] = $result;
}
$detect = '';
if (isset($request->server['HTTP_ACCEPT_LANGUAGE']) && ($request->server['HTTP_ACCEPT_LANGUAGE'])) {
$browser_languages = explode(',', $request->server['HTTP_ACCEPT_LANGUAGE']);
foreach ($browser_languages as $browser_language) {
foreach ($languages as $key => $value) {
if ($value['status']) {
$locale = explode(',', $value['locale']);
if (in_array($browser_language, $locale)) {
$detect = $key;
}
}
}
}
}
if (isset($session->data['language']) && array_key_exists($session->data['language'], $languages) && $languages[$session->data['language']]['status']) {
$code = $session->data['language'];
} elseif (isset($request->cookie['language']) && array_key_exists($request->cookie['language'], $languages) && $languages[$request->cookie['language']]['status']) {
$code = $request->cookie['language'];
} elseif ($detect) {
$code = $detect;
} else {
$code = $config->get('config_language');
}
if (!isset($session->data['language']) || $session->data['language'] != $code) {
$session->data['language'] = $code;
}
if (!isset($request->cookie['language']) || $request->cookie['language'] != $code) {
setcookie('language', $code, time() + 60 * 60 * 24 * 30, '/', $request->server['HTTP_HOST']);
}
$config->set('config_language_id', $languages[$code]['language_id']);
$config->set('config_language', $languages[$code]['code']);
// Language
$language = new Language($languages[$code]['directory']);
$language->load($languages[$code]['directory']);
$registry->set('language', $language);
// Document
$registry->set('document', new Document());
// Customer
$registry->set('customer', new Customer($registry));
// Affiliate
$registry->set('affiliate', new Affiliate($registry));
//user
$registry->set('user', new User($registry));
if (isset($request->get['tracking']) && !isset($request->cookie['tracking'])) {
setcookie('tracking', $request->get['tracking'], time() + 3600 * 24 * 1000, '/');
}
// Currency
$registry->set('currency', new Currency($registry));
// Tax
$registry->set('tax', new Tax($registry));
// Weight
$registry->set('weight', new Weight($registry));
// Length
$registry->set('length', new Length($registry));
// Cart
$registry->set('cart', new Cart($registry));
// Encryption
$registry->set('encryption', new Encryption($config->get('config_encryption')));
// Front Controller
$controller = new Front($registry);
// Maintenance Mode
$controller->addPreAction(new Action('common/maintenance'));
// SEO URL's
$controller->addPreAction(new Action('common/seo_url'));
// Router
if (isset($request->get['route'])) {
$action = new Action($request->get['route']);
} else {
$action = new Action('common/home');
}
// Dispatch
$controller->dispatch($action, new Action('error/not_found'));
// Output
$response->output();
if ($pagecache->OkToCache()) { //PAGECACHE
$pagecache->CachePage($response); //PAGECACHE
} //PAGECACHE
?>
И это полный файл config.php
<?php
// HTTP
define('HTTP_SERVER', 'http://www.example.com/');
//define('HTTP_IMAGE', 'http://www.example.com/image/');
define('HTTP_IMAGE', 'http://wwwexamplecom-cdn.com/image/');
define('HTTP_ADMIN', 'http://www.example.com/admin/');
define('HTTPS_CATALOG', 'https://www.example.com/');
define('HTTP_CATALOG', 'http://www.example.com/');
// HTTPS
define('HTTPS_SERVER', 'https://www.example.com/');
define('HTTPS_IMAGE', 'https://www.example.com/image/');
// DIR
define('DIR_APPLICATION', '/var/www/vhosts/example.com/httpdocs/catalog/');
define('DIR_SYSTEM', '/var/www/vhosts/example.com/httpdocs/system/');
define('DIR_DATABASE', '/var/www/vhosts/example.com/httpdocs/system/database/');
define('DIR_LANGUAGE', '/var/www/vhosts/example.com/httpdocs/catalog/language/');
define('DIR_TEMPLATE', '/var/www/vhosts/example.com/httpdocs/catalog/view/theme/');
//define('DIR_DEFAULT_TEMPLATE', '/var/www/vhosts/example.com/httpdocs/catalog/view/theme/');
define('DIR_CONFIG', '/var/www/vhosts/example.com/httpdocs/system/config/');
define('DIR_IMAGE', '/var/www/vhosts/example.com/httpdocs/image/');
define('DIR_CACHE', '/var/www/vhosts/example.com/httpdocs/system/cache/');
define('DIR_DOWNLOAD', '/var/www/vhosts/example.com/httpdocs/download/');
define('DIR_LOGS', '/var/www/vhosts/example.com/httpdocs/system/logs/');
// DB
define('DB_DRIVER', 'mysqliz');
define('DB_HOSTNAME', 'IP Address');
define('DB_USERNAME', 'USER');
define('DB_PASSWORD', 'PASSWORD');
define('DB_DATABASE', 'example');
define('DB_PREFIX', '');
?>
Я испробовал все возможные способы, но пока они решают мои проблемы.Приложение не работает, и я застрял с ошибкой на 10 дней, любая помощь, пожалуйста.
Спасибо заранее!
РЕДАКТИРОВАТЬ: Предполагаемая причина проблемы: После глубокогокопаясь, и в течение нескольких недель я обнаружил, что сервер получает запрос SOAP 1.2 / 2.0, в то время как мне нужно, чтобы он был принудительно настроен на SOAP 1.1
Так что либо я должен изменить код, чтобы принимать SOAP 1.2 / 2.0, либочтобы запрос был отправлен как SOAP 1.1, нужна помощь?
Редактировать: 05/07/2018
Влияет ли PHP-FPM на ответ SOAP?Для решения этой проблемы необходима ваша помощь
Конфигурации cURL:
curl
Поддержка cURL включена
Информация о cURL 7.35.0
Возраст 3
Функции
AsynchDNS Да
CharConv Нет
Отладка Нет
GSS-согласование Да
IDN Да
IPv6 Да
krb4 Нет
Большой файл Да
libz Да
NTLM Да
NTLMWBДа
SPNEGO Нет
SSL Да
SSPI Нет
TLS-SRP Да
HTTP2 Нет
Протоколы dict, file, ftp, ftps, gopher, http, https, imap, imaps,ldap, ldaps, pop3, pop3s, rtmp, rtsp, smtp, smtps, telnet, tftp
Хост x86_64-pc-linux-gnu
Версия SSL OpenSSL / 1.0.1f
ZLib Версия 1.2.8