$smile = str_replace($smile, ":$smile:", $smile);
где pathinfo – возвращает информацию о пути к файлу,
str_replace (что меняем, на что меняем, где меняем) – заменяет все вхождения строки поиска на строку замены;
и строим пути к картинкам:
$path = '/say/smile/'.$val;
При успешном завершении кода выводим сообщение:
echo '
'.'Все таблицы успешно созданы';
Запускаем сайт. Добавляем после «news» в адресную строку /chat/admin/createbase.php. Обновляем страницу. Должно получиться следующее.
Рис. 11 Результат работы файла createbase.php
Заходим в phpMyAdmin и проверяем. В списке БД должна появится новая база «beseder».
phpMyAdmin находится на вкладке «дополнительно» «Open Server».
Рис. 12. Проверяем наличие созданной БД
Файл работает. Для интереса, можете посмотреть, какие таблицы созданы.
На данном этапе БД не нужна, поэтому удаляем. В phpMyAdmin:
– выбираем базу «beseder»;
– жмём кнопку «Операции»;
– жмем кнопку «Удалить базу данных (DROP)».
Для того чтобы выполнять удаление не входя в phpMyAdmin средствами PHP, создаем файл «drop» и размещаем его также в папке «admin». Теперь можно будет удалять базу переходя по адресу: news/chat/admin/drop.php
Листинг 5. drop.php Путь: news/chat/admin/drop.php
include_once $_SERVER['DOCUMENT_ROOT'].'/chat/dsn.php';
try {
$sql = 'DROP DATABASE beseder';
$s = $dsn->exec($sql);
} catch (PDOException $e) {
echo $e->getMessage();
exit('Ошибка подключения к базе данных');
}
header('Location: /');//переходим на главную страницу
В этом скрипте мы сначала подключаемся к нашей базе данных beseder, а затем выполняем SQL запрос DROP DATABASE удаляющий все таблицы в указанной базе данных и саму базу. В результате выполнения данного оператора база удаляется полностью.
*файл подключения к БД dsn.php будет рассмотрен в следующем разделе.
5. Файл подключения к базе данных
Теперь нужен файл, при помощи которого можно будет создавать подключения к БД. В корне папки «chat» создаем файл «dsn.php» со следующим содержимым:
Листинг 6. dsn.php Путь: news/chat/dsn.php
try {
$dsn = new PDO('mysql:host=localhost;dbname=beseder', 'root', '');
$dsn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$dsn->exec('SET NAMES "utf8"');
} catch (PDOException $e) {
echo $e->getMessage();
echo $e->getLine();
exit();
}
Он будет вставляться в те PHP файлы, где потребуется обращение к базе данных.