相信有不少站長朋友都或多或少接觸過 WordPress 吧,其中很多人都需要一個投稿頁面,當然其中好處不言而喻了。網上有的投稿外掛是英文的,有的類似於留言本,有的會顯示亂碼,而今天筆者就教大家自己做一個外掛來實現投稿功能。

首先新建 submit_posts_ajax.php,將以下內容複製進去:

function submit_posts_ajax(){
         if($_POST['submit_posts_ajax']=='yinheli'){
         $title=strip_tags(trim($_POST['post_title']));
         $name=trim($_POST['your_name']);
         $mail=trim($_POST['your_email']);
         $site=trim($_POST['your_site']);
         $content=stripslashes(trim($_POST['post_content']));
         $tags=strip_tags(trim($_POST['post_tags']));
                   $db="SELECT post_title FROM $wpdb->posts WHERE post_title = '$title' LIMIT 1";
                   if ($wpdb->get_var($db)){
                            echo '<div > 發現重複文章. 你已經發表過了. 或者存在該文章</div>';
                            if(substr($site, 0, 7) != 'http://') $site= 'http://'.$site;
                   $author='<a href="'.$site.'" title="'.$name.'">'.$name.'</a>';

         $info='<div > 感謝: '.$author.' 的供稿.</div>'."

";

         if(isset($_POST['post_submit'])){
                   echo '<div > 錯誤: 沒有填寫標題!</div>';
                   echo '<div > 錯誤: 沒有填寫郵箱地址.</div>';
                   echo '<div > 錯誤: 還沒有填寫內容!!!</div>';
                            'post_content' =>$content,
                            'post_status'   => 'pending'
                   $post_id = wp_insert_post($submitdata,$wp_error = false);
                   $subject='您給 [ '.get_option('blogname').' ] 寫了篇文章 標題是: '.$title;
                   $message='非常感謝您的供稿. 您的稿件已經提交. 等待管理員的稽核. 以下是您提交的內容:<hr>'.stripslashes(trim($_POST['post_content']));
                   yinheli_sendmail_ps($mail,$subject,$message);
                   echo '<div > 非常感謝您的供稿. 您的稿件已經提交. 等待管理員的稽核. 請耐心等待.</div>';
                   @header('Content-type: ' . get_option('html_type') . '; charset=' . get_option('blog_charset'));
         if(isset($_POST['post_review'])){
                   if(''==$tags) $tags='您還沒有填寫 標籤 (Tags)';
                   echo '<div >
                            <div >
                                     <p > 標籤:'.$tags.'</p>
function yinheli_sendmail_ps($to,$subject,$message){
         $blogname = get_option('blogname');
         $charset = get_option('blog_charset');
         $ps_sendmail_headers = "From: $blogname
" ;
         $ps_sendmail_headers .= "MIME-Version: 1.0
";
         $ps_sendmail_headers .= "Content-Type: text/html;charset="$charset"
";
         return @wp_mail($to, $subject, $message, $ps_sendmail_headers);
function submit_posts_load_js(){
echo "
".'<script type="text/javascript" src="'%20.%20get_bloginfo('wpurl')%20.%20'/wp-content/plugins/submit_posts/submit_posts.js"></script>'."
";
add_action('init', 'submit_posts_ajax');
require_once('submit_posts.php');
function submit_posts_display(){
$submit_posts_html=submit_posts_html();
return $submit_posts_html;
add_shortcode('submit_posts','submit_posts_display');

接下來新建 submit_posts.php,同樣將以下內容複製進去:

<script type="text/javascript">
function submit_posts_html(){
<div id="ps_msg"> 歡迎給我供稿</div>
<form id="post_submit_form" name="post_submit_form" method="post" action="">
<input type="hidden" name="submit_posts_ajax" id="submit_posts_ajax" value="yinheli"/>
<label><input type="text" name="post_title" id="post_title" tabindex="1" value="<?php echo strip_tags($_POST['post_title']);?>"/> 投稿標題 (必填)</label>
<label><input type="text" name="your_name" id="your_name" tabindex="2" value="<?php echo $_POST['your_name'];?>" /> 您的名字或暱稱</label>
<label><input type="text" name="your_email" id="your_email" tabindex="3" value="<?php echo $_POST['your_email'];?>" /> 您的郵箱 (必填)</label>
<label><input type="text" name="your_site" id="your_site" tabindex="4" value="<?php echo $_POST['your_site'];?>" /> 您的網站</label>
<textarea name="post_content" cols="50" rows="15" id="post_content" tabindex="5"><?php echo stripslashes($_POST['post_content']);?></textarea>
<label><input type="text" name="post_tags" id="post_tags" tabindex="6" value="<?php echo strip_tags($_POST['post_tags']);?>" /> 標籤 (tags)[每個標籤用半形的逗號分開]</label>
<input type="submit" name="post_review" id="post_review" value="預覽" tabindex="7" />
<input type="submit" name="post_submit" id="post_submit" value="提交" tabindex="8" />
<div style="clear:both"></div>

最後再新建 submit_posts.js,將以下內容複製進去:

Author URI: http://www.89948.net/
if(!window.YHLJSPS) window['YHLJSPS']={};
function isCompatible(other) {
                   || !Object.hasOwnProperty
                   || !document.createElement
                   || !document.getElementsByTagName
                   alert('TR- if you see this message isCompatible is failing incorrectly.');
return document.getElementById(id);
function getXmlHttpObject(){
                   xmlHttp = new XMLHttpRequest();
                            xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
                            xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
function setStyle(element, key, value) {
         element.style[key] = value;
function addEvent(node,type,listener){
         if(!isCompatible()) { return false }
         if(node.addEventListener){
         node.addEventListener(type,listener,false);
         }else if(node.attachEvent){
         node['e'+type+listener]=listener;
         node[type+listener]=function(){
                   node['e'+type+listener](window.event);
                   node.attachEvent('on'+type,node[type+listener]);
function insertAfter(node, referenceNode) {
    if(!(node = $(node))) return false;
    if(!(referenceNode = $(referenceNode))) return false;
    return referenceNode.parentNode.insertBefore(node, referenceNode.nextSibling);
function preventDefault(eventObject) {
         eventObject = eventObject || getEventObject(eventObject);
         if(eventObject.preventDefault) {
                   eventObject.preventDefault();
                   eventObject.returnValue = false;
function formToRequestString(form_obj,val){
         for (i=0;i<form_obj.length ;i++ ){
                   if (e.name!='' && e.type!='submit'){
                            if (e.type=='select-one'){
                                     element_value=e.options[e.selectedIndex].value;
                            }else if (e.type=='checkbox' || e.type=='radio'){
                            query_string+=and+encodeURIComponent(e.name)+'='+encodeURIComponent(element_value);
function setopacity(node,opacity){
setStyle(node, 'opacity', opacity);
setStyle(node, 'MozOpacity', opacity);
setStyle(node, 'KhtmlOpacity', opacity);
setStyle(node, 'filter', 'alpha(opacity=' + opacity * 100 + ')');
function stateChangeListener(){
var the_form=$('post_submit_form');
         if(xmlHttp.readyState==1){
         r_msg.innerHTML='資料載入中, 請稍候...';
         setopacity(the_form,0.8);
         $('post_submit').disabled=true;
         window.scrollTo(0,r_msg.offsetTop+15);
         }else if(xmlHttp.readyState==4 && xmlHttp.status==200){
         r_msg.innerHTML=xmlHttp.responseText;
         setTimeout(function(){$('post_submit').disabled=false;},1000);
         }else if(xmlHttp.status!=200){
                   alert('呃 出錯了 (建議您儲存好文章再重新整理瀏覽器.) 錯誤資訊:'+xmlHttp.statusText);
function submitactiontype(type){
var A=formToRequestString($('post_submit_form'))+'&'+encodeURIComponent($(type).name)+'='+encodeURIComponent($(type).value);
function ps_submit(action){
         xmlHttp = getXmlHttpObject();
                   alert ("Oop! Browser does not support HTTP Request.")
         var url=window.location.href;
         if(action=='post_submit'){
                   var senddata=submitactiontype(action);
         if(action=='post_review'){
                   var senddata=submitactiontype(action);
         xmlHttp.onreadystatechange=function(){
         xmlHttp.open("POST", url, true);
         xmlHttp.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
         addEvent($('post_submit'),'click',function(W3CEvent){
                   ps_
submit(action='post_submit');
                   preventDefault(W3CEvent);
         addEvent($('post_review'),'click',function(W3CEvent){
                   ps_submit(action='post_review');
                   preventDefault(W3CEvent);
if (document.addEventListener) {
         document.addEventListener("DOMContentLoaded", initps, false);
} else if (/MSIE/i.test(navigator.userAgent)) {
         document.write('<script id="__ie_onload_for_post_posts" defer src="javascript:void(0)"></script>');
         var script = $('__ie_onload_for_post_posts');
         script.onreadystatechange = function() {
                   if (this.readyState == 'complete') {
} else if (/WebKit/i.test(navigator.userAgent)) {
         var _timer = setInterval( function() {
                   if (/loaded|complete/.test(document.readyState)) {
         window.onload = function(e) {

把以上三個檔案儲存在 submit_posts 資料夾內,上傳至外掛目錄,並進後臺安裝該外掛。使用時只需要新建頁面並輸入 [submit_posts] 即可呼叫出。