[ Поиск ] - [ Пользователи ] - [ Календарь ]
Полная Версия: Не запускается приложение=задача по php
Nick_1
Друзья всем привет.
Есть такая БД test с таблицей news из 3х строчек. Соединение с БД есть, при проверке через var_damp выводится массив данных из БД:

array(3) { [0]=> array(8) { ["id"]=> string(1) "1" [0]=> string(1) "1" ["title"]=> string(50) "Большие слоны идут на север" [1]=> string(50) "Большие слоны идут на се-вер" ["lead"]=> string(0) "" [2]=> string(0) "" ["author_id"]=> string(1) "1" [3]=> string(1) "1" } [1]=> array(8) { ["id"]=> string(1) "2" [0]=> string(1) "2" ["title"]=> string(58) "Метеорит упал рядом с человеком" [1]=> string(58) "Метеорит упал рядом с человеком" ["lead"]=> string(0) "" [2]=> string(0) "" ["author_id"]=> string(1) "2" [3]=> string(1) "2" } [2]=> array(8) { ["id"]=> string(1) "3" [0]=> string(1) "3" ["title"]=> string(65) "Экономика оставляет желать лучшего" [1]=> string(65) "Экономика оставляет желать лучшего" ["lead"]=> string(0) "" [2]=> string(0) "" ["author_id"]=> string(1) "3" [3]=> string(1) "3" } }


https://cloud.mail.ru/public/gJrD/6b5pJkfXa



Вот некоторые из задач по созданию:
Нужно осздать веб-приложение, использующее базу данных.
1. Создать класс DB.
- В конструкторе установить и сохранить соединение с базой данных  (параметры соединения берем из файла конфига);
- Метод execute(string $sql) выполняет запрос и возвращает true либо false в  зависимости от того, уда-лось ли выполнение
- Метод query(string $sql, array $data) выполняет запрос, подставляет в него  данные $data,
возвращает данные результата запроса либо false, если выполнение не удалось
2. Создайте таблицу news с полями "заголовок", "текст", "автор". Заполните ее 3-5 новостями.
Запишите запросы на языке SQL, которые вы использовали и приложите к своему  ДЗ
3. Создайте две страницы сайта, используя технику шаблонов и класс View из  предыдущего ДЗ:
- index.php выводит все новости (самая новая - наверху)
- article.php?id=N выводит одну новость, с id=N

Код накидал как есть, я новичек в этом деле поэтому дальше сложновато двигаться в решении данной задачи если кто поможет с решением будут очень рад.


Файлы и папки:

index.php

<?php
require __DIR__ . '/templates/news.php';
?>

config.php

<?php
return
[
'host'=>'127.0.0.1',
'db_name'=>'test',
'username'=>'root',
'password'=>''
];
?>

Папка templates:

article.php

<h2>
<?php echo $this->data['record']->getHeadline();?>
</h2>
<p>
<?php echo $this->data['record']->getFullText();?>
</p>


news.php

<!doctype html>
<html lang="ru">
<head>
<meta charset="UTF-8">
<meta name="viewport"
content="width=device-width, user-scalable=no, initial-scale=1.0,
maximum-scale=1.0, minimum-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Новости</title>
</head>
<body>
<h1>Главные новости</h1>
<hr>

<?php
foreach($this->data['news']->getNews() as $article)
{
$line = new View();
$line->assign('article', $article);
$line->display('newsAll.php');
}
?>
<hr>
</body>
</html>

newsAll.php

<article>
<h2>
<a href="article.php?id=<?php echo $this->data['article']->getId(); ?>">
<?php echo $this->data['article']->getHeadline(); ?>
</a>
</h2>
<p>
<?php echo $this->data['article']->getText(); ?>
</p>
</article>
<hr>

Папка: Classes

Article.php:

<?php

class Article
{
protected $id;
protected $headline;
protected $text;
protected $fullText;
protected $author;
public function __construct($article)
{
$data = explode('|', $article);
$this->id = ($data[0]);
$this->headline = trim($data[1]);
$this->text = mb_substr($data[2], 0, 150) . '...';
$this->fullText = trim($data[2]);
$this->author = trim($data[3]);
}

public function getId()
{
return $this->id; .
} //
public function getHeadline()
{
return $this->headline;
}
public function getText()
{
return $this->text;
}
public function getFullText()
{
return $this->fullText;
}
public function getAuthor()
{
return $this->author;
}

public function getLine()
{
return $this->headline . '|' . $this->text . '|' . $this->author;
}
}

DB.php:

<?php

class DB
{
protected $dbh;

public function __construct()
{
$this->connect();
}
private function connect()
{
$config = include __DIR__ . '/../config.php';
$dsn = 'mysql:host='. $config['host'] . ';dbname='.$config['db_name'].';';
$this->dbh = new PDO ($dsn, $config['username'], $config['password']);
return $this;

public function execute($sql)
{
$sth = $this->dbh->prepare($sql);
$res = $sth->execute();
return $res;
}

public function query($sql, $class)
{
$sth = $this->dbh->prepare($sql);
$res = $sth->execute();
if (false !== $res) {
return $sth->fetchAll(\PDO::FETCH_CLASS, $class);
}
return [];
}
}

$db = new DB;
$sql = 'SELECT * FROM news';
$a = $db->execute($sql);
?>

News.php:

<?php

require __DIR__.'/Article.php';

class News
{

protected $path;
protected $data;

public function __construct($path)
{
$id = 0;
$this->path = $path;
$data = file($path, FILE_IGNORE_NEW_LINES);
foreach ($data as $line) {
$this->data[++$id] = new Article($line);
}
}

public function getData($id)
{
return $this->data[$id];
}

public function getNews()
{
return $this->data;
}

public function append(Article $text)
{
$this->data[] = $text;
}

public function save()
{
$str = implode("\n", $this->data());
file_put_contents($this->path, $str);
}

public function getAll()
{
$data = [];
foreach ($this->getData() as $record) {
$data[] = $record->getLine();
}
return $data;
}
}
?>

View.php:

<?php

class View
protected $data;

public function __construct()
{
}

public function assign(string $name, $value)
{
$this->data = [];
$this->data[$name] = $value;
}

public function display(string $template)
{
echo $this->render($template);
}

public function render(string $template)
{
ob_start();
extract($this->data, EXTR_OVERWRITE);
include $template;
$content = ob_get_contents();
ob_end_clean();
return $content;
}
}
?>

Результат следующий: Т.е.: неустранимая ошибка: Неперехваченная ошибка: использование $ this вне контекста объекта

https://cloud.mail.ru/public/mhCB/Zqazy2EpS
Быстрый ответ:

 Графические смайлики |  Показывать подпись
Здесь расположена полная версия этой страницы.
Invision Power Board © 2001-2025 Invision Power Services, Inc.