У меня проблема с автозагрузкой PHP с определенным классом, где постоянно говорится, что он не найден.
Ошибка:
Warning: require_once(Models/BaseModel.php): failed to open stream: No such file or directory in /var/www/html/icompare/init.php on line 29
Fatal error: require_once(): Failed opening required 'Models/BaseModel.php' (include_path='.:/usr/share/php:/var/www/html/icompare/lib') in /var/www/html/icompare/init.php on line 29
Как моя автозагрузка запускается в init.php
:
set_include_path(get_include_path().PATH_SEPARATOR.APP_ROOT_PATH.DIRECTORY_SEPARATOR.'lib');
spl_autoload_extensions(".php");
spl_autoload_register(function($className){
$className = str_replace('\\', DIRECTORY_SEPARATOR, $className);
$file = $className.".php";
// echo 'Loading file: '.$file.PHP_EOL;
require_once $file;
});
Структура моей папки:
BaseModel
класс (это не полный файл):
<?php
/**
* Model Base CRUD Banco de Dados
*/
namespace Models;
class BaseModel {
protected $tableName = null;
public function find($value, $field = 'id', $fieldType = \PDO::PARAM_STR){
if(!isset($this->tableName) || empty($this->tableName)){
return null;
}
$DB = new \DB;
$sql = sprintf("SELECT * FROM %s WHERE %s = :value", $this->tableName, $field);
$stmt = $DB->prepare($sql);
$stmt->bindParam(':value', $value, $fieldType);
$stmt->execute();
Каким-то образом PHP ищет заглавную папку "Models /"? Ребята, вы когда-нибудь испытывали это раньше?