<

Нет сайта??

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

Есть сайт нет посетителей?

Раскрутка и продвижение сайта по поисковым запросам. Наш опыт позволит при продвижении Вашего сайта быстро достигнуть первой десятки и уверенно быть лидером среди других сайтов в дальнейшем. Наша методика продвижения основывается на внутренней оптимизации (оптимизация кода) и внешней оптимизации (оптимизация страницы).

Сколько это будет стоить?

Цена варьируется от ваших пожеланий и бюджета, основные же расценки вы можете посмотреть тут

Одной из важнейших составных частей блога на движке WordPress является административная панель (админка). Именно с ее помощью пользователи имеют возможность управлять сайтом: дизайном, сообщениями, записями и многим другим. Разработчики сайтов должны осуществлять контроль над админкой, чтобы действия клиента не влияли координальным образом на внешний вид ресурса и его функциональность. Для этого, ниже описаны 10 различных хаков упрощающих контроль над админкой WordPress.

1. Удаление лишних пунктов меню

При создании блога целесообразно будет запретить доступ к определенным функциям. Таким образом удастся избежать многих проблем, включая случайное удаление основной темы. Для этого необходимо внедрить код в имеющийся файл темы functions.php. Следует добавить, что такое удаление пунктов меню не запрещает прямой доступ к ним (доступ по ссылке), а всего лишь визуально убирает пункты меню:

  1. function remove_menus(){
  2.     global $menu;
  3.     $restricted = array(__(‘Dashboard’), __(‘Posts’), __(‘Media’), __(‘Links’), __(‘Pages’), __(‘Appearance’), __(‘Tools’), __(‘Users’), __(‘Settings’), __(‘Comments’), __(‘Plugins’));
  4.     end ($menu);
  5.     while (prev($menu)){
  6.         $value = explode(‘ ‘, $menu[key($menu)][0]);
  7.         if(in_array($value[0] != NULL?$value[0]:»» , $restricted)){unset($menu[key($menu)]);}
  8.     }
  9. }
  10. add_action(‘admin_menu’, ‘remove_menus’);

Наверное, нужно пояснить что:

  • __(‘Dashboard’) — главная страница админки (консоль);
  • __(‘Posts’) — пункт меню «Записи»;
  • __(‘Media’) — пункт меню «Медиафайлы» (картинки, видео и т.п.);
  • __(‘Links’) — никому не нужный, пункт меню «Ссылки»;
  • __(‘Pages’) — пункт меню «Страницы»;
  • __(‘Appearance’) — пункт меню «Внешний вид»;
  • __(‘Tools’) — пункт меню «инструменты» — это где всякие там: «импорт», «экспорт»;
  • __(‘Users’) — пользователи;
  • __(‘Settings’) — пункт меню «Настройки». Его очень даже можно закрыть для клиентов, а то они настроят …;
  • __(‘Comments’) — комментарии;
  • __(‘Plugins’) — ну и наконец, святое: пункт меню «Плагины».

Также, существует специальная функция WP для удаления пунктов меню и подменю: remove_menu_page() иremove_submenu_page().

1.1. Удаляем админ-меню полностью

В комментариях спросили как полностью удалить админ-меню. Мне стало интересно и вот что я придумал:

  1. add_action(‘admin_head’, ‘kill_adminmenu’);
  2. function kill_adminmenu(){
  3.     $GLOBALS[‘menu’] = array();
  4.     echo «<style type=’text/css’>#adminmenuwrap, #adminmenuback{display:none!important;} #wpcontent{margin-left:10px!important;}</style>»;
  5. }

Вставляем код куда-нить в functions.php и у нас больше нет меню в админ-панли. Тут меню также убирается визуально и не закрывает прямой доступ к пунктам меню по ссылкам.

2. Собственный логотип на странице входа

Какой либо практической пользы такой хак не принесет, но увеличит привлекательность и внешний вид сайта, клиенты порадуются тому, что будут видеть собственный логотип при входе в админку. То что делает хак ниже можно реализовать с помощью плагина «The Custom admin branding», но к чему плагин, когда мы можем просто добавить пару строк в файл темы functions.php.

Важно, чтобы логотип (картинка custom-login-logo.gif) находился по указанному адресу (в папке images в каталоге темы).

  1. function my_custom_login_logo(){
  2.     echo ‘<style type=»text/css»>
  3.     h1 a { background-image:url(‘.get_bloginfo(‘template_directory’).’/images/custom-login-logo.gif) !important; }
  4.     </style>’;
  5. }
  6. add_action(‘login_head’, ‘my_custom_login_logo’);

3. Изменение внутреннего логотипа админки

Данный хак дополнит предыдущий и увеличит ощущение того, что блог создавался именно для конкретного клиента. Если мы вставим этот код в файл темы functions.php, то логотип в верхнем левом углу в админке WP изменится на нужный нам (custom-logo.gif).

Важно, чтобы логотип (картинка custom-logo.gif) находилась по указанному адресу (в папке images в каталоге темы).

  1. function my_custom_logo(){
  2.     echo ‘<style type=»text/css»>
  3.     #header-logo { background-image: url(‘.get_bloginfo(‘template_directory’).’/images/custom-logo.gif) !important; }
  4.     </style>’;
  5. }
  6. add_action(‘admin_head’, ‘my_custom_logo’);

2 и 3 примеры (смена логотипов в WordPress) более подробно описаны тут.

4. Отключение сообщений о необходимости обновится

Пакеты обновлений для WordPress разработчики движка выпускают часто. Их обязательно необходимо устанавливать, чтобы поддержать меры безопасности на должном уровне. Однако клиентам о различных обязательных изменениях лучше не знать. Это позволит избежать необоснованного волнения, что что-то не так с сайтом. Делается это просто, следует вставить такой код в файл темы functions.php:

  1. if( !current_user_can( ‘edit_users’ ) ){
  2.     add_action( ‘init’, create_function( ‘$a’, «remove_action( ‘init’, ‘wp_version_check’ );» ), 2 );
  3.     add_filter( ‘pre_option_update_core’, create_function( ‘$a’, «return null;» ) );
  4.     // для 3.0+
  5.     add_filter( ‘pre_site_transient_update_core’, create_function( ‘$a’, «return null;» ) );
  6. }

5. Удаление лишних виджетов из консоли WordPress

Множество полезных функций присутствует в панели управления версий 2.7 и выше. Они очень удобны и дают возможность просматривать статистику блога и различные новинки на сайте разработчиков и т.п. Однако, некоторые из виджетов совершенно не нужны клиентам и разумно их вообще отключить. Делается это добавлением такого кода в файл темы function.php:

  1. /* Удаление виджетов из Консоли WordPress */
  2. function clear_dash(){
  3.     $side = &$GLOBALS[‘wp_meta_boxes’][‘dashboard’][‘side’][‘core’];
  4.     $normal = &$GLOBALS[‘wp_meta_boxes’][‘dashboard’][‘normal’][‘core’];
  5.     unset($side[‘dashboard_quick_press’]); //Быстрая публикация
  6. //  unset($side[‘dashboard_recent_drafts’]); //Полседние черновики
  7.     unset($side[‘dashboard_primary’]); //Блог WordPress
  8.     unset($side[‘dashboard_secondary’]); //Другие Нновости WordPress
  9.     unset($normal[‘dashboard_incoming_links’]); //Входящие ссылки
  10. //  unset($normal[‘dashboard_right_now’]); //Прямо сейчас
  11.     unset($normal[‘dashboard_recent_comments’]); //Последние комментарии
  12.     unset($normal[‘dashboard_plugins’]); //Последние Плагины
  13. }
  14. add_action(‘wp_dashboard_setup’, ‘clear_dash’ );

Подробнее про удаление виджетов из консоли WordPress я описывал в этой статье.

6. Добавление собственных виджетов в консоль (админку)

Определенные функции в панели администратора необходимы, при этом они могут не входить в стандартный пакет. В таком случае создатель сайта должен их добавить самостоятельно, посредством вставки следующего кода в файл functions.php:

  1. function example_dashboard_widget_function(){
  2.     // Показать то, что вы хотите показать
  3.     echo «Привет, мир. Я — великий виджет админки, созданный великими программистами»;
  4. }
  5. // Создаем функцию, используя хук действия
  6. function example_add_dashboard_widgets() {
  7.     wp_add_dashboard_widget(‘example_dashboard_widget’, ‘Пример виджета админки’, ‘example_dashboard_widget_function’);
  8. }
  9. // Хук в ‘wp_dashboard_setup’, чтобы зарегистрировать нашу функцию среди других
  10. add_action(‘wp_dashboard_setup’, ‘example_add_dashboard_widgets’ );

7. Изменение цвета шапки админки

Иногда возможно нужно изменить белый фон шапки админки, например чтобы цвета соответствовали цветам бренда клиента или еще по каким-то причинам. Чтобы изменить цветовую схему воспользуйтесь следующим хуком и укажите цвета в CSS стилях:

  1. add_action(‘admin_head’, ‘custom_colors’);
  2. function custom_colors() {
  3.     echo ‘<style type=»text/css»>
  4.     #wphead{background:#069}
  5.     </style>’;
  6. }

Таким же образом можно указать CSS стили для любых других элементов админки.

8. Добавление сообщений с дополнительной справкой

У основной массы клиентов могут возникать проблемы с пониманием даже простых вещей при использовании блога на WordPress. Для них существует контекстная справка, отвечающая на некоторые вопросы. Внедрение такой справки производится подобным кодом:

  1. function my_admin_help($text, $screen) {
  2.     // Проверим, только ли для страницы настроек это применимо
  3.     if (strcmp($screen, MY_PAGEHOOK) == 0 ) {
  4.         $text = ‘Вот некоторая полезная информация, которая поможет вам разобраться с плагином…’;
  5.         return $text;
  6.     }
  7.     // Пусть по умолчанию штуки с помощью будут и на других страницах панели управления
  8.     return $text;
  9. }
  10. add_action( ‘contextual_help’, ‘my_admin_help’ );

9. Мониторинг ошибок сервера из админки

В WordPress можно создавать виджеты и это ни для кого не секрет, в частности, из консоли можно производить мониторинг собственного сервера по средствам виджетов. Сделать это можно, использовав  функцию, которая будет считывать лог файл сервера и выводить ошибки из него в виджете. Также можно будет очистить этот лог файл прямо из админки WP. Для этого используйте следующую функцию:

  1. function slt_PHPErrorsWidget() {
  2.     $logfile = ‘/home/path/logs/php-errors.log’; // Полный пусть до лог файла
  3.     $displayErrorsLimit = 100; // Максимальное количество ошибок, показываемых в виджете
  4.     $errorLengthLimit = 300; // Максимальное число символов для описания каждой ошибки
  5.     $fileCleared = false;
  6.     $userCanClearLog = current_user_can( ‘manage_options’ );
  7.     // Очистить файл?
  8.     if( $userCanClearLog && isset( $_GET[«slt-php-errors»] ) && $_GET[«slt-php-errors»]==»clear» ){
  9.         $handle = fopen( $logfile, «w» );
  10.         fclose( $handle );
  11.         $fileCleared = true;
  12.     }
  13.     // Читаем файл
  14.     if( file_exists( $logfile ) ){
  15.         $errors = file( $logfile );
  16.         $errors = array_reverse( $errors );
  17.         if ( $fileCleared ) echo ‘<p><em>Файл очищен.</em></p>’;
  18.         if ( $errors ) {
  19.             echo ‘<p>’.count( $errors ).’ ошибка’;
  20.             if ( $errors != 1 ) echo ‘s’;
  21.             echo ‘.’;
  22.             if ( $userCanClearLog ) echo ‘ [ <b><a href=»‘.get_bloginfo(«url»).’/wp-admin/?slt-php-errors=clear» onclick=»return confirm(‘Вы уверенны?’);»>ОЧИСТИТЬ ЛОГ ФАЙЛ</a></b> ]’;
  23.             echo ‘</p>’;
  24.             echo ‘<div id=»slt-php-errors» style=»height:250px;overflow:scroll;padding:2px;background-color:#faf9f7;border:1px solid #ccc;»>’;
  25.             echo ‘<ol style=»padding:0;margin:0;»>’;
  26.             $i = 0;
  27.             foreach( $errors as $error ){
  28.                 echo ‘<li style=»padding:2px 4px 6px;border-bottom:1px solid #ececec;»>’;
  29.                 $errorOutput = preg_replace( ‘/[([^]]+)]/’, ‘<b>[$1]</b>’, $error, 1 );
  30.                 if( strlen( $errorOutput ) > $errorLengthLimit ){
  31.                     echo substr( $errorOutput, 0, $errorLengthLimit ).’ […]’;
  32.                 }
  33.                 else
  34.                     echo $errorOutput;
  35.                 echo ‘</li>’;
  36.                 $i++;
  37.                 if( $i > $displayErrorsLimit ){
  38.                     echo ‘<li style=»padding:2px;border-bottom:2px solid #ccc;»><em>Набралось больше чем ‘.$displayErrorsLimit.’ ошибок в файле…</em></li>’;
  39.                     break;
  40.                 }
  41.             }
  42.             echo ‘</ol></div>’;
  43.         }
  44.         else
  45.             echo ‘<p>Ошибок пока нет.</p>’;
  46.     }
  47.     else
  48.         echo ‘<p><em>Произошла ошибка чтения лог файла.</em></p>’;
  49. }
  50. // Добавляем виджет
  51. function slt_dashboardWidgets(){
  52.     wp_add_dashboard_widget( ‘slt-php-errors’, ‘PHP errors’, ‘slt_PHPErrorsWidget’ );
  53. }
  54. add_action( ‘wp_dashboard_setup’, ‘slt_dashboardWidgets’ );

10. Избирательное удаление виджетов для конкретных пользователей и групп

Скрытие некоторых блоков для определенных групп пользователей иногда бывает полезным. Нижеприведенный код показывает как удалить блок произвольных полей на странице создания/редактирования поста для пользователя с уровнем ниже 5:

  1. function customize_meta_boxes(){
  2.     // получим данные текущего пользователя
  3.     global $current_user;
  4.     get_currentuserinfo();
  5.     // Если уровень текущего пользователя ниже 5, удалим блок произвольных полей
  6.     if ($current_user->user_level < 5)
  7.     remove_meta_box(‘postcustom’, ‘post’, ‘normal’);
  8. }
  9. add_action(‘admin_init’,’customize_meta_boxes’);

Этот код также как и остальные вставляем в functions.php

Что касается всяких там регалий пользователей, читайте на официальных страницах codex.wordpress.org(знание англ приветствуется).

11. Упрощаем ссылку входа

Ссылка на страницу входа (логина) в WordPress выглядит: http://site.ru/wp-login.php, т.е. для входа нужно набирать в адресной строке: wp-login.php что менее удобно чем просто login, поэтому логично поправить этот момент и сделать так, чтобы по ссылке http://site.ru/login пользователя бы перекидывало на страницу http://site.ru/wp-login.php. Задача реализуется 2-мя способами:

1. дополняем файл .htaccess такой строкой:

  1. RewriteRule ^login$ http://site.ru/wp-login.php [NC,L]

Не забудьте site.ru заменить на свой сайт.

2. вставляем код в functions.php:

  1. /* редирект с login на /wp-login.php  и с admin на /wp-admin */
  2. add_action(‘template_redirect’, ‘kama_login_redirect’);
  3. function kama_login_redirect(){
  4.     if( strpos($_SERVER[‘REQUEST_URI’], ‘login’)!==false )
  5.         $loc = ‘/wp-login.php’;
  6.     elseif( strpos($_SERVER[‘REQUEST_URI’], ‘admin’)!==false )
  7.         $loc = ‘/wp-admin/’;
  8.     if( $loc ){
  9.         header( ‘Location: ‘.get_option(‘site_url’).$loc, true, 303 );
  10.         exit;
  11.     }
  12. }

Этот пример удобнее тем, что нет никаких site.ru… и не надо редактировать .htaccess — все изменения остаются как бы «внутри» темы.


12. Умный показ ошибок PHP

Одним из элементов защиты блога от взлома, является отключение вывода ошибок PHP на экран. Поэтому на рабочем сервере все же лучше, чтобы ошибки не показывались. По умолчанию, на многих серверах так и сделано, но во время работы над сайтом, а это часто бесконечный процесс, ошибки появляются постоянно и всегда включать/выключать становится все сложнее с каждым разом. Поэтому мне пришел в голову такой прием: показывать ошибки PHP только, если пользователь зарегистрирован и иммет права администратора, для этого вставьте такой код в functions.php:

  1. add_action(‘init’, ‘enable_errors’);
  2. function enable_errors(){
  3.     if( $GLOBALS[‘user_level’] < 5 )
  4.         return;
  5.     error_reporting(E_ALL ^ E_NOTICE);
  6.     ini_set(«display_errors», 1);
  7. }

Перед установкой кода убедитесь, что показ ошибок выключен и конфигурация PHP позволяет включить ошибки таким способом (обычно он работает).

Важно! При таком способе включения ошибок, PHP ошибки допущенные в functions.php (файл куда мы вставили код) отображаться не будут!

На этом, пожалуй, все.

Мой блог находят по следующим фразам

Рубрики: WordPress

Комментарии закрыты.

Портфолио

Популярные записи

ДЕНЬ ПЕРВЫЙ

Итак, вы получили новую базу, с перенесенными данными ...

Металлическое кольцо

Создайте новое изображение (ширина и высота должны быть ...

Детализация

С помощью выделения создайте необходимую вам область. Залейте выбранную ...

Кожаный переплет

Начнем с цвета, подобно приведенному ниже. Примените фильтр texturizer/canvas на 100% ...

Отделение фона

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

Реклама

Спонсоры

Яндекс.Метрика