Архив мая, 2010

  • Перезагрузка мозга

    4

    Сегодня мой знакомый рассказал мне об интересном способе «перезагрузки» мозга, чтобы снять с него усталость и продолжать работать. Нужно это для поддержки аврального образа жизни, который, к сожалению, сейчас ведут многие. Сразу оговорюсь: способ помогает только снять симптом усталости, вы будете чувствовать себя свежим и выспавшимся, пропадет вялость и тяжесть в конечностях.

    Нам потребуется 15 минут свободного времени, чашка кофе, и возможность уединиться и поспать.

    Итак, вы устали, валитесь сног... залпом выпиваете чашку кофе и ложитесь спать. Предварительно поставьте будильник на 15 минут. За это время оргазизм сможет побывать только в стадии быстрого сна, в которой, судя по данным википедии, происходит упорядочивание информации, но не успеет провалиться в медленный сон. Через 15 минут вас разбудит будильник, и вы будете чувствовать себя как после нормального восьмичасового сна!

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

    Тело после такого сна не отдохнет, но голова будет свежая и вы снова сможете думать =)

  • Защита продажных ссылок

    3

    Озаботился не так давно защитой своих сайтов от детекторов продажных ссылок, типа http://www.venality.ru. Если вы не защищаете продажные ссылки, попробуйте ввести туда адрес страницы, на которой у вас проданы ссылки, он скорее всего определит их. Работает он просто: к адресу страницы добавляются динамические параметры, вроде ?sape=1, в результате чего страница для скрипта биржи ссылок становится уже другой, и ссылки с нее пропадают. Хотя, ппо факту, ничего другого на странице не меняется.

    Конечно, сомнительно, что поисковики будут так фильтровать продажные ссылки, но лучше перестраховаться =)

    В сети полно скриптов на эту тему, некоторые занимают по 100 и больше строк! Я обошелся всего двумя =) Но скажу сразу, у меня почти все сайты на Wordpress, и скрипт писался именно под вордпресс с включенным ЧПУ. Вот эти строки нужно добавить в шаблон header.php, они должны быть самыми первыми, до тега HTML и DOCUTYPE:

    < ?
    $url = explode('?', $_SERVER['REQUEST_URI']);
    if ($url[1] AND (!$_GET['s'])) header('Location: http://'.$_SERVER['HTTP_HOST'].$url[0]);
    ?>

    В первой строке мы делим URL-адрес на две части: в одной адрес самой страницы, типа index.html, а в другой — все дополнительные параметры, все, что после знака вопроса.

    Во второй строке мы проверяем, есть ли что-то во второй части адреса, и не производился ли поиск ($_GET['s'] проверяет, не установлена ли переменная s, в кооторой задается строка поиска в вордпрессе)

    Если есть какие-то дополнительные параметры в строке, и если это не строка поиска, то идет перенаправление на страницу без параметров. Элементарно =)

    На самом деле, мне кажется тут нужно быть немного строже, делать не перенаправление, а отдавать ошибку 404, типа «страница не найдена», ибо это логично — нет такой страницы, с такими параметрами. Посмотрите, например, как сделано в Гугле, если подставить левый параметр, то выдается ошибка 404.

    Если кто хочет отдавать ошибку, то замените вторую строку скрипта на:

    if ($url[1] AND (!$_GET['s'])) header('HTTP/1.0 404 Not Found');

    Я пока поставил оба варианта, на разных сайтах. Ни один детектор продажных ссылок не определяет факт продажности =) Пользуйтесь, на здоровье!

    Кстати, спустя какое-то время доработал скрипт, теперь уже в две строки не уложился, зато предусмотрен список разрешенных параметров, которые не выбрасываются, зато все остальные вырезаются. Вот он:

    < ?php
    $url = explode('?', $_SERVER['REQUEST_URI']);
    $allows = array('s', 'cid', 'replytocom', 'action', 'ads_basecat', 'page_id', 'ADS_EDIT_POST');
    parse_str($url[1], $qv);
    foreach ($qv as $key => $val) {
    	if (in_array($key, $allows)) $q[] = $key.'='.$val;
    	else $dis = 1;
    }
    if ($dis == 1) {
    	if (sizeof($q) != 0) header('Location: http://'.$_SERVER['HTTP_HOST'].$url[0].'?'.implode('&', $q));
    	if (sizeof($q) == 0) header('Location: http://'.$_SERVER['HTTP_HOST'].$url[0]);
    }
    ?>

    В переменную $allows вписываем все параметры, которые нам не надо вырезать (через запятую, и в апострофах). В данном скрипте у меня записаны некоторые переменные вордпресса и плагинов, которыми я пользуюсь.

  • Модифицируем галерею Wordpress

    8

    Для сайта с рецептами приготовления блюд с иллюстрациями каждого шага, потребовалась простая и наглядная система добавления шагов-рисунков с кратким описанием каждого шага. В стандартной галерее вордпресса (шорткод GALLERY) уже реализован весь необходимый функционал: можно пачкой загружать фотки, прописывать к ним названия, описания и выводить в нужном порядке. Однако есть несколько «НО»:

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

    В общем, разработчикам вордпресса есть еще над чем работать, надеюсь, в третьей ветке значительным изменениям подвергнется и стандартная галерея, тогда можно будет со спокойной душой выкинуть тормознутые галереи-плагины типа «NextGEN Gallery». Кстати, используя данный плагин вполне возможно выполнить поставленную задачу, однако такое решение выглядит несколько туповато, учитывая что все необходимые возможности уже реализованы в стандартной галереи, и все дело лишь в ее внешнем виде. Зачем изобретать велосипед, если можно просто его модернизировать?

    Модернизируем наш «велосипед»

    Любителям на досуге пописать плагинчики для вордпресса конечно же известны функции add_shortcode и remove_shortcode, первая регистрирует, а вторая удаляет регистрацию  шорткода. Шорткоды, если кто не знает, это специальные кодовые слова, которые можно прописывать прямо в теле статьи, и которые вызывают какую-то функцию. Например, шорткод CAPTION служит для вставки изображения с подписью, а шорткод GALLERY — необходимую нам стандартную галерею вордпресс.

    Нам нужно всего лишь переписать функцию вывода на экран галереи и сделать так, чтобы шортег GALLERY вызывал именно нашу функцию, а не стандартную. Сделать это проще, чем вы можете подумать =)

    В первую очередь нам нужно отключить стандартную функцию галереи. Открываем файл functions.php, и вставляем в конец файла (до знака «?>») строку:

    remove_shortcode('gallery');

    Затем нам нужна новая функция вывода галереи. Крутые программисты наверняка напишут ее сами, но лично мне нужно всего лишь добавить пару фишек к стандартной галерее, поэтому я просто немного изменю стандартную функцию, текст которой находится в файле wp-includes/media.php и называется gallery_shortcode. Файл большой, поэтому воспользуйтесь функцией поиска.

    Для версии вордпресс 2.9.2 эта функция выглядит так:

    function gallery_shortcode($attr) {
    	global $post, $wp_locale;
     
    	static $instance = 0;
    	$instance++;
     
    	// Allow plugins/themes to override the default gallery template.
    	$output = apply_filters('post_gallery', '', $attr);
    	if ( $output != '' )
    		return $output;
     
    	// We're trusting author input, so let's at least make sure it looks like a valid orderby statement
    	if ( isset( $attr['orderby'] ) ) {
    		$attr['orderby'] = sanitize_sql_orderby( $attr['orderby'] );
    		if ( !$attr['orderby'] )
    			unset( $attr['orderby'] );
    	}
     
    	extract(shortcode_atts(array(
    		'order'      => 'ASC',
    		'orderby'    => 'menu_order ID',
    		'id'         => $post->ID,
    		'itemtag'    => 'dl',
    		'icontag'    => 'dt',
    		'captiontag' => 'dd',
    		'columns'    => 3,
    		'size'       => 'thumbnail',
    		'include'    => '',
    		'exclude'    => ''
    	), $attr));
     
    	$id = intval($id);
    	if ( 'RAND' == $order )
    		$orderby = 'none';
     
    	if ( !empty($include) ) {
    		$include = preg_replace( '/[^0-9,]+/', '', $include );
    		$_attachments = get_posts( array('include' => $include, 'post_status' => 'inherit', 'post_type' => 'attachment', 'post_mime_type' => 'image', 'order' => $order, 'orderby' => $orderby) );
     
    		$attachments = array();
    		foreach ( $_attachments as $key => $val ) {
    			$attachments[$val->ID] = $_attachments[$key];
    		}
    	} elseif ( !empty($exclude) ) {
    		$exclude = preg_replace( '/[^0-9,]+/', '', $exclude );
    		$attachments = get_children( array('post_parent' => $id, 'exclude' => $exclude, 'post_status' => 'inherit', 'post_type' => 'attachment', 'post_mime_type' => 'image', 'order' => $order, 'orderby' => $orderby) );
    	} else {
    		$attachments = get_children( array('post_parent' => $id, 'post_status' => 'inherit', 'post_type' => 'attachment', 'post_mime_type' => 'image', 'order' => $order, 'orderby' => $orderby) );
    	}
     
    	if ( empty($attachments) )
    		return '';
     
    	if ( is_feed() ) {
    		$output = "\n";
    		foreach ( $attachments as $att_id => $attachment )
    			$output .= wp_get_attachment_link($att_id, $size, true) . "\n";
    		return $output;
    	}
     
    	$itemtag = tag_escape($itemtag);
    	$captiontag = tag_escape($captiontag);
    	$columns = intval($columns);
    	$itemwidth = $columns > 0 ? floor(100/$columns) : 100;
    	$float = $wp_locale->text_direction == 'rtl' ? 'right' : 'left'; 
     
    	$selector = "gallery-{$instance}";
     
    	$output = apply_filters('gallery_style', "
    		<style type='text/css'>
    			#{$selector} {
    				margin: auto;
    			}
    			#{$selector} .gallery-item {
    				float: {$float};
    				margin-top: 10px;
    				text-align: center;
    				width: {$itemwidth}%;			}
    			#{$selector} img {
    				border: 2px solid #cfcfcf;
    			}
    			#{$selector} .gallery-caption {
    				margin-left: 0;
    			}
    		</style>
    		<!-- see gallery_shortcode() in wp-includes/media.php -->
    		<div id='$selector' class='gallery galleryid-{$id}'>");
     
    	$i = 0;
    	foreach ( $attachments as $id => $attachment ) {
    		$link = isset($attr['link']) && 'file' == $attr['link'] ? wp_get_attachment_link($id, $size, false, false) : wp_get_attachment_link($id, $size, true, false);
     
    		$output .= "< {$itemtag} class='gallery-item'>";
    		$output .= "
    			< {$icontag} class='gallery-icon'>
    				$link
    			";
    		if ( $captiontag && trim($attachment->post_excerpt) ) {
    			$output .= "
    				< {$captiontag} class='gallery-caption'>
    				" . wptexturize($attachment->post_excerpt) . "
    				";
    		}
    		$output .= "";
    		if ( $columns > 0 && ++$i % $columns == 0 )
    			$output .= '<br style="clear: both" />';
    	}
     
    	$output .= "
    			<br style='clear: both;' />
    		</div>\n";
     
    	return $output;
    }

    Эту функцию нужно просто вставить в файл functions.php вашей темы и внести нужные вам изменения. Скорее всего потребуются небольшие знания PHP. Я всего лишь добавил следующий код:

    		if (trim($attachment->post_content) ) {
    			$output .= "
    				< {$captiontag} class='gallery-description'>
    				" . wptexturize($attachment->post_content) . "
    				";
    		}

    сразу после:

    		if ( $captiontag && trim($attachment->post_excerpt) ) {
    			$output .= "
    				< {$captiontag} class='gallery-caption'>
    				" . wptexturize($attachment->post_excerpt) . "
    				";
    		}

    Благодаря этой вставке, в галерее теперь будут отображаться описания к файлам. Все просто!

    Если не хотите, чтобы в галерее отображалась миниатюра, просто замените строку:

    'exclude'    => ''

    На:

    'exclude'    => get_post_meta($post->ID, '_thumbnail_id', 1)

    Теперь нужно снова включить шортаг GALLERY, но уже с нашей функцией. Кстати, название функции необходимо изменить, иначе это вызовет фатальную ошибку (старая функция галереи все еще доступна в файле media.php, и я не советую ее удалять!) Просто переименуйте функцию из gallery_shortcode в, например, new_gallery_shortcode.

    Чтобы шортаг снова заработал, добавьте в functions.php строку:

    add_shortcode('gallery', 'new_gallery_shortcode');

    Она должна быть после remove_shortcode и нашей новой функции.

    Кстати, не обязательно отключать функцию стандартной галереи, можно сделать все тоже самое, но в add_shortcode написать, например:

    add_shortcode('new_gallery', 'new_gallery_shortcode');

    Тем самым мы создадим новый шорткод NEW_GALLERY и сможем его использовать при написании поста (ставлять придется ручками, в режиме HTML. Таким макаром можно связать любую функцию с шорткодом, какую захотите!

    Вот, собственно, и все =) Сохраняем файл и смотрим результат! Для людей, немного знакомых с программированием, не будет проблемой дописать любые фишки к стандартной галерее, и значительно расширить ее функционал, без всяких плагинов.