my blog my blog

Tag: 插件
WordPress高亮插件推荐之Syntax Highlighter Compress

 

前几天顾客买主机的时候说想让奶牛帮着安装个高亮插件,奶牛平时虽然有写一些代码出来,但是都是命令类的,所以也没用过高亮代码。前阵子帮群里MM小青青在blogcn那里调用过它们的高亮插件,每次插入代码都需要手动来调整,不是很舒服,这次介绍的这款插件Syntax Highlighter Compress可以直接在工具栏中找到,插入代码的时候直接插入就ok,不用手动切换到html上来修改代码了。

插件支持的代码类型有:

AppleScript, ActionScript3, Bash/shell, Coldfusion, C#, C++, CSS, Delphi, Diff, Erlang, Groovy, JavaScript, Java, JavaFX, Perl, PHP, Plain Text, Python, Ruby, Scala, SQL, Visual Basic , XML

Syntax Highlighter Compress下载:点此下载

安装方法,直接解压缩到wordpress的wp-content/plugins下面就可以了。

火狐插件推荐>>Pearl Crescent Page Saver Basic<<将网页保存为图片

 

今天为大家推荐一款火狐浏览器上很好用的网页保存插件Pearl Crescent Page Saver Basic,跟我们传统的保存不同,Pearl Crescent Page Saver Basic是将网页完整的保存为图片,功能很实用。我们甚至可以用此功能剪切下来的图片合成PDF文档来方便观看。

插件安装很简单,下载Pearl Crescent Page Saver Basic的插件,然后直接从桌面拖到firefox的地址栏即可自动识别并开始安装。

Pearl Crescent Page Saver Basic下载:点此下载Pearl Crescent Page Saver Basic

WordPress垃圾评论克星Akismet

 

今天奶牛一看后台的评论,竟然一天暴增了30+条垃圾评论(昨天总共才30条),狂汗,还好前几天装了垃圾评论的屏蔽插件Akismet。话说奶牛装垃圾评论的屏蔽插件的时候还是在端午,那阵子奶牛出去玩,害怕有垃圾评论,所以才开的,今天才发现效果只明显。Akismet确实挺强悍的,一般的垃圾评论都能kill掉。下面就来说说这个小插件。

这个插件是WordPress自带的一个小插件,启用需要一个Akismet API Key,这个可以在安装结束激活插件之后的Akismet配置中找到,你可以根据提示注册一个就可以正常使用了。Akismet不需要什么设置,一切都走网络,只要开启就可以了,开启成功后在Akismet的配置中就可以看到绿色的网络连通。

有需要的童鞋可以在WP的后台添加插件搜索Akismet就可以进行安装了。

wordpress评论回复邮件通知插件与非插件双法总结

 

从前天就开始搞wordpress的评论回复的邮件通知,因为wp的通知一般是用mai()函数,所以很多win的主机需要想其它方法实现邮件通知,奶牛虽然用的是linux的主机,但是这个邮件通知可是让我费了不少心思,昨天总算找了个比较满意的方法,下面就来跟大家分享一下这个评论回复的邮件通知功能。

插件法

奶牛先来说说插件,先说大名鼎鼎的wp thread comment。

wp thread comment可谓是在邮件通知评论者的比较出名的插件了,功能也很强大,不仅可以实现Ajax嵌套回复,而且还可以根据不同的情况实现邮件回复的选择,比如全部回复啦,让评论者自己选择啦,而且对于大多数主题都会适用,可谓算是通吃型的插件,但是也有例外,就是奶牛现在用的这个主题,主题本来有嵌套,而且挺漂亮的,但是用了wp thread comment后就会变形,看着很不爽,但是这个插件的功能确实很赞,一般的主题都可以用,所以奶牛在这里依然很推荐。

既然wp thread comment用不了了,奶牛只能换其它的插件,搜索开始,先找来了一个comment reply notification,这个是国人水煮鱼的作品,但是貌似这个插件确实是针对wordpress 2.7的,奶牛博客是wordpress 2.9.2的,经过折腾后发现并不能发送邮件,呃,继续换。

mail to commmenter,这个插件也比较不错,可以自动通知管理员和评论者(虽然wordpress本身也有通知管理员的功能),你还可以通过这个插件的测试功能看看是不是确实可以发送邮件,经过测试,发送邮件是可以的,但是问题总是存在,就是回复的时候无法后台实现邮件回复(这点儿就很鸡肋了,管理员不能总在前台丫),然后就是回复的时候必须通过按钮加入需要邮件通知的人的信息,但是奶牛测试的时候回复的信息默认加入的老是最后一个评论者的,呃,然后就跟fcola询问了一下,他下班之前告诉我他解决了,然后给了我个地址,是zww写的,用 jQuery 实现点击回复之后显示@用户名的效果  ,奶牛摘取一下更改步骤过来

1. 确定自己的主题评论结构基本是 WordPress 默认的结构(也就是说主题的评论结构比较标准),而且用的是 WordPress 2.7 以上版本的 wp_list_comments 函数,具体可以参考 http://codex.wordpress.org/Template_Tags/wp_list_comments

2. 确定自己已经加载 jQuery 库,如果没有加载,在主题文件 header.php 里面找到下面这个

<?php wp_head(); ?>

在 它前面加入以下代码:(注:jquery 1.3.2 一样效果)

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.2.6/jquery.min.js"></script>
<script type="text/javascript" src="<?php bloginfo(‘template_directory’); ?>/reply.js"></script>

3. 把下面的 jQuery 代码保存为 reply. js 文件,并存到主题所在目录(也可以加在主题本身已有的 js 文件里面)

/* @reply js by zwwooooo */
jQuery(document).ready(function($){ //Begin jQuery
$(‘.reply’).click(function() {
var atid = ‘"#’ + $(this).parent().attr("id") + ‘"’;
var atname = $(this).prevAll().find(‘cite:first’).text();
$("#comment").attr("value","<a href=" + atid + ">@" + atname + " </a>").focus();
});
$(‘.cancel-comment-reply a’).click(function() { //点击取消回复评论清空评论框的内容
$("#comment").attr("value",);
});
}) //End jQuery

4. OK 啦,可以试试了。加些说明:如果你的主题评论结构符合上面第 1 点所说,原则上支持 WordPress 2.7 版本以上的自带评论嵌套

奶牛实验了一下,还是没成功,唉,因为奶牛也是属于门外汉型的,不懂php,不懂java,不懂…..唉,没办法,大家有用的就自己拿去实验吧。

试用的最后一个插件是ReplyMe,这个插件功能嘛还不错,但是有一点儿奶牛很不满意,就是评论者发表评论后就先给人家回复一条告诉别人回复成功的信息,唉,说实话自己想想都挺讨厌的,也许改改也会很好用,呃,奶牛不懂代码,闪过~~~

 

非插件法

这个方法也是我现在正在用的,效果很好,自己感觉很完美,跟原生的Ajax嵌套一点儿也不冲突,而且适用范围很广,奶牛这里引用的是Willin Kan 的方法,参考的文章是Comment Mail Notify,方法文章给的很详细,奶牛也就直接拉过来啦,这个方法经过奶牛的测试,相当的不错,而且还不用插件,最主要的是后台回复也可以自动的邮件通知,超赞。

 

這是由《Ajax comments 回應郵件通知》所改進的評論回應郵件通知 (Comment Mail Notify).
主要改進兩個項目:
1. 所有模板都適用, 不只是 Ajax comments.
2. 管理者在後台回覆也可自動發郵件.

安裝步驟:
1. 如果你用了上一版的 "Ajax comments 回應郵件通知", 請先在 comments-ajax.php 刪除上一版的代碼.
2. 在下面三種方式, 選擇你想用的代碼, copy 到 functions.php 的 <?php ….. ?> 區域內.

《評論回應郵件通知》的三種代碼: (按下面的標題可直接滾下去)
一、有勾選欄, 由訪客決定是否要回應郵件通知
二、無勾選欄, 由管理者決定在什麼條件下發郵件
三、所有回覆都發郵件

必須注意的是: 你的服務器一定要有 mail() 功能. 測試方式: 在登入頁故意按下 ‘忘記密碼’, 收到郵件就有 mail() 功能; 沒收到郵件的可以下課了.


一、有勾選欄, 由訪客決定是否要回應郵件通知:

 

(會在模板自動加勾選欄, 如果不想自動加, 可把後面一小段刪除.)

/* comment_mail_notify v1.0 by willin kan. (有勾選欄, 由訪客決定) */
function comment_mail_notify($comment_id) {
$admin_notify = ‘1’; // admin 要不要收回覆通知 ( ‘1’=要 ; ‘0’=不要 )
$admin_email = get_bloginfo (‘admin_email’); // $admin_email 可改為你指定的 e-mail.
$comment = get_comment($comment_id);
$comment_author_email = trim($comment->comment_author_email);
$parent_id = $comment->comment_parent ? $comment->comment_parent : ;
global $wpdb;
if ($wpdb->query("Describe {$wpdb->comments} comment_mail_notify") == )
$wpdb->query("ALTER TABLE {$wpdb->comments} ADD COLUMN comment_mail_notify TINYINT NOT NULL DEFAULT 0;");
if (($comment_author_email != $admin_email && isset($_POST[‘comment_mail_notify’])) || ($comment_author_email== $admin_email && $admin_notify == ‘1’))
$wpdb->query("UPDATE {$wpdb->comments} SET comment_mail_notify=’1′ WHERE comment_ID=’$comment_id’");
$notify = $parent_id ? get_comment($parent_id)->comment_mail_notify : ‘0’;
$spam_confirmed = $comment->comment_approved;
if ($parent_id !=  && $spam_confirmed != ‘spam’ && $notify == ‘1’) {
$wp_email = ‘no-r[email protected] . preg_replace(‘#^www\.#’, , strtolower($_SERVER[‘SERVER_NAME’])); // e-mail 發出點, no-reply 可改為可用的 e-mail.
$to = trim(get_comment($parent_id)->comment_author_email);
$subject = ‘您在 [‘ . get_option("blogname") . ‘] 的留言有了回應’;
$message = 
<div style="background-color:#eef2fa; border:1px solid #d8e3e8; color:#111; padding:0 15px; -moz-border-radius:5px; -webkit-border-radius:5px; -khtml-border-radius:5px;">
<p>’ . trim(get_comment($parent_id)->comment_author) . ‘, 您好!</p>
<p>您曾在《’ . get_the_title($comment->comment_post_ID) . ‘》的留言:<br />
 . trim(get_comment($parent_id)->comment_content) . ‘</p>
<p>’ . trim($comment->comment_author) . ‘ 給您的回應:<br />
 . trim($comment->comment_content) . ‘<br /></p>
<p>您可以點擊 <a href="’ . htmlspecialchars(get_comment_link($parent_id)) . ‘">查看回應完整內容</a></p>
<p>歡迎再度光臨 <a href="’ . get_option(‘home’) . ‘">’ . get_option(‘blogname’) . ‘</a></p>
<p>(此郵件由系統自動發出, 請勿回覆.)</p>
</div>’;
$from = "From: \"" . get_option(‘blogname’) . "\" <$wp_email>";
$headers = "$from\nContent-Type: text/html; charset=" . get_option(‘blog_charset’) . "\n";
wp_mail( $to, $subject, $message, $headers );
//echo ‘mail to ‘, $to, ‘<br/> ‘ , $subject, $message; // for testing
}
}
add_action(‘comment_post’, ‘comment_mail_notify’);
/* 自動加勾選欄 */
function add_checkbox() {
echo ‘<input type="checkbox" name="comment_mail_notify" id="comment_mail_notify" value="comment_mail_notify" checked="checked" style="margin-left:20px;" /><label for="comment_mail_notify">有人回覆時郵件通知我</label>’;
}
add_action(‘comment_form’, ‘add_checkbox’);
// — END —————————————-

 


二、無勾選欄, 由管理者決定在什麼條件下發郵件:


/* comment_mail_notify v1.0 by willin kan. (無勾選欄) */
function comment_mail_notify($comment_id) {
$admin_email = get_bloginfo (‘admin_email’); // $admin_email 可改為你指定的 e-mail.
$comment = get_comment($comment_id);
$comment_author_email = trim($comment->comment_author_email);
$parent_id = $comment->comment_parent ? $comment->comment_parent : ;
$to = $parent_id ? trim(get_comment($parent_id)->comment_author_email) : ;
$spam_confirmed = $comment->comment_approved;
if (($parent_id != ) && ($spam_confirmed != ‘spam’) && ($to != $admin_email) && ($comment_author_email ==$admin_email)) {
/* 上面的判斷式,決定發出郵件的必要條件:
($parent_id != ”) && ($spam_confirmed != ‘spam’): 回覆的, 而且不是 spam 才可發, 必需!!
($to != $admin_email) : 不發給 admin.
($comment_author_email == $admin_email) : 只有 admin 的回覆才可發.
可視個人需求修改以上條件.
*/
$wp_email = [email protected] . preg_replace(‘#^www\.#’, , strtolower($_SERVER[‘SERVER_NAME’])); // e-mail 發出點, no-reply 可改為可用的 e-mail.
$subject = ‘您在 [‘ . get_option("blogname") . ‘] 的留言有了回應’;
$message = 
<div style="background-color:#eef2fa; border:1px solid #d8e3e8; color:#111; padding:0 15px; -moz-border-radius:5px; -webkit-border-radius:5px; -khtml-border-radius:5px;">
<p>’ . trim(get_comment($parent_id)->comment_author) . ‘, 您好!</p>
<p>您曾在《’ . get_the_title($comment->comment_post_ID) . ‘》的留言:<br />
 . trim(get_comment($parent_id)->comment_content) . ‘</p>
<p>’ . trim($comment->comment_author) . ‘ 給您的回應:<br />
 . trim($comment->comment_content) . ‘<br /></p>
<p>您可以點擊 <a href="’ . htmlspecialchars(get_comment_link($parent_id)) . ‘">查看回應完整內容</a></p>
<p>歡迎再度光臨 <a href="’ . get_option(‘home’) . ‘">’ . get_option(‘blogname’) . ‘</a></p>
<p>(此郵件由系統自動發出, 請勿回覆.)</p>
</div>’;
$from = "From: \"" . get_option(‘blogname’) . "\" <$wp_email>";
$headers = "$from\nContent-Type: text/html; charset=" . get_option(‘blog_charset’) . "\n";
wp_mail( $to, $subject, $message, $headers );
//echo ‘mail to ‘, $to, ‘<br/> ‘ , $subject, $message; // for testing
}
}
add_action(‘comment_post’, ‘comment_mail_notify’);
// — END —————————————-

 

 

三、所有回覆都發郵件:

(當然, 在底層的評論不發郵件, 回覆的才發)

/* comment_mail_notify v1.0 by willin kan. (所有回覆都發郵件) */
function comment_mail_notify($comment_id) {
$comment = get_comment($comment_id);
$parent_id = $comment->comment_parent ? $comment->comment_parent : ;
$spam_confirmed = $comment->comment_approved;
if (($parent_id != ) && ($spam_confirmed != ‘spam’)) {
$wp_email = [email protected] . preg_replace(‘#^www\.#’, , strtolower($_SERVER[‘SERVER_NAME’])); //e-mail 發出點, no-reply 可改為可用的 e-mail.
$to = trim(get_comment($parent_id)->comment_author_email);
$subject = ‘您在 [‘ . get_option("blogname") . ‘] 的留言有了回應’;
$message = 
<div style="background-color:#eef2fa; border:1px solid #d8e3e8; color:#111; padding:0 15px; -moz-border-radius:5px; -webkit-border-radius:5px; -khtml-border-radius:5px;">
<p>’ . trim(get_comment($parent_id)->comment_author) . ‘, 您好!</p>
<p>您曾在《’ . get_the_title($comment->comment_post_ID) . ‘》的留言:<br />
 . trim(get_comment($parent_id)->comment_content) . ‘</p>
<p>’ . trim($comment->comment_author) . ‘ 給您的回應:<br />
 . trim($comment->comment_content) . ‘<br /></p>
<p>您可以點擊 <a href="’ . htmlspecialchars(get_comment_link($parent_id)) . ‘">查看回應完整內容</a></p>
<p>歡迎再度光臨 <a href="’ . get_option(‘home’) . ‘">’ . get_option(‘blogname’) . ‘</a></p>
<p>(此郵件由系統自動發出, 請勿回覆.)</p>
</div>’;
$from = "From: \"" . get_option(‘blogname’) . "\" <$wp_email>";
$headers = "$from\nContent-Type: text/html; charset=" . get_option(‘blog_charset’) . "\n";
wp_mail( $to, $subject, $message, $headers );
//echo ‘mail to ‘, $to, ‘<br/> ‘ , $subject, $message; // for testing
}
}
add_action(‘comment_post’, ‘comment_mail_notify’);
// — END —————————————-

其實以上三段代碼都是同一個程式, 內容幾乎完全相同, 只是怕有人不會改, 出錯時又來找我發問, 所以放了三種寫法供各位直接 copy.
感謝 
萬戈童鞋 幫忙測試, 我們試用了幾天還沒出問題, 本想試用兩個星期再公佈, 算一算時間剛好在過年後, 到時候我可能還在休假, 還是現在先發出來當作是送給各位的過年禮物吧! 新年快樂!

後記: 忘了加上 spam 檢查, 幸虧萬戈童鞋及時提醒, 謝謝萬戈! (2/10 22:24 已更新)

◎2010/4/2 又發現這程式在評論分頁的 get_comment_link() 有個 bug.
這 bug 對使用 comments 和 trackbacks/pingbacks 分離的情況才會出現, 沒分離的是沒影響.
當直接叫用 get_comment_link() 因為沒經過 wp_list_comments(‘type=comment’) 函數, 它會以所有的評論作為分頁對象. 所以 trackbacks/pingbacks 數量多的時候會讓 cpage 多算了, 本來是 cpage=7 會成了 cpage=8, 所以點擊郵件裏的 "查看回應完整內容" 會找不到正確評論頁面.

— 修正方式 —-
將以上的:

get_comment_link($parent_id)

改成:

get_comment_link($parent_id, array(‘type’ => ‘comment’))

加入的參數是讓它選取 comment 數量計算就好.
評論式樣有使用 comments 和 trackbacks/pingbacks 分離的童鞋, 請進行修改. 沒用到的就不能改.

 

 

 

ok,总结写完,折腾了两天总算是把这个邮件回复给搞定了,wordpress丫,还就是得折腾呢~~~

wordpress20款常用插件推荐

 

奶牛用wordpress开博已经接近一个月了。一个月下来对wordpress的插件感受颇深,wordpress有些插件可以为我们的blog增加一些小功能,有的插件可以帮助我们更好的管理后台,帮助我们做好备份工作、发布推广工作。ok,下面奶牛就把自己这一月来接触的好用的插件跟大家来分享一下~~~

后台插件:

1.Google XML Sitemaps

自从网站被google收录之后,每天都有google的bot来爬,但是几周下来发现有很多不需要发布的页面也都被搜索引擎给抓取去了,而有了这款插件,我们就可以限制让google的bot都抓取哪些页面了。插件会自动在网站根目录下生成sitemap文件,只需配合robots.txt文件我们就可以规定bot访问抓取的页面了。

2.Baidu Sitemap Generator

这款baidu sitemap是柳城的作品,功能嘛跟Google XML Sitemaps差不多,只不过一个是针对google的,一个是针对baidu的,毕竟baidu是中国第一大搜索引擎,所以对搜索引擎优化一些对于提高我们的网站收录有很大的帮助。

3. WP Super Cache

这款插件是针对优化缓存功能的,软件开启之后会帮助我们页面的缓存,对于提高网站的载入速度有一些帮助。软件有两种模式,使用下来效果也比较不错。

4.ChenPress

这款插件是默认编辑器的替代插件,具有比较完备的文本编辑功能,上手很快,可以帮助我们更好的为我们blog文章排版、控制格式等。

5. All in One SEO Pack

大名鼎鼎的seo全能工具all in one SEO工具就是它啦,该插件只要是为了搜索引擎优化,可以为我们的blog文章和主页进行关键词,描述等定义,可以帮助搜索引擎更好的抓取文章的内容。但是貌似baidu对这个插件的优化效果不怎么感冒,很多网友反映用了该款插件之后baidu的收录收到影响。所以奶牛也把该插件的部分功能给关闭了,不过主页的关键字,描述,文章的标题格式设定还是用的这个插件。

6.Online Backup for WordPress

wordpress的在线备份工具,可以将备份的内容发送到指定邮箱,对于不方便经常去管理服务器进行后台备份的朋友,这款插件可谓是首选哦。

7.Google Analytics Settings

Google Analytics的wordpress支持,需要在google开启Google Analytics服务后将获得的编号输入即可实现google的分析(就是google的站长分析)。

页面优化类:

8.MobilePress

这款插件可以为手机用户提供简洁的blog界面,对于我们的blog面向手机用户提供了很棒的支持。而且还提供了几款皮肤,博友们可以根据个人的需要进行修改定制。

9.WP Thread Comment

这款插件是对评论优化的工具,可以设置评论回复邮件提醒功能,并且还有评论嵌套显示的功能哦。

10.wp-limit-posts-automatically

文章自动截断插件,可以设置首页的显示,比如设置截断特定字数,或者设定截取首段,而且奶牛使用的是中文版本,比从前的英文版本对中文提供了更好的支持。

11.wp-posturl

这个可以根据博主需要在文章后面自动添加文章信息和相关的版权说明,比如奶牛博客的文章背后那句文章出自….如需转载请注明。

12.custom-smilies-se

这个可以自定义回复时候是否可以添加表情哦。

13.wp-postviews

显示访问者的东东,可以为你记录每篇文章的访客数量,而且还提供了widget哦~~~

14.wp-pagenavi

可以为你的文章提供下一页效果,对于文章较长的博主比较有用。

15.wp-related-posts

相关文章插件,在你的文章结尾添加相关文章,可以帮博主吸引更多读者进行深层访问。

widget类:

16.wp-cumulus

标签云,像一个小flash一样放在widget的位置,醒目又简洁,比传统的文字标签云更能吸引读者,而且动态效果可以给访客不错的体验。

17.wp-polls

投票插件,可以在侧边栏放置的投票插件,可以根据需要进行投票哦~~~

18.genki-announcement

公告插件,可以定制公告,发布一些博主公告。

19.enhanced-categories

不错的分类widget,可以将你的文章分类更清晰调理地表现出来。

20.Image Widget

侧栏图片插件,这款插件可以帮你添加图片到侧栏中,也让你省去了麻烦。

 文章涉及的插件奶牛已经打包了,需要的朋友可以 点此下载

firefox邮件提醒插件,邮件来了就知道

很多时候,我们往往使用多个邮箱,在不同的邮箱间切换实在是件麻烦事儿,奶牛为大家介绍一个firefox的邮件提醒插件WebMail Notifier,所有的问题都会迎刃而解。

WebMail Notifier插件的下载地址是https://addons.mozilla.org/en-US/firefox/addon/4490/

进入页面,点击add to firefox系统就会自动进行安装,安装完成后firefox提示重新启动浏览器,点击是,完成重启过程。

这时,firefox的右下角会多一个邮件的小图标,右键单击选择选项按钮,然后就可以进行添加e-mail帐号等设置了,这款插件支持目前主流的gmail, yahoo, hotmail, aol, daum, naver, nate, paran等邮箱。ok,介绍到这里,喜欢就去试试吧~

密码保护:Ubuntu 10.04 ҆翻҆墙,firefox轻松看youtube,密码free

这是一篇受密码保护的文章,您需要提供访问密码: