WordPress添加投稿功能

林继 WordPress 2,225 共写了559个字 (2010-12-16 23:47:43) 没有评论 打印 扫描二维码 百度未收录

来自网络 很多网站都想开放读者的投稿功能,接受读者的投稿,不仅可以丰富博客的内容,还可以增加与读者之间的沟通,可以说是一举多得的事情,何乐不为呢?WordPress本身并不提供投稿功能,但是WordPress拥有强大的扩展能力,我们可以自己来添加这个功能。

实现用户投稿,有两种方法,一种是开放后台的注册功能,普通用户注册进去默认设置为投稿者,登陆进去即可添加文章(默认为草稿);另一种方法是在前台提供投稿表单,用户填写相应的表格即可。前一种方法实现起来比较简单,基本不需要博主配置太多东西,只是有些博主可能会觉得别扭,不愿让他人看到自己的博客后台;而后一种方法对投稿者来说方便了很多,博主也不用担心自己博客的后台隐私,只是该方法实现起来比较麻烦,需要配置的东西很多。本文也只将介绍后一种方法,希望对你有所帮助。

一、添加投稿表单

1、首先在当前主题的目录下新建一个php文件,命名为tougao-page.php,然后将page.php中的所有代码复制到tougao-page.php中;

2、删除tougao-page.php开头的所有注释,即 /* 与 */ ,以及它们之间的所有内容;

3、将 改成以下代码:

  1. <?php the_content(); ?>
  2. <form method="post" action="<?php echo $_SERVER["REQUEST_URI"]; ?>">
  3.     <div style="text-align: left; padding-top: 10px;">
  4.         <label>昵称:*</label>
  5.     </div>
  6.     <div>
  7.         <input type="text" size="40" value="" name="tougao_authorname" />
  8.     </div>
  9.  
  10.     <div style="text-align: left; padding-top: 10px;">
  11.         <label>E-Mail:*</label>
  12.     </div>
  13.     <div>
  14.         <input type="text" size="40" value="" name="tougao_authoremail" />
  15.     </div>
  16.  
  17.     <div style="text-align: left; padding-top: 10px;">
  18.         <label>您的博客:</label>
  19.     </div>
  20.     <div>
  21.         <input type="text" size="40" value="" name="tougao_authorblog" />
  22.     </div>
  23.  
  24.  
  25.     <div style="text-align: left; padding-top: 10px;">
  26.         <label>文章标题:*</label>
  27.     </div>
  28.     <div>
  29.         <input type="text" size="40" value="" name="tougao_title" />
  30.     </div>
  31.  
  32.     <div style="text-align: left; padding-top: 10px;">
  33.         <label>分类:*</label>
  34.     </div>
  35.     <div style="text-align: left;">
  36.         <?php wp_dropdown_categories('show_count=1&hierarchical=1'); ?>
  37.     </div>
  38.  
  39.     <div style="text-align: left; padding-top: 10px;">
  40.         <label>文章内容:*</label>
  41.     </div>
  42.     <div>
  43.         <textarea rows="15" cols="55" name="tougao_content"></textarea>
  44.     </div>
  45.  
  46.     <br clear="all">
  47.     <div style="text-align: center; padding-top: 10px;">
  48.         <input type="hidden" value="send" name="tougao_form" />
  49.         <input type="submit" value="提交" />
  50.         <input type="reset" value="重填" />
  51.     </div>
  52. </form>

二、添加表单处理代码

在tougao-page.php中,将第一个

  1. <?php
  2. /*
  3.  * Template Name: tougao
  4.  * @author: Ludou  
  5.  * @Email : zhouzb889@gmail.com
  6.  * @Blog  : http://www.ludou.org/
  7.  */
  8.  
  9. if( isset($_POST['tougao_form']) && $_POST['tougao_form'] == 'send')
  10. {
  11.     // 两次投稿间隔至少120秒,可自行修改时间间隔,修改下面代码中的120即可
  12.     if ( isset($_COOKIE["tougao"]) && ( time() - $_COOKIE["tougao"] ) < 120 )
  13.     {
  14.         wp_die('您投稿也太勤快了吧,先歇会儿!');
  15.     }
  16.  
  17.     // 表单变量初始化
  18.     $name = isset( $_POST['tougao_authorname'] ) ? trim(htmlspecialchars($_POST['tougao_authorname'], ENT_QUOTES)) : '';
  19.     $email =  isset( $_POST['tougao_authoremail'] ) ? trim(htmlspecialchars($_POST['tougao_authoremail'], ENT_QUOTES)) : '';
  20.     $blog =  isset( $_POST['tougao_authorblog'] ) ? trim(htmlspecialchars($_POST['tougao_authorblog'], ENT_QUOTES)) : '';
  21.     $title =  isset( $_POST['tougao_title'] ) ? trim(htmlspecialchars($_POST['tougao_title'], ENT_QUOTES)) : '';
  22.     $category =  isset( $_POST['cat'] ) ? (int)$_POST['cat'] : 0;
  23.     $content =  isset( $_POST['tougao_content'] ) ? trim(htmlspecialchars($_POST['tougao_content'], ENT_QUOTES)) : '';
  24.  
  25.     // 表单项数据验证
  26.     if ( empty($name) || strlen($name) > 20 )
  27.     {
  28.         wp_die('昵称必须填写,且长度不得超过20字');
  29.     }
  30.  
  31.     if ( empty($email) || strlen($email) > 60 || !preg_match("/^([a-z0-9\+_\-]+)(\.[a-z0-9\+_\-]+)*@([a-z0-9\-]+\.)+[a-z]{2,6}$/ix", $email))
  32.     {
  33.         wp_die('Email必须填写,且长度不得超过60字,必须符合Email格式');
  34.     }
  35.  
  36.     if ( empty($title) || strlen($title) > 100 )
  37.     {
  38.         wp_die('标题必须填写,且长度不得超过100字');
  39.     }
  40.  
  41.     if ( empty($content) || strlen($content) > 3000 || strlen($content) < 100)
  42.     {
  43.         wp_die('内容必须填写,且长度不得超过3000字,不得少于100字');
  44.     }
  45.  
  46.     $post_content = '昵称: '.$name.'<br />Email: '.$email.'<br />blog: '.$blog.'<br />内容:'.$content;
  47.  
  48.     $tougao = array(
  49.         'post_title' => $title,
  50.         'post_content' => $post_content,
  51.         'post_category' => array($category)
  52.     );
  53.  
  54.  
  55.     // 将文章插入数据库
  56.     $status = wp_insert_post( $tougao );
  57.  
  58.     if ($status != 0) 
  59.     {
  60.         setcookie("tougao", time(), time()+180);
  61.  
  62.         // 投稿成功给站长发送邮件
  63.         // somebody@example.com替换站长邮箱
  64.         // My subject替换为邮件标题,content替换为邮件内容
  65.         // 建议用英文,否则会出现乱码
  66.         mail("somebody@example.com","My subject","content");
  67.  
  68.         wp_die('投稿成功!感谢投稿!');
  69.     }
  70.     else
  71.     {
  72.         wp_die('投稿失败!');
  73.     }
  74. }

代码补充说明,如果你想让让投稿的文章立即发布,而不需要审核再编辑,那么请将以上代码45行改成:

  1. 'post_content' => $post_content, 'post_status' => 'publish',

最后进入WordPress管理后台 – 页面 – 创建页面,标题为投稿(可以自己起名),内容填上投稿说明等,右侧可以选择模板,选择 tougao 即可

好了,基本的投稿功能已经添加完毕,至于表单样式不好看,表单缺少你想要的项目等问题,你就自己添加css、表单项吧。最后,也欢迎给本站投稿哦。

如果觉得我的文章对您有用,请随意赞赏。您的支持将鼓励我继续创作!

发表评论

电子邮件地址不会被公开。 必填项已用*标注

< >