wordpress调用函数大全

WordPress模板基本文件

style.css 样式表文件
index.php 主页文件
single.php 日志单页文件
page.php 页面文件
archvie.php 分类和日期存档页文件
searchform.php 搜索表单文件
search.php 搜索页面文件
comments.php 留言区域文件(包括留言列表和留言框)
404.php 404错误页面
header.php 网页头部文件
sidebar.php 网页侧边栏文件
footer.php 网页底部文件

WordPress Header头部 PHP代码

注: 也就是位于<head>和</head>之间的PHP代码

<?php bloginfo(’name’); ?> 网站标题
<?php wp_title(); ?> 日志或页面标题
<?php bloginfo(’stylesheet_url’); ?> WordPress主题样式表文件style.css的相对地址
<?php bloginfo(’pingback_url’); ?> WordPress博客的Pingback地址
<?php bloginfo(’template_url’); ?> WordPress主题文件的相对地址
<?php bloginfo(’version’); ?> 博客的WordPress版本
<?php bloginfo(’atom_url’); ?> WordPress博客的Atom地址
<?php bloginfo(’rss2_url’); ?> WordPress博客的RSS2地址
<?php bloginfo(’url’); ?> WordPress博客的绝对地址
<?php bloginfo(’name’); ?> WordPress博客的名称
<?php bloginfo(’html_type’); ?> 网站的HTML版本
<?php bloginfo(’charset’); ?> 网站的字符编码格式

WordPress 主体模板 PHP代码

<?php the_content(); ?> 日志内容
<?php if(have_posts()) : ?> 确认是否有日志
<?php while(have_posts()) : the_post(); ?> 如果有,则显示全部日志
<?php endwhile; ?> 结束PHP函数”while”
<?php endif; ?> 结束PHP函数”if”
<?php get_header(); ?> header.php文件的内容
<?php get_sidebar(); ?> sidebar.php文件的内容
<?php get_footer(); ?> footer.php文件的内容
<?php the_time(’m-d-y’) ?> 显示格式为”02-19-08″的日期
<?php comments_popup_link(); ?> 显示一篇日志的留言链接
<?php the_title(); ?> 显示一篇日志或页面的标题
<?php the_permalink() ?> 显示一篇日志或页面的永久链接/URL地址
<?php the_category(’, ‘) ?> 显示一篇日志或页面的所属分类
<?php the_author(); ?> 显示一篇日志或页面的作者
<?php the_ID(); ?> 显示一篇日志或页面的ID
<?php edit_post_link(); ?> 显示一篇日志或页面的编辑链接
<?php get_links_list(); ?> 显示Blogroll中的链接
<?php comments_template(); ?> comments.php文件的内容
<?php wp_list_pages(); ?> 显示一份博客的页面列表
<?php wp_list_cats(); ?> 显示一份博客的分类列表
<?php next_post_link(’ %link ‘) ?> 下一篇日志的URL地址
<?php previous_post_link(’%link’) ?> 上一篇日志的URL地址
<?php get_calendar(); ?> 调用日历
<?php wp_get_archives() ?> 显示一份博客的日期存档列表
<?php posts_nav_link(); ?> 显示较新日志链接(上一页)和较旧日志链接(下一页)
<?php bloginfo(’description’); ?> 显示博客的描述信息

其它的一些WordPress模板代码

/%postname%/ 显示博客的自定义永久链接
<?php the_search_query(); ?> 搜索表单的值
<?php _e(’Message’); ?> 打印输出信息
<?php wp_register(); ?> 显示注册链接
<?php wp_loginout(); ?> 显示登入/登出链接
<!–next page–> 在日志或页面中插入分页
<!–more–> 截断日志
<?php wp_meta(); ?> 显示管理员的相关控制信息
<?php timer_stop(1); ?> 显示载入页面的时间
<?php echo get_num_queries(); ?> 显示载入页面查询

1. wordpress调用最新文章

WordPress最新文章的调用可以使用一行很简单的模板标签wp_get_archvies来实现. 代码如下:

<?php get_archives(‘postbypost’, 10); ?> (显示10篇最新更新文章)

或者

<?php wp_get_archives(‘type=postbypost&limit=20&format=custom’); ?>

后面这个代码显示你博客中最新的20篇文章,其中format=custom这里主要用来自定义这份文章列表的显示样式。具体的参数和使用方法你可 以参考官方的使用说明- wp_get_archvies。(fromat=custom也可以不要,默认以UL列表显示文章标题。)

补充: 通过WP的query_posts()函数也能调用最新文章列表, 虽然代码会比较多一点,但可以更好的控制Loop的显示,比如你可以设置是否显示摘要。具体的使用方法也可以查看官方的说明。

2. wordpress调用随机文章

<?php
$rand_posts = get_posts(‘numberposts=10&orderby=rand’);
foreach( $rand_posts as $post ) :
?>
<!–下面是你想自定义的Loop–>
<li><a href=”<?php the_permalink(); ?>”><?php the_title(); ?></a></li>
<?php endforeach; ?>

3. wordpress调用最新留言

下面是我之前在一个WordPress主题中代到的最新留言代码,具体也记不得是哪个主题了。该代码直接调用数据库显示一份最新留言。其中 LIMIT 10限制留言显示数量。绿色部份则是每条留言的输出样式。

<?php
global $wpdb;
$sql = “SELECT DISTINCT ID, post_title, post_password, comment_ID,
comment_post_ID, comment_author, comment_date_gmt, comment_approved,
comment_type,comment_author_url,
SUBSTRING(comment_content,1,30) AS com_excerpt
FROM $wpdb->comments
LEFT OUTER JOIN $wpdb->posts ON ($wpdb->comments.comment_post_ID =
$wpdb->posts.ID)
WHERE comment_approved = ’1′ AND comment_type = ” AND
post_password = ”
ORDER BY comment_date_gmt DESC
LIMIT 10″;
$comments = $wpdb->get_results($sql);
$output = $pre_HTML;   foreach ($comments as $comment) {
$output .= “n<li>”.strip_tags($comment->comment_author)
.”:” . ” <a href=”” . get_permalink($comment->ID) .
“#comment-” . $comment->comment_ID . “” title=”on ” .
$comment->post_title . “”>” . strip_tags($comment->com_excerpt)
.”</a></li>”;
}   $output .= $post_HTML;
echo $output;?>

4.wordpress调用相关文章

在文章页显示相关文章

<?php

$tags = wp_get_post_tags($post->ID);

if ($tags) {

$first_tag = $tags[0]->term_id;

$args=array(

‘tag__in’ => array($first_tag),

‘post__not_in’ => array($post->ID),

‘showposts’=>10,

‘caller_get_posts’=>1

);

$my_query = new WP_Query($args);

if( $my_query->have_posts() ) {

while ($my_query->have_posts()) : $my_query->the_post(); ?>

<li><a href=”<?php the_permalink() ?>” rel=”bookmark” title=”<?php the_title_attribute(); ?>”><?php the_title();?> <?php comments_number(‘ ‘,’(1)’,'(%)’); ?></a></li>

<?php

endwhile;

}

}

wp_reset_query();

?>

5.wordpress调用指定分类的文章

<?php $posts = get_posts( “category=4&numberposts=10″ ); ?>
<?php if( $posts ) : ?>
<ul><?php foreach( $posts as $post ) : setup_postdata( $post ); ?>
<li>
<a href=”<?php the_permalink() ?>” rel=”bookmark” title=”<?php the_title(); ?>”><?php the_title(); ?></a>
</li>
<?php endforeach; ?>
</ul>
<?php endif; ?>

6.wordpress去评论者链接的评论输出

<?php

global $wpdb;

$sql = “SELECT DISTINCT ID, post_title, post_password, comment_ID,

comment_post_ID, comment_author, comment_date_gmt, comment_approved,

comment_type,comment_author_url,

SUBSTRING(comment_content,1,14) AS com_excerpt

FROM $wpdb->comments

LEFT OUTER JOIN $wpdb->posts ON ($wpdb->comments.comment_post_ID =

$wpdb->posts.ID)

WHERE comment_approved = ’1′ AND comment_type = ” AND

post_password = ”

ORDER BY comment_date_gmt DESC

LIMIT 10″;

$comments = $wpdb->get_results($sql);

$output = $pre_HTML;

foreach ($comments as $comment) {

$output .= “\n<li>”.strip_tags($comment->comment_author)

.”:” . ” <a href=\”” . get_permalink($comment->ID) .

“#comment-” . $comment->comment_ID . “\” title=\”on ” .

$comment->post_title . “\”>” . strip_tags($comment->com_excerpt)

.”</a></li>”;

}

$output .= $post_HTML;

echo $output;?>

7.wordpress调用含gravatar头像的评论输出

<?php

global $wpdb;

$sql = “SELECT DISTINCT ID, post_title, post_password, comment_ID, comment_post_ID, comment_author, comment_date_gmt, comment_approved,comment_author_email, comment_type,comment_author_url, SUBSTRING(comment_content,1,10) AS com_excerpt FROM $wpdb->comments LEFT OUTER JOIN $wpdb->posts ON ($wpdb->comments.comment_post_ID = $wpdb->posts.ID) WHERE comment_approved = ’1′ AND comment_type = ” AND comment_author != ‘郑 永’ AND post_password = ” ORDER BY comment_date_gmt DESC LIMIT 10″;

$comments = $wpdb->get_results($sql);

$output = $pre_HTML;

foreach ($comments as $comment) {

$output .= “\n<li>”.get_avatar(get_comment_author_email(‘comment_author_email’), 18). ” <a href=\”” . get_permalink($comment->ID) . “#comment-” . $comment->comment_ID . “\” title=\”” . $comment->post_title . ” 上的评论\”>”. strip_tags($comment->comment_author) .”: “. strip_tags($comment->com_excerpt) .”</a></li>”;

}

$output .= $post_HTML;

$output = convert_smilies($output);

echo $output;

?>

上面代码把comment_author的值改成你的ID,18是头像大小,10是评论数量。

8.wordpress调用网站统计大全

1、日志总数:

<?php $count_posts = wp_count_posts(); echo $published_posts = $count_posts->publish;?>

2、草稿数目:

<?php $count_posts = wp_count_posts(); echo $draft_posts = $count_posts->draft; ?>

3、评论总数:

<?php echo $wpdb->get_var(“SELECT COUNT(*) FROM $wpdb->comments”);?>

4、成立时间:

<?php echo floor((time()-strtotime(“2008-8-18″))/86400); ?>

5、标签总数:

<?php echo $count_tags = wp_count_terms(‘post_tag’); ?>

6、页面总数:

<?php $count_pages = wp_count_posts(‘page’); echo $page_posts = $count_pages->publish; ?>

7、分类总数:

<?php echo $count_categories = wp_count_terms(‘category’); ?>

8、链接总数:

<?php $link = $wpdb->get_var(“SELECT COUNT(*) FROM $wpdb->links WHERE link_visible = ‘Y’”); echo $link; ?>

9、用户总数:

<?php $users = $wpdb->get_var(“SELECT COUNT(ID) FROM $wpdb->users”); echo $users; ?>

10、最后更新:

<?php $last = $wpdb->get_results(“SELECT MAX(post_modified) AS MAX_m FROM $wpdb->posts WHERE (post_type = ‘post’ OR post_type = ‘page’) AND (post_status = ‘publish’ OR post_status = ‘private’)”);$last = date(‘Y-n-j’, strtotime($last[0]->MAX_m));echo $last; ?>

9.wordpress判断语句

is_single()

判断是否是具体文章的页面

is_single(’2′)

判断是否是具体文章(id=2)的页面

is_single(’Beef Stew’)

判断是否是具体文章(标题判断)的页面

is_single(’beef-stew’)

判断是否是具体文章(slug判断)的页面

comments_open()

是否留言开启

pings_open()

是否开启ping

is_page()

是否是页面

is_page(’42′)

id判断,即是否是id为42的页面

is_page(’About Me’)

判断标题

is_page(’about-me’)

slug判断

is_category()

是否是分类

is_category(’6′)

id判断,即是否是id为6的分类

is_category(’Cheeses’)

分类title判断

is_category(’cheeses’)

分类 slug判断

in_category(’5′)

判断当前的文章是否属于分类5

is_author()

将所有的作者的页面显示出来

is_author(’1337′)

显示author number为1337的页面

is_author(’Elite Hacker’)

通过昵称来显示当前作者的页面

is_author(’elite-hacker’)

下面是通过不同的判断实现以年、月、日、时间等方式来显示归档

is_date()

is_year()

is_month()

is_day()

is_time()

判断当前是否是归档页面

is_archive()

判断是否是搜索

is_search()

判断页面是否404

is_404()

判断是否翻页,比如你当前的blog是http://domain.com 显示http://domain.com?paged=2的时候,这个判断将返 回真,通过这个函数可以配合is_home来控制某些只能在首页显示的界面,

例如:

<?php if(is_single()):?>

//这里写你想显示的内容,包括函数

<?php endif;?>

或者:

<?php if(is_home() && !is_paged() ):?>

//这里写你想显示的内容,包括函数

<?php endif;?>

10.wordpress 非插件调用评论表情

<!–smilies–>
<?php

function wp_smilies() {

global $wpsmiliestrans;

if ( !get_option(‘use_smilies’) or (empty($wpsmiliestrans))) return;

$smilies = array_unique($wpsmiliestrans);

$link=”;

foreach ($smilies as $key => $smile) {

$file = get_bloginfo(‘wpurl’).’/wp-includes/images/smilies/’.$smile;

$value = ” “.$key.” “;

$img = “<img src=\”{$file}\” alt=\”{$smile}\” />”;

$imglink = htmlspecialchars($img);

$link .= “<a href=\”#commentform\” title=\”{$smile}\” onclick=\”document.getElementById(‘comment’).value += ‘{$value}’\”>{$img}</a>&nbsp;”;

}

echo ‘<div>’.$link.’</div>’;

}

?>

<?php wp_smilies();?>

<!–smilies—>

将以上代码复制到 comments.php 中合适的位置:

原帖地址:http://www.cnblogs.com/huangcong/archive/2011/07/04/2097764.html

做一个zencart产品详细页相关产品模块

 

<div class=”centerBoxWrapper” id=”similar_product”>

<h2 class=”centerBoxHeading”>&nbsp;&nbsp;Related products &nbsp;&nbsp;&nbsp;&nbsp;</h2>

<ul>

<?php

 

$products_id = (int)$_GET[‘products_id’];

 

$flash_page_id_con = array();

$flash_page_images_con = array();

$flash_page_price_con = array();

$flash_page_name_con = array();

 

$flash_page_query = “select p.products_id,p.products_image,pd.products_name from ” . TABLE_PRODUCTS .” p, “. TABLE_PRODUCTS_DESCRIPTION . ” pd where p.`products_id`=pd.`products_id` AND pd.`language_id` = ‘” . (int)$_SESSION[‘languages_id’] . “‘ AND p.`master_categories_id` = ” . zen_get_products_category_id($products_id) . ” ORDER BY rand() limit 4″;

$flash_page = $db->Execute($flash_page_query);

while(!$flash_page->EOF){

$flash_page_items[] = $flash_page->fields;

$flash_page_id_con[] = $flash_page->fields[‘products_id’];

$flash_page_images_src = is_int(strpos($flash_page->fields[‘products_image’],’,’))? substr($flash_page->fields[‘products_image’],0,strpos($flash_page->fields[‘products_image’],’,’)):$flash_page->fields[‘products_image’];

$flash_page_images_con[] = ‘”‘.(zen_not_null($flash_page->fields[‘products_image’]) ? $flash_page_images_src : PRODUCTS_IMAGE_NO_IMAGE ).'”‘;

$flash_page_price_con[] = ‘”‘.$currencies->display_price(zen_get_products_base_price($flash_page->fields[‘products_id’]),zen_get_tax_rate($product_check->fields[‘products_tax_class_id’])).'”‘;

$flash_page_name_con[] = ‘”‘.zen_output_string(zen_get_products_name($flash_page->fields[‘products_id’])).'”‘;

$flash_page->MoveNext();

}

 

$flash_page_id = implode(“,”, $flash_page_id_con);

$flash_page_images = implode(“,”, $flash_page_images_con);

$flash_page_price = implode(“,”, $flash_page_price_con);

$flash_page_name = implode(“,”, $flash_page_name_con);

$flash_page_display_num = $flash_page->RecordCount();

?>

 

<?php for($i = 0; $i< $flash_page_display_num ; $i++){?>

<li id=”li<?php echo $i;?>” style=”display:block;float:left;padding-left:10px;width:22%;”>

<a href=”<?php echo zen_href_link(zen_get_info_page($flash_page_items[$i][‘products_id’]), ‘products_id=’ . $flash_page_items[$i][‘products_id’]);?>”><?php echo zen_image(DIR_WS_IMAGES . $flash_page_items[$i][‘products_image’], $flash_page_items[$i][‘products_name’], IMAGE_FEATURED_PRODUCTS_LISTING_WIDTH, IMAGE_FEATURED_PRODUCTS_LISTING_HEIGHT); ?></a><p style=”text-align:center;”><a href=”<?php echo zen_href_link(zen_get_info_page($flash_page_items[$i][‘products_id’]), ‘products_id=’ . $flash_page_items[$i][‘products_id’]);?>”><?php echo $flash_page_items[$i][‘products_name’]; ?></a><br /><strong id=”cell_price<?php echo $i?>” class=”red”><?php echo $currencies->display_price((zen_get_products_base_price($flash_page_items[$i][‘products_id’]) == 0 ? zen_get_products_sample_price($flash_page_items[$i][‘products_id’]): zen_get_products_base_price($flash_page_items[$i][‘products_id’])),zen_get_tax_rate($product_check->fields[‘products_tax_class_id’])); ?></strong></p>

</li>

<?php

//print_r($flash_page_items[$i]);

}

?>

</ul>

</div>

在includes/templates/你的模板/templates目录下创建一个新文件,命名为:tpl_product_info_similar.php

把以上代码复制进去保存,

打开:tpl_product_info_display

在合适的位置,添加代码

<?php require($template->get_template_dir(‘tpl_product_info_similar.php’,DIR_WS_TEMPLATE, $current_page_base,’templates’). ‘/’ . ‘tpl_product_info_similar.php’); ?>

修改之前,一定要备份。

大功搞成。去看下修改效果吧

apache的.htaccess伪静态规则和nginx伪静态规则对比

伪静态对于SEO来说是非常重要的,当我们从apache转移到nginx的时候,伪静态规则怎么转变呢?

下面是两者伪静态的对比:

apache:

RewriteEngine On

RewriteRule ^/([a-z]+)/p_([0-9]+)\.html$ /list\.php\?id=$1

nginx:

 rewrite ^/([a-z]+)/p_([0-9]+)\.html$ /list.php?id=$1 last;

 

两者有啥区别呢?嘿嘿,相信细心的童鞋已经看出区别来了。

就是讲RewriteRule替换成rewrite

将/list\.php\?id=$1中的”\”去掉,即:/list.php?id=$1

这样,apache下的.htaccess伪静态就替换成了nginx的伪静态了~

当你安装了一个新的程序之后,如果没有现成的nginx 的伪静态可以使用 那你就可以自己动手将apache下的htaccess里的规则修改为nginx的规则了

VPS安全之修改ssh端口以及禁用root账户登录

当然首先要做的就是修改ssh端口以及禁用root账户登录

当然这些都是在ssh的配置文件中完成的。他的路径就在/etc/ssh/sshd_config

我们所要做的就是vi他一下,然后修改ssh端口和root。

首先修改ssh端口

翻到13行(用winscp可以很轻松的找到)去掉前面的#,将port 22 这个22的数字改掉,改成3344等随便你觉得舒服的端口(80端口和143端口还有110端口等都不要用上,否则会冲突,最好就是直接改成4位数以上的。)

然后就是修改root账户的登录情况了

不过在这之前得创建新账户,使用命令

useradd rffan

passwd rffan

来创建账户和创建账户密码。

创建好了之后还是vi 到/etc/ssh/sshd_config  翻到39行去掉#PermitRootLogin yes 前面的#然后把yes改成no,然后保存一下就OK了。

改好之后reboot重启一下系统,这时候你就需要输入新的端口和新的账户来登陆了。

不过这个账户没有root权限,那么怎么用这个账户获取root权限的

用命令su root 然后会提示你输入root的密码,输入之后你就获得了root的权限了。

转自:http://rffan.info/1968

lnmp安装之后的数据库(phpmyadmin)的安全设置

很简单,修改phpmyadmin的文件夹的名字。

是的,phpmyadmin仅仅是一款管理工具,实际上的数据库是mysql,修改phpmyadmin不会对mysql做任何的破坏。

你可以随便取些复杂的名字,比如:shujuku112233445566,或者shu11ju22ku33,等等类似的名字,自己最好做下记录,不然每次使用都要登录SSH查看名字了。

如果取个自己容易记住的名字也可以 不过 最好还是复杂一点。

Zen Cart 产品标题或者图片名称字数限制的修改

Zen Cart默认产品标题是64个字符,可是实际使用过程中往往出现产品的标题长度超过64字符的情况,可以用如下方法解决:

在后台 install sql patch 中输入: ALTER TABLE products_description MODIFY products_name varchar(256);
其中256也可以改成128 根据自己实际情况使用。
如果熟悉zen cart数据库结构,也可以用phpmyadmin进去修改位数。
同理还有图片的名字过长也可以用类似的方法修改。

具体命令为:  ALTER TABLE products MODIFY products_image varchar(256);

另外注意一个细节,那就是在zen cart后台输入sql语句时候,必须以英文的分号”;”结束,否则会提示错误.

修改了产品名字的长度,注意orders_products表下也有个products_name,也需要更改为256或者128(根据前面自己的设置更改),否则在购物车第3步(index.php?main_page=checkout_confirmation)会出现产品名字太长的sql错误。