0 Пользователей и 1 Гость просматривают эту тему.
  • 4 Ответов
  • 288 Просмотров
*

gbolo

  • Новичок
  • 3
  • 0 / 0
Здравствуйте!

Есть сайт с большим количеством страниц, в тексте страниц то тут, то там указан телефон компании.
И вот компания решила сменить номер телефона, и его нужно оперативно обновить везде, где он встречается.
Страниц реально много, наверное больше 1000, поэтому ручками везде менять — самоубийство.

Дамп базы данных весит 600 мегабайт, что немного усложняет мою задачу (можно было бы заменить в выгрузке все номера телефонов и загрузить дамп обратно, но во-первых, текстовые редакторы падают от такого объема, а во-вторых его потом еще обратно фиг импортируешь).

Я придумал решение — перед выводом сгенерированной HTML-страницы, можно было бы в ее тексте менять телефон простой PHP-командой, но проблема в том, что я не могу найти, где бы эту сгенерированную страницу перед выводом подловить.

Подскажите, какие могут быть решения в такой ситуации?

Спасибо!
« Последнее редактирование: 16.01.2018, 19:11:26 от gbolo »
*

Aleks.Denezh

  • Живу я здесь
  • 3395
  • 422 / 4
во первых вы уверены что везде телефон в одинаковом формате?
во вторых можно написать sql запрос на замену всех телефонов в базе и не морочить голову со скриптами
что то типа:
UPDATE table_name SET filed = replace(field,'тут старый телефон','тут новый телефон')
*

kern.USR

  • Давно я тут
  • 810
  • 61 / 1
Вариант №1 - Дампите всю базу, открываете sql файл в редакторе и, через поиск и замену, регуляркой, меняете телефон
Вариант №2 - Каждый раз, при выводе контента, заменять  номер телефона. Для этого пишете плагин, который отрабатывает по вызову onAfterRender https://docs.joomla.org/Plugin/Events/System#onAfterRender
Вариант №3 - То же, что и в первом, но вместо номера телефона пишете вызов модуля, в котором прописан номер телефона.
*

gbolo

  • Новичок
  • 3
  • 0 / 0
Aleks.Denezh, спасибо, я как раз этот вариант локально у себя пробую, т.к. боюсь что-нибудь сломать на рабочем сайте. Пока пытаюсь в локальную бд импортировать дамп


kern.USR, вариант 1 не подходит, я написал сразу почему. А вот второй вполне может быть! Спасибо, буду разбираться, если с БД не получится
*

gbolo

  • Новичок
  • 3
  • 0 / 0
...
во вторых можно написать sql запрос на замену всех телефонов в базе и не морочить голову со скриптами
что то типа:
UPDATE table_name SET filed = replace(field,'тут старый телефон','тут новый телефон')

Спасибо, так и сделал, помогло.

Кстати, база весила 600 Мб из-за таблицы ze1vm_seflog, в которой плагин JoomSEF хранил свои лог-файлы на 2,5 млн+ записей. После ее чистки, база стала весить меньше 70, что существенно упростило дальнейшую работу.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Выводится код файла template.css в коде всех страниц, кроме главной

Автор Ramz707

Ответов: 3
Просмотров: 93
Последний ответ 24.04.2019, 10:11:43
от Ramz707
[Решено] Создание якоря в заголовке (теги H1 или H2)

Автор Клим

Ответов: 8
Просмотров: 176
Последний ответ 17.04.2019, 16:11:46
от Клим
[Решено] Перенос меню с j1.5 в J.3.x

Автор dron

Ответов: 4
Просмотров: 117
Последний ответ 14.04.2019, 12:19:09
от dron
[РЕШЕНО] Модуль только на главной index.php и больше нигде

Автор dron

Ответов: 3
Просмотров: 97
Последний ответ 10.04.2019, 14:29:49
от dron
[РЕШЕНО] Разные урлы в J 2.5 и J 3.5 при одинаковых настройках пунктов меню

Автор dron

Ответов: 11
Просмотров: 179
Последний ответ 10.04.2019, 11:24:30
от effrit