Как скрыть, что используется wordpress

Вордпресс наверно самый популярный движок в мире. Удобный, куча плагинов, тем и хаков. Все хорошо, но есть и ложка дегтя — это куча спама, попытки взлома, ну и частное мнение некоторых товарищей что на вордпрессе нельзя сделать что-то путное.

И вот была поставлена задача для одного сайта первоначально спрятать, что это вордпресс, а потом и выдать его за другую cms. Про то, как сделать из одной cms другую (по внешним признакам) я могу отдельно пост накатать, если кому интересно будет. Тут расскажу как убрать признаки вордпресса.

Сам поциэнт http://battmart.ru/, еще не готов в плане диза и наполнения, но попалить цмску на нем уже не получится. Определяется как битрикс, на самом деле вп обычный.

Итак, поехали.

Вордпресс палится сразу несколькими вещами. Для их определения мы заюзаем таблицу признаков cms.

1. Заголовки

Заголовки, это служебная инфа, которую отдает сервер перед тем как отдать код страницы. Я проверяю через curl -I site.ru

HTTP/1.1 200 OK
Server: nginx/1.2.6
Date: Tue, 12 Feb 2013 06:44:57 GMT
Content-Type: text/html; charset=UTF-8
Connection: keep-alive
Keep-Alive: timeout=10
X-Pingback: http://alexvolkov.ru/xmlrpc.php

Что-же тут такого палится. X-Pingback конечно же.

Убираем в файле functions.php нашей темы.

function remove_x_pingback($headers) {
    unset($headers['X-Pingback']);
    return $headers;
}
add_filter('wp_headers', 'remove_x_pingback');

Еще плагины для кеширования могут добавить информацию о времени жизни кеша и подписаться. Решается по аналогии.

2. Шапка

Шапка — это все, что между тегами <head></head>.

Пути до тем, цссов и js отдельно будут рассмотрены в следующем разделе. Тут про мета-теги типа генератор и другую фигню, которую всякие плуги суют.

Пример шапки с моего блога

<head>
	<meta charset="UTF-8" />
	<meta name="verify-v1" content="by1MB81PjkQUdjinZJQn73aCwjaV5erxwsvtTP7pTNE=" />
	<meta name="viewport" content="width=device-width" />
	<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"/>
	<meta name="keywords" content="cms,detection,Web" />	
	<link href="" rel="icon" type="image/x-icon" />
	<link rel="apple-touch-icon" href="/wp-content/themes/somerandomdude/images/apple-touch-icon.png"/>

	<title>Linux, кодинг, митолл и прочая хрень :)</title>

	<link rel="alternate" type="application/rss+xml" title="RSS 2.0" href="/feed/" />
	<link rel="pingback" href="/xmlrpc.php" />

	<link rel="alternate" type="application/rss+xml" title="Linux, кодинг, митолл и прочая хрень 🙂 &raquo; Лента" href="http://alexvolkov.ru/feed" />
<link rel="alternate" type="application/rss+xml" title="Linux, кодинг, митолл и прочая хрень 🙂 &raquo; Лента комментариев" href="http://alexvolkov.ru/comments/feed" />
<link rel='stylesheet' id='frank_srd_stylesheet-css'  href='http://alexvolkov.ru/wp-content/themes/somerandomdude/style.css' type='text/css' media='all' />
<!--[if IE]>
<link rel='stylesheet' id='frank_srd_stylesheet_ie-css'  href='http://alexvolkov.ru/wp-content/themes/somerandomdude/ie.css' type='text/css' media='all' />
<![endif]-->
<!--[if IE 7]>
<link rel='stylesheet' id='frank_srd_stylesheet_ie7-css'  href='http://alexvolkov.ru/wp-content/themes/somerandomdude/ie7.css' type='text/css' media='all' />
<![endif]-->
<link rel='stylesheet' id='schema-style-css'  href='http://alexvolkov.ru/wp-content/plugins/schema-creator/lib/css/schema-style.css' type='text/css' media='all' />
<script type='text/javascript' src='http://alexvolkov.ru/wp-includes/js/jquery/jquery.js'></script>
<link rel="EditURI" type="application/rsd+xml" title="RSD" href="http://alexvolkov.ru/xmlrpc.php?rsd" />
<link rel="wlwmanifest" type="application/wlwmanifest+xml" href="http://alexvolkov.ru/wp-includes/wlwmanifest.xml" /> 
<meta name="generator" content="WordPress 3.5.1" />

<!-- All in One SEO Pack 1.6.15.3 by Michael Torbert of Semper Fi Web Design[976,1117] -->
<link rel="canonical" href="http://alexvolkov.ru/" />
<!-- /all in one seo pack -->
<link rel="stylesheet" href="http://dtmvdvtzf8rz0.cloudfront.net/static/css-text/plain.css?version=2.4" />
<!--[if lt IE 9]><script src="http://alexvolkov.ru/wp-content/themes/somerandomdude/javascripts/html5.js"></script><![endif]--><!--[if lt IE 7]><script src="http://alexvolkov.ru/wp-content/themes/somerandomdude/javascripts/ie7.js"></script><![endif]--><style type="text/css" id="custom-background-css">
body.custom-background { background-color: #fffefe; }
</style>

	<!--[if lte IE 8]>
	<script src="http://html5shim.googlecode.com/svn/trunk/html5.js" type="text/javascript"></script>
	<![endif]-->

	<!--[if lt IE 7]>
	<script src="http://ie7-js.googlecode.com/svn/version/2.1(beta4)/IE7.js"></script>
	<![endif]-->

</head>

Тут мы видим адреса фидов, пингбеков, сеопак засунул свою инфу. Плагины вообще любят в шапку свой хлам насовать.

Так вообще вп сует еще манифесты, адреса предыдущего и следущего поста, рсд.

Есть радикальный способ убрать все это дело — удалить вызов функции wp_head() в шапке. Тогда ничего не будет автоматом соваться. На подопытном сайте я так и сделал.

Или надо по одному выключать все, что свидетельствует о вп. Делается через хуки в файле functions.php выбранной темы:

remove_action( 'wp_head', 'wp_generator'); 
remove_action( 'wp_head', 'rsd_link' );
remove_action( 'wp_head', 'feed_links', 2 );
remove_action( 'wp_head', 'wlwmanifest_link' );
remove_action( 'wp_head', 'index_rel_link' );
remove_action( 'wp_head', 'adjacent_posts_rel_link', 10, 0 );
remove_action('wp_head', 'previous_post_rel_link', 10, 0);
remove_action( 'wp_head', 'start_post_rel_link', 10, 0 );
remove_action( 'wp_head', 'feed_links_extra', 3 );
remove_action('wp_head', '_ak_framework_meta_tags');

Для ленивых есть плагин WP Head Section Cleaner, сам все подчистит.

3. Пути

Самая мякотка. Именно по путям можно однозначно сказать, что за цмс именно используется. С путями не так все просто — их нельзя взять и поменять без проблем с последующим обновлением.  Поэтому действовать нужно более обходительно.

Папок у вордпресса 3 — wp-admin, wp-includes, wp-content. Только wp-content позволяет менять свое имя. С него и начнем.

Файл wp-config.php

define('WP_CONTENT_FOLDERNAME', 'bitrix');
define('WP_CONTENT_DIR', ABSPATH . WP_CONTENT_FOLDERNAME );
define('WP_CONTENT_URL', 'http://battmart.ru/'.WP_CONTENT_FOLDERNAME);
define('WP_PLUGIN_DIR', WP_CONTENT_DIR . '/plugins' );
define('WP_PLUGIN_URL', WP_CONTENT_URL.'/plugins');
define( 'UPLOADS', '/upload/' );
define('TEMPLATEPATH', 'bitrix/battmart');

Тут конфиг с баттмарта, пути типа под битрикс сделаны.

Пояснения по коду

  • WP_CONTENT_FOLDERNAME — имя папки wp-content
  • WP_CONTENT_DIR — путь на сервере до этой папки
  • WP_CONTENT_URL — путь из адресной строки
  • WP_PLUGIN_DIR — путь до папки с плагинами
  • WP_PLUGIN_URL — тоже, но из браузера
  • UPLOADS — папка куда картинки грузятся
  • TEMPLATEPATH — путь до текущей темы

С templatepath небольшая засада, он прибавляется к выводу функции theme_root() и theme_root_uri(), т.е. поменять через templatepath можно только конец пути.

Чтобы сделать путь до темы полностью произвольным, нужно добавить в functions.php это

function change_theme_root_uri()
{
    // возвращает новый урл до темы
    return  get_bloginfo('wpurl') . '/bitrix/templates';
}

function change_theme_root()
{
    // возвращает путь до темы
    return '/bitrix/templates';
}

add_filter('theme_root_uri', 'change_theme_root_uri');
add_filter('theme_root', 'change_theme_root');

Также можно прописать новые пути до css и js, используя хуки script_loader_src и style_loader_src.

Теперь черед папки wp-admin. Встроенными средствами ее не переименовать. Был раньше плагин, stealth-login, но пропал куда-то. Однако один неизвестный вебмастер предусмотрительно его сохранил. Плагин прячет wp-login.php, переименовывает путь до wp-admin/

Хотя плагин старый, но на последнем вордпрессе заработал. Скрин настроек с баттмарта

Снимок экрана от 2013-02-12 11:30:55

Однако, есть один момент с этим плугом. Он не запрещает пути, он вешает редиректы на них.  А нам нужно получить 404 по всем известным путям.

Я решил не заморачиваться и просто закрыл доступ на все системные папки для всех айпи кроме моего.

RewriteCond %{REQUEST_URI} /wp-login\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-admin/$ [OR]
RewriteCond %{REQUEST_URI} /wp-includes/$
RewriteCond %{REMOTE_HOST} !^31\.44\.58\.*
RewriteRule $ /http://battmart.ru [R=404,L]

Так вот отрубаются все пути.

4. Внешние файлы

Второй по обьему любви пункт. Фенька в том, что окромя папок в корне также лежат файлы, которые при запросе извне дают ответ, отличный от 404. Именно этот ответ и выдает нас. Также отрубаем все в htaccess

RewriteCond %{REQUEST_URI} /wp-login\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-admin/$ [OR]
RewriteCond %{REQUEST_URI} /wp-activate\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-app\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-blog-header\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-comments-post\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-config-sample\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-config\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-cron\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-links-opml\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-load\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-mail\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-settings\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-signup\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-trackback\.php$ [OR]
RewriteCond %{REQUEST_URI} /xmlrpc\.php$ [OR]
RewriteCond %{REQUEST_URI} /wp-includes/$
RewriteCond %{REMOTE_HOST} !^31\.44\.58\.*
RewriteRule $ /http://battmart.ru [R=404,L]

Небольшое предостережение. Такое тотальное запрещение подключения файлов может вызвать проблемы что кому-то просто не будет ничего показываться. Хотя подключение файлов идет через include внутри вордпресса, так что все должно быть нормально.

Я пока не испытывал никаких проблем с этим, но если будут то отпишите в коментах.

Это были системные файлы. Есть еще файлы, которые боты поисковых систем запрашивает сразу. Это роботс и, если есть, сайтмап.

В роботсе обычно закрывают админку от индексирования. Поэтому нужно удалять все такие строки.

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

Еще один признак вордпресса, самый наверно глупый — это присутствие в корне файлов readme.html и readme.txt ))

 

5. Плагины

Плуги палятся тем, что любят вставить свой коммент или цсску или яваскрипт в код. Тут какбы нет общих методик для всех плагинов. Нужно просто смотреть код и уже действовать по обстановке. Имейте ввиду, что некоторые плуги грузятся только на странице поста или категории.

Я просто не использую плуги.

6. Код

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

 

Вот и все, что я делал чтобы скрыть вордпресс. Если найдете какую лазейку, которая позволит вам идентифицировать данный сайтик как вп, черканите плз в коменты

UPD1

Данной функцией можно удалить сразу все комментарии в шаблоне.

function callback($buffer) {
	$buffer = preg_replace('/<!--(.|\s)*?-->/', '', $buffer);
	return $buffer;
}
function buffer_start() {
	ob_start("callback");
}
function buffer_end() {
	ob_end_flush();
}
add_action('get_header', 'buffer_start');
add_action('wp_footer', 'buffer_end');

 

Полезные ссылочки

  • http://2ip.ru/cms/ — палит как раз по служебным файлам в корне
  • http://guess.scritch.org/ — какой-то свой алгоритм для определения цмс, судя по всему подсчитывает число различных путей и сверяет их с таблицей, после чего отдает результат в процентах.
  • rds bar — палит по коду, для русских cms признаки дополнены
  • wappalyzer — также палит по коду, но число всяких систем там больше.
4.61 avg. rating (92% score) - 49 votes

49 комментариев

  • Блин, только уходить собрался…
    Сохраняю целиком, потом читать буду 🙂

  • /admin редиректит на /wp-admin/
    /login редиректит на /wp-login/

    • из поста
      >>Однако, есть один момент с этим плугом. Он не запрещает пути, он вешает редиректы на них

  • Битрикс — это интересно 🙂 Раз собрался, выкладывай и про другие «положительные» CMS.
    C Ip засада. У меня мобильный интернет и айпишник тут меняется по щучьему велению и чьему-то хотению.
    Вот про изменение страницы авторизации на другую попадалась статейка раньше у кого-то из блогеров, как ещё один шаг к повышению защищённости блога, правда нужно поискать её…
    Уяснил одно, что скрыть можно, хотя и сложно, а на обновлениях при этом желательно забить крест…

    • с обновлениями все норм кстати, т.е. их работа изначально преследовалась

      если с айпи проблема — то навскидку решение, создаешь страницу с произвольным именем и в htaccesse проверяешь не айпи а рефера

  • Знавал историю про чувака, который также опасаясь попалить ЦМС маскировал ее под другую, в итоге за такую подмену попал под фильтры Яндекса. У вас с индексацией подопытного тоже не все гладко, но может это просто сайт еще новичек и контента толкового нет, потому он и не в индексе поисковых монстров

    • и под какие фильтры попал чувак?

      а подопытный закрыт от индексации в роботсе, там еще дел куча

  • Какие фильтры точно уже не помню, но с поиска трафика точно меньше стало

    По поводу закрыто от индексации в роботс. Тоже классический бич советского менталитета. Что страшного в том, если поисковики уже начнут индексировать сайт? по мере развития сайта поисковики учидят, что сайт развивается, а это дополнительный плюс в траст сайту. Понимаю опасения, что посетитель пришел и тут же ушел т.к. сайт недоделан, но тут можно ведь наладить обратную связь или через статистику метрики понять ч каком направлении двигаться, а не по интуиции

    А если закрывать пока не будет все идеально, то сайт может вообще всегда быть закрытым, т.к. нет предела совершенству.

    Но это сугубо мое мнение и вы вправе с ним не согласиться

    • >>Какие фильтры точно уже не помню, но с поиска трафика точно меньше стало
      Фильтры обычно накладываются за контент, так что цмс тут нипричем

      >>что посетитель пришел и тут же ушел
      и тем самым повысил процент отказов и убил поведенческие ))

  • Спасибо. Ещё одна полезная статья о WordPress попадает в закладки…

  • >>Фильтры обычно накладываются за контент, так что цмс тут нипричем
    не факт, за ссылочное тоже, за различные накрутки, да за много чего еще

    >>и тем самым повысил процент отказов и убил поведенческие ))
    Поведенческие работают на запросы, и при неоптимизированном сайте вряд ли будет много посетителей с какого-нить ВЧ, чтобы убить поведенческие 😉

    • >>не факт, за ссылочное тоже, за различные накрутки, да за много чего еще
      Факт, причем проверенный не раз и не только мной. Вспомни историю с мегаиндексом и их тулзой для накрутки поведенческих.

      >>вряд ли будет много посетителей с какого-нить ВЧ, чтобы убить поведенческие
      Если сайт будет в индексе, то он вполне может выползти по не суть важно каким запросам. Поэтому он и закрыт.

  • У меня антивир ругается, Exploit.PDF.48 проверьте http://alexvolkov.ru/wp-content/plugins/simple-mail-address-encoder/smae.js

    • Владимир, там все чисто, это кодировщик мыла

  • Александр, не буду больше спорить. На то оно и свое мнение, чтобы при нем оставаться 🙂

  • Круто. Даже жалко, что мои блоги уже настроены и перенастроены до посинения — очень не хочется всё переделывать и ломать урлы (хотя кое-что из других советов всё-таки можно использовать). Но если я решу завести ещё один блог — попробую использовать эти приёмы. А вот копирайтов и «фирменных» классов у меня и так нет — тема вёрстана собственноручно. 🙂

  • Вот только не уверен, что вся эта морока стоит результатов.. имхо больше for fan ну или для очень редких и специфичных задач

  • Хороший пост! Надо бы и себе как-то wordpress спрятать!)

  • проверил твой сайт пациент через http://2ip.ru/cms/
    определил 2 CMS:
    WordPress найдены признаки использования
    1C:Битрикс найдены признаки использования

    очень интересен действительный эффект

    вот бы еще для сравнения клончик запустить на чистом WordPress и ломаном

  • Крутая тема!
    Правда все замороченно((
    А можно единый плагин сделать для подмены цмс, так, чтоб ни какие файлы не править?

  • Сайт грузит тему с папки
    http://ввв.сайт.ru/bitrix/templates/мойстиль/style.css

    Но в теме путь к картинке указывает как
    http://ввв.сайт.ru/wp-content/themes/мойстиль/images/headers/5.jpg

    Нужно так:
    http://ввв.сайт.ru/bitrix/templates/мойстиль/images/headers/5.jpg

    Подскажите, пожалуйста, где исправить/добавить в wp-config или functions (темы)?

  • а есть возможность выложить исходники — ибо тема не раскрыта:

    вроде заработало, но на сайте не отображаются сайдбары

    кстати, нигде не сказано, что наименование папки wp-content надо поменять на bitrix

    как поменять путь:
    /bitrix/themes/mytema/
    на
    /bitrix/mytema/

    с function change_theme_root_uri(), тема не выбирается (ошибка, сброс на дефолтную)
    без этого кода работает — вообще так и не понял для чего он нужен

    • Исходники чего?

      >>кстати, нигде не сказано, что наименование папки wp-content надо поменять на bitrix
      Пункт 3 целиком про это

      >>с function change_theme_root_uri(), тема не выбирается (ошибка, сброс на дефолтную)
      Есть такой косяк
      Я сначала выбрал тему, а потом уже вставил эту функцию

  • исходники — файлы папки bitrix (wp-content) — т.е измененных файлов

    вопросы остались про сайдбары и пути

    • >>исходники — файлы папки bitrix (wp-content) — т.е измененных файлов
      это какбы обычный wp-content, просто переименованный. Все замены делаются в functions.php темы и wp-config.php в корне

  • Я решил не заморачиваться и просто закрыл доступ на все системные папки для всех айпи кроме моего.Я решил не заморачиваться и просто закрыл доступ на все системные папки для всех айпи кроме моего

    Странно, но wp-signup.php, wp-admin и wp-login.php там ведут на вполне себе открытую админку wp.

    • хтаксесс потерли, сейчас уже не ведет

  • Алекс,подскажи пожалуйста

    >>»Также можно прописать новые пути до css и js, используя хуки script_loader_src и style_loader_src»
    час гулил на эту тему, но так и не нашел ответа
    опубликуй пожалуйста пример

    единственно полезный хук на эту тему —
    удаление в WordPress № версий всех скриптов и стилей:

    function remove_version_data( $src ){
    $parts = explode( '?ver', $src );
    return $parts[0];
    }
    add_filter( 'script_loader_src', 'remove_version_data', 15, 1 );
    add_filter( 'style_loader_src', 'remove_version_data', 15, 1 );

  • вот код на тему
    Change WP Directory Names
    https://gist.github.com/franz-josef-kaiser/2007615

  • УРА! У МЕНЯ ПОЛУЧИЛОСЬ! СПАСИБО ТЕБЕ ДОБРЫЙ ЧЕЛОВЕК!
    оказывается что бы работал код:
    function change_theme_root_uri()

    должны быть 2 папки:
    /bitrix/themes/моятема/ — здесь вызывается функция
    /bitrix/templates/моя тема/ — сюда редиректит

    другие способы изменить пути к папке темы я не нашел — 4 часа ковырял весь инет
    твой хак function change_theme_root_uri() отлично работает

  • А у мну не получилось 🙁
    После внесения изменений в wp-config.php появилась ошибка.

    Warning: include(/bitrix/templates/dt-crea/dt-pagenavi.php): failed to open stream: No such file or directory in /home/u911185618/public_html/s2/bitrix/themes/dt-crea/functions.php on line 128 Warning: include(): Failed opening ‘/bitrix/templates/dt-crea/dt-pagenavi.php’ for inclusion (include_path=’.:/usr/lib/php’) in /home/u911185618/public_html/s2/bitrix/themes/dt-crea/functions.php on line 128

    При это сайт открывается (только без фоток).

    Если внести изменения в «Чтобы сделать путь до темы полностью произвольным, нужно добавить в functions.php это» ошибка остается, но шаблон погибает. Выдает то что ему нравицо.

  • Спасибо!! Не упустил ни одного момента. Завтра тоже попробую.

  • http://battmart.ru/wp-login.php
    вот и палево

  • Ну просто фундаментальный пост 🙂 Первый раз вижу настолько полное раскрытие темы по поводу сокрытия факта использования wordpress. Я сам когда-то убрал только generator и был невероятно горд по этому поводу 🙂 А, оказываься, сколько еще нюансов есть…

  • Черкаю лазейки как узнал WP на battmart.ru:
    1. — зачем он нужен? Удаляем!
    2. /category/ — эта штука есть на нескольких движках. Тем более зачем она нужна? Убираем!
    3. wp-login.php, wp-admin и т.д. Палевно все это. Я заменил все названия глобальным поиском по notepad++ и все летает. Все нормально работает.

    Во внутренних страницах не лазил. Ничего сказать не смогу.

    З.Ы. странно построен ДОКТАЙП на сайте: , потом . Сделайте как у DLE:
    . У меня стоит именно так, все нормально работает.

    • >>3. wp-login.php, wp-admin и т.д

      В данный момент не палятся. Они периодически открываются, чтоб с других айпи можно было зайти. Все остальное не дает 100% гарантии, что это вордпресс

  • Здравствуй Александр!

    «…Чтобы сделать путь до темы полностью произвольным, нужно добавить в functions.php это…» — из «3. Пути» — это говорится про файл functions.php из текущей темы или все же из папки wp-includes?
    Скажи пожалуйста.

    • Петр, Шапка будет выводится
      Алексей, про functions.php

  • По сервисам не смотрел. Но rds bar в мозиле, четко говорит, что используется wordpress.

  • К пункту 2: «Есть радикальный способ убрать все это дело — удалить вызов функции wp_head() в шапке. Тогда ничего не будет автоматом соваться. »
    А сама шапка при этом будет выводиться?

  • Если все это осуществить, спам и попытки взлома исчезнут?

  • По моему мнению, пользователи Ру-нета сильно переоценивают популярность и значимость WordPress. Мне, к примеру, он не нравился никогда и не думаю, что я одинок в безразличности к данному движку и созданию блогов на WordPress.

  • В большинстве случаем провека осуществляется через site.com/feed/ http://wordpress.org/?v=3.5.1

  • Нет смысла скрывать факт использования WordPress.

    Ботнеты которые брутфорсят пароли к админкам WordPress не тратят времени на проверку на чём именно работает сайт. Запустите простой HTML сайт без движка и вы увидите в логах, как кто-то пытается отправить POST запрос на несуществующую страницу wp-login.php. Скрывать WordPress нет смысла, а вот использовать надёжный пароль — есть.

    Мало того, ни один плагин, и ни одно существующее решение не поможет скрыть факт использования WordPress, и если кому-нибудь очень сильно понадобится, они с лёгкостью смогут не только узнать что вы используете WordPress, но и точно определить версию.

    Используйте WordPress и обновляйтесь вовремя.

  • никак не скроешь, лох это судьба ахаххаха

  • wp-post-imag — нужно еще поработать с классами

  • http://2ip.ru/cms/?PHPSESSID=0b80adkg3ag94upc355216l2n6&url=http%3A%2F%2Fbattmart.ru%2F
    уверенно показывает как битрикс.

  • Жаль демка не работает. Спасибо автору за пост. Не увидел, по какому пути будут отображаться изображения?

  • И снова WordPress, выскажу своё мнение, — самый популярный увы не самый лучший, одним из плюсов бесплатность, к минусам — избыточный код в каскадных таблицах css, постоянно сканят wp-login.php, сайты выглядят словно как с одного инкубатора, ну и не знаю как он работал раньше, но у меня тормозил даже на локальном сервере. Предпочитаю создавать проекты руками, без платформ, с использованием php, mysql, jquery, html, css — сложнее, но больше гибкости, отсутствует избыточность кода, неповторимость и уникальность проекта.

css.php