怎么WordPress增加在線投稿功能


現在很多個人博客為了增加博客的內容,都會提供投稿通道,大部分都是以郵箱的形式進行投稿,不過這樣一來,也很費人力,要拷貝復制,然后編輯等。如果給博客加個在線投稿功能,那就方便多了。稍微審核下文章內容就可以了。下面介紹一些如何給WordPress博客增加在線投稿功能的方法。

WordPress增加在線投稿功能

有兩個方向:一個是尋找插件,一個是自己動手編寫代碼。

通過百度和若干WordPress技術網站,我們整理出下面幾款。

1、WP User Frontend插件,這是用戶中心插件。

功能如下:

  • 用戶可以在前台發布文章

  • 用戶可以前台查看和管理他們自己的文章

  • 用戶可以前台編輯個人資料

  • 管理員可以設置哪些等級的用戶才允許訪問WordPress后台(/wp-admin)

  • 可以設置用戶的新文章狀態,例如 已發布、草稿、等待審核等

  • 當用戶發布新文章時,郵件通知管理員

  • 設置是否允許用戶編輯和刪除他們的文章

  • 允許用戶發布文章時上傳附件

  • 允許用戶設置特色圖像

  • 管理員可以前台管理用戶(添加用戶,刪除用戶等)

  • 支持收費發布文章(設置用戶要發布文章是否需要付費)

使用方法如下:

  • 設置你的WordPress固定鏈接要包含%postname%,插件才生效。

  • 新建一個名為頁面“新文章”,添加簡碼 [wpuf_addpost] 然后發布,這個頁面就可以顯示用戶自己的文章。如果想顯示自定義文章類型,比如 event,可以添加簡碼 [wpuf_addpost post_type=”event”]

  • 新建一個名為“編輯”的頁面,添加簡碼 [wpuf_edit] 然后發布,這個頁面就是用來前台編輯文章的。

  • 新建名為“個人資料”的頁面,添加簡碼 [wpuf_editprofile],用來顯示和編輯用戶個人資料

  • 新建名為“儀表盤”的頁面,添加簡碼 [wpuf_dashboard] 就是前台用戶中心主頁 。如果要主頁顯示自定義文章類型的列表,可以使用 [wpuf_dashboard post_type=”event”]

  • 要顯示所有的訂購發布信息,請使用簡碼 [wpuf_sub_info]

  • 要顯示所有的訂購發布套餐,請使用簡碼 [wpuf_sub_pack]

  • 要編輯用戶,插入短代碼 [wpuf-edit-users]

  • 對於認購的付款頁面,以及付款完后的配置, 在插件設置選項卡上中的“PayMents”選項下進行設置。認購付款頁面,創建一個新的頁面,並在WP用戶前端的“貝寶付款頁面”選項插入的頁ID。

如果需要良好的現實用戶中心頁面,可以為WP User Frontend的頁面單獨定制一個模板,這樣可以提供更好的使用體驗。

但是這個插件有個最大的麻煩,那就是需要到網站固定連接將你的自定義網址改成%postname%。這是個麻煩的活,微部落博客之前都是用的

%post_id%。這對於老站,不僅工作量大,而且會造成大量的404頁面。當然網絡上有辦法在不改變原始網址的情況下解決這個問題,這里微部落博客不做細述。

2、submit posts插件

這是個極其簡單的擁有AJAX效果的投稿插件,沒有附加其他任何功能,支持游客投稿,不依賴任何的框架,無需任何設置.

使用方法:解壓上傳,激活。后台創建一個投稿的頁面,在需要插入投稿表單的地方插入[submit_posts]即可,在日志中插入也有效。

可根據你的主題風格,添加CSS樣式,使用投稿表單看上去更漂亮。

功能:

  • 投稿到審核狀態。

  • 投稿成功后給投稿者發送郵件通知。

但這個插件頁面比較簡陋,當然他支持CSS,有興趣的可以自己完善。

3、DX-Contribute插件

DX-Contribute是一個wordpress投稿插件,主要功能如下:

  1. 允許游客無需注冊即可在你的網站投稿。

  2. 靈活的后台設置,可以自定義限定內容輸入字數,為投稿的文章指定分類等。

  3. 前台內容采用wordpress內置的文章編輯器,簡單易用。

  4. 該wordpress插件還有很好的驗證保護措施,會自動檢測標題字數、email格式,並且能夠有效控制用戶重復投稿。

不過這個插件已經超過兩年沒有更新了。

當然wordpress投稿插件還有別的,但主要是以上三種,在嘗試了三種插件后,微部落博客有找到了不用插件的解決方案:

不用插件用代碼解決wordpress網站在線投稿功能

經過幾種嘗試,微部落博客在露兜博客找到了合適的方法,並經過微調。

步驟如下:

1、找到當前主題目錄下page.php,並復制傳輸到本地電腦,重命名為tougao-page.php。

2、搜索:the_content,可以查找到類似代碼<?php the_content(); ?>,在這行代碼下面添加表單樣式代碼:

<form class=”ludou-tougao” method=”post” action=”<?php echo $_SERVER["REQUEST_URI"]; $current_user = wp_get_current_user(); ?>”>
<div style=”text-align: left; padding-top: 10px;”>
<label for=”tougao_authorname”>昵稱:*</label>
<input type=”text” size=”40″ value=”<?php if ( 0 != $current_user->ID ) echo $current_user->user_login; ?>” id=”tougao_authorname” name=”tougao_authorname” />
</div>

<div style=”text-align: left; padding-top: 10px;”>
<label for=”tougao_authoremail”>E-Mail:*</label>
<input type=”text” size=”40″ value=”<?php if ( 0 != $current_user->ID ) echo $current_user->user_email; ?>” id=”tougao_authoremail” name=”tougao_authoremail” />
</div>

<div style=”text-align: left; padding-top: 10px;”>
<label for=”tougao_authorblog”>您的博客:</label>
<input type=”text” size=”40″ value=”<?php if ( 0 != $current_user->ID ) echo $current_user->user_url; ?>” id=”tougao_authorblog” name=”tougao_authorblog” />
</div>

<div style=”text-align: left; padding-top: 10px;”>
<label for=”tougao_title”>文章標題:*</label>
<input type=”text” size=”40″ value=”" id=”tougao_title” name=”tougao_title” />
</div>

<div style=”text-align: left; padding-top: 10px;”>
<label for=”tougaocategorg”>分類:*</label>
<?php wp_dropdown_categories(‘hide_empty=0&id=tougaocategorg&show_count=1&hierarchical=1′); ?>
</div>

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

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

3、在文件頭部,添加代碼:

<?php
/*
Template Name: 投稿模板
*/

if( isset($_POST['tougao_form']) && $_POST['tougao_form'] == ‘send’) {
global $wpdb;
$current_url = ‘http://www.vprol.com/tougao’; // 注意修改此處的鏈接地址

$last_post = $wpdb->get_var(“SELECT `post_date` FROM `$wpdb->posts` ORDER BY `post_date` DESC LIMIT 1″);

// 博客當前最新文章發布時間與要投稿的文章至少間隔120秒。
// 可自行修改時間間隔,修改下面代碼中的120即可
// 相比Cookie來驗證兩次投稿的時間差,讀數據庫的方式更加安全
if ( (date_i18n(‘U’) – strtotime($last_post)) < 120 ) {
wp_die(‘您投稿也太勤快了吧,先歇會兒!<a href=”‘.$current_url.’”>點此返回</a>’);
}
// 表單變量初始化
$name = isset( $_POST['tougao_authorname'] ) ? trim(htmlspecialchars($_POST['tougao_authorname'], ENT_QUOTES)) : ”;
$email = isset( $_POST['tougao_authoremail'] ) ? trim(htmlspecialchars($_POST['tougao_authoremail'], ENT_QUOTES)) : ”;
$blog = isset( $_POST['tougao_authorblog'] ) ? trim(htmlspecialchars($_POST['tougao_authorblog'], ENT_QUOTES)) : ”;
$title = isset( $_POST['tougao_title'] ) ? trim(htmlspecialchars($_POST['tougao_title'], ENT_QUOTES)) : ”;
$category = isset( $_POST['cat'] ) ? (int)$_POST['cat'] : 0;
$content = isset( $_POST['tougao_content'] ) ? trim(htmlspecialchars($_POST['tougao_content'], ENT_QUOTES)) : ”;
// 表單項數據驗證
if ( empty($name) || mb_strlen($name) > 20 ) {
wp_die(‘昵稱必須填寫,且長度不得超過20字。<a href=”‘.$current_url.’”>點此返回</a>’);
}

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格式。<a href=”‘.$current_url.’”>點此返回</a>’);
}
if ( empty($title) || mb_strlen($title) > 100 ) {
wp_die(‘標題必須填寫,且長度不得超過100字。<a href=”‘.$current_url.’”>點此返回</a>’);
}
if ( empty($content) || mb_strlen($content) > 10000 || mb_strlen($content) < 100) {
wp_die(‘內容必須填寫,且長度不得超過10000字,不得少於100字。<a href=”‘.$current_url.’”>點此返回</a>’);
}
$post_content = ‘昵稱: ‘.$name.’<br />Email: ‘.$email.’<br />blog: ‘.$blog.’<br />內容:<br />’.$content;
$tougao = array(
‘post_title’ => $title,
‘post_content’ => $post_content,
‘post_category’ => array($category)
);

// 將文章插入數據庫
$status = wp_insert_post( $tougao );
if ($status != 0) {
// 投稿成功給博主發送郵件
// somebody#example.com替換博主郵箱
// My subject替換為郵件標題,content替換為郵件內容
wp_mail(“somebody#example.com”,”My subject”,”content”);

wp_die(‘投稿成功!感謝投稿!您的文章將在審核通過后發布!<a href=”‘.$current_url.’”>點此返回</a>’, ‘投稿成功’);
}
else {
wp_die(‘投稿失敗!<a href=”‘.$current_url.’”>點此返回</a>’);
}
}
?>

4、保存上傳到主題目錄,然后新建一個頁面,用投稿模板

不出意外的話,就OK了,當然你可以逐步調整代碼,進一步完善。當然你可以再將功能完善,比如:

好了,實現WordPress添加投稿功能的辦法基本如上,微部落博客也是整理了一些百度到的資料,希望能夠幫到你,另外希望各位有空投個稿給我。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM