HardBirch

WP添加投稿功能(非插件实现)

时间:12-08-29 栏目:WP技巧分享 作者:魔豆先生 评论:0 点击: 2,327 次

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

一、添加投稿表单

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

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

3、将 <?php the_content(); ?> 改成以下代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
<?php the_content(); ?>

<!-- 关于表单样式,请自行调整-->
<form method="post" action="<?php echo $_SERVER["REQUEST_URI"]; ?>">
<div style="text-align: left; padding-top: 10px;">
<label for="userpost_authorname">昵称:*</label>
<input type="text" size="40" value="" id="userpost_authorname" name="userpost_authorname" />
</div>

<div style="text-align: left; padding-top: 10px;">
<label for="userpost_authoremail">E-Mail:*</label>
<input type="text" size="40" value="" id="userpost_authoremail" name="userpost_authoremail" />
</div>

<div style="text-align: left; padding-top: 10px;">
<label for="userpost_authorblog">您的博客:</label>
<input type="text" size="40" value="" id="userpost_authorblog" name="userpost_authorblog" />
</div>

<div style="text-align: left; padding-top: 10px;">
<label for="userpost_title">文章标题:*</label>
<input type="text" size="40" value="" id="userpost_title" name="userpost_title" />
</div>

<div style="text-align: left; padding-top: 10px;">
<label for="userpostcategorg">分类:*</label>
<?php wp_dropdown_categories('id=userpostcategorg&show_count=1&hierarchical=1'); ?>
</div>

<div style="text-align: left; padding-top: 10px;">
<label style="vertical-align:top" for="userpost_content">文章内容:*</label>
<textarea rows="15" cols="55" id="userpost_content" name="userpost_content"></textarea>
</div>

<br clear="all">
<div style="text-align: center; padding-top: 10px;">
<input type="hidden" value="send" name="userpost_form" />
<input type="submit" value="提交" />
<input type="reset" value="重填" />
</div>
</form>

二、添加表单处理代码

在userpost.php开头处中,将第一个 <?php 改成:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
<?php
/**
* Template Name: userpost
* 作者:魔豆博主
* 博客:http://www.mythroad.net/
*
* 更新记录
*  2010年09月09日 :
*  首个版本发布
*
*  2011年03月17日 :
*  修正时间戳函数,使用wp函数current_time('timestamp')替代time()
*
*  2011年04月12日 :
*  修改了wp_die函数调用,使用合适的页面title
*/

if( isset($_POST['userpost_form']) && $_POST['userpost_form'] == 'send')
{
global $wpdb;
$last_post = $wpdb->get_var("SELECT post_date FROM $wpdb->posts WHERE post_type = 'post' ORDER BY post_date DESC LIMIT 1");

// 博客当前最新文章发布时间与要投稿的文章至少间隔120秒。
// 可自行修改时间间隔,修改下面代码中的120即可
// 相比Cookie来验证两次投稿的时间差,读数据库的方式更加安全
if ( current_time('timestamp') - strtotime($last_post) < 120 )
{
wp_die('您投稿也太勤快了吧,先歇会儿!');
}

// 表单变量初始化
$name = isset( $_POST['userpost_authorname'] ) ? trim(htmlspecialchars($_POST['userpost_authorname'], ENT_QUOTES)) : '';
$email =  isset( $_POST['userpost_authoremail'] ) ? trim(htmlspecialchars($_POST['userpost_authoremail'], ENT_QUOTES)) : '';
$blog =  isset( $_POST['userpost_authorblog'] ) ? trim(htmlspecialchars($_POST['userpost_authorblog'], ENT_QUOTES)) : '';
$title =  isset( $_POST['userpost_title'] ) ? trim(htmlspecialchars($_POST['userpost_title'], ENT_QUOTES)) : '';
$category =  isset( $_POST['cat'] ) ? (int)$_POST['cat'] : 0;
$content =  isset( $_POST['userpost_content'] ) ? trim(htmlspecialchars($_POST['userpost_content'], ENT_QUOTES)) : '';

// 表单项数据验证
if ( empty($name) || mb_strlen($name) > 20 )
{
wp_die('昵称必须填写,且长度不得超过20字');
}

if ( empty($email) || strlen($email) > 60 || !preg_match("/^([a-z0-9\+_\-]+)(\.[a-z0-9\+_\-]+)*@([a-z0-9\-]+\.)+[a-z]{2,6}$/ix", $email))
{
wp_die('Email必须填写,且长度不得超过60字,必须符合Email格式');
}

if ( empty($title) || mb_strlen($title) > 100 )
{
wp_die('标题必须填写,且长度不得超过100字');
}

if ( empty($content) || mb_strlen($content) > 3000 || mb_strlen($content) < 100)
{
wp_die('内容必须填写,且长度不得超过3000字,不得少于100字');
}

$post_content = '昵称: '.$name.'<br />Email: '.$email.'<br />blog: '.$blog.'<br />内容:<br />'.$content;

$userpost= array(
'post_title' => $title,
'post_content' => $post_content,
'post_category' => array($category)
);

// 将文章插入数据库
$status = wp_insert_post( $userpost);

if ($status != 0)
{
// 投稿成功给博主发送邮件
// somebody#example.com替换博主邮箱
// My subject替换为邮件标题,content替换为邮件内容
wp_mail("somebody#example.com","My subject","content");

wp_die('投稿成功!感谢投稿!', '投稿成功');
}
else
{
wp_die('投稿失败!');
}
}

最后以UTF-8编码保存userpost.php,否则中文可能会乱码。

代码补充说明

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

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

2、如果你想让用户在投稿的同时,将投稿者注册成你本站的投稿者,并将文章的作者归到这个投稿者的名下,你可以参考此条回复的内容修改相应的代码:查看回复

3、如果你的博客文章都有自定义栏目,并且想在用户投稿的同时添加自定义栏目,可以参考这条回复:查看回复

4、如果你使用了一些富文本编辑器,文章提交后内容中的代码都被转义了,可以参考这条回复:查看回复

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

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

声明: 本文由( 魔豆先生 )原创编译,转载请保留链接: WP添加投稿功能(非插件实现)

WP添加投稿功能(非插件实现):等您坐沙发呢!

发表评论


QQ群互动

Linux系统与内核学习群:194051772

WP建站技术学习交流群:194062106

魔豆之路QR

魔豆的Linux内核之路

魔豆的Linux内核之路

优秀工程师当看优秀书籍

优秀程序员,要看优秀书!

赞助商广告

友荐云推荐