Перенос сайта с dle на wordpress
Многим из Вас, кто использует Нулл версию DLE, приходили "письма счастья". Либо они скоро Вам придут, и у Вас будет несколько вариантов:
1) Это купить DLE - От 3199 до 3999 рублей;
2)Взять абузник;
3) Переехать на бесплатный движок - WordPress.
Выберем третий вариант, т.к. он самый легкий и бесплатный.
Прежде чем начинать какие-то манипуляции, стоит сделать backup сайта и backup базы данных.
Пошаговая инструкция переноса сайта с DLE на Wordpress:
1) Делаем бэкапы базы данных и всех файлов. (на всякий случай, вдруг не получится перенос)
2) В корневую папку устанавливаем wordpress
3) В качестве базы указываем базу от сайта на dle
4) Устанавливаем плагины: Wp-no-category-base (убирает ссылки на /category/) , Rus-to-lat (Переводит урлы в латиницу)
5) Приводим Url wordpress к виду как они были на dle. (для этого Идем Консоль -> Параметры->Постоянные ссылки-> Произвольно-> Ставим: «/%category%/%post_id%-%postname%.html» )
6) Конвертируем базу данных
Для этого в phpmyadmin необходимо выполнить вот такой запрос:
DELETE FROM `wp_users` WHERE `wp_users`.`ID` != 1;
INSERT INTO wp_users (ID, user_login, user_nicename, user_email, user_registered, display_name) SELECT user_id, name, name, email, FROM_UNIXTIME( reg_date ), name FROM dle_users WHERE user_id != 1;
TRUNCATE `wp_terms`;
INSERT INTO `wp_terms` (`term_id`, `name`, `slug`) SELECT `id`, `name`, `alt_name` FROM `dle_category`;
TRUNCATE `wp_term_taxonomy`;
INSERT INTO `wp_term_taxonomy` (`term_taxonomy_id`, `term_id`, `description`, `parent`) SELECT `id`, `id`, `descr`, `parentid` FROM `dle_category`;
UPDATE `wp_term_taxonomy` SET `taxonomy`='category';
TRUNCATE `wp_term_relationships`;
INSERT INTO wp_term_relationships (object_id, term_taxonomy_id) SELECT id, category FROM dle_post;
TRUNCATE wp_posts;
INSERT INTO wp_posts (id, post_author, post_date, post_content, post_title, post_name) SELECT d_p.id, d_u.user_id, d_p.date, CONCAT(d_p.short_story, '<!--more-->' ,d_p.full_story), d_p.title, d_p.alt_name FROM dle_post as d_p, dle_users as d_u WHERE d_p.autor = d_u.name;
TRUNCATE `wp_comments`;
INSERT INTO wp_comments (comment_ID,comment_post_ID, comment_author, comment_author_email, comment_date, comment_content) SELECT id, post_id, autor, email, date, text FROM dle_comments;
В принципе сайт уже должен работать. Остается только подогнать шаблон, вернуть все блоки, кнопки и прочее. Но это уже скорее относится к настройкам wordpress, чем к предмету этой статьи, поэтому просто упущу этот момент.