Rumah >Tutorial CMS >WordTekan >Penjelasan terperinci tentang cara menambah fungsi penyerahan dalam WordPress
Banyak laman web yang ingin membuka fungsi penyerahan daripada pembaca bukan sahaja dapat memperkayakan kandungan blog, malah boleh dikatakan begitu ia membunuh dua burung dengan satu batu. Mengapa tidak melakukannya? WordPress sendiri tidak menyediakan fungsi penyerahan, tetapi WordPress mempunyai keupayaan sambungan yang kuat, dan kami boleh menambah fungsi ini sendiri.
Terdapat dua cara untuk melaksanakan penyerahan pengguna Satu ialah membuka fungsi pendaftaran bahagian belakang Apabila pengguna biasa mendaftar, mereka ditetapkan sebagai penyumbang secara lalai adalah draf); kaedah lain Borang penyerahan disediakan di meja depan, dan pengguna boleh mengisi borang yang sepadan. Kaedah terdahulu agak mudah untuk dilaksanakan dan pada asasnya tidak memerlukan blogger untuk mengkonfigurasi terlalu banyak perkara, tetapi sesetengah blogger mungkin berasa janggal dan tidak mahu orang lain melihat bahagian belakang blog mereka manakala kaedah yang kedua lebih mudah untuk penyumbang tidak perlu risau tentang privasi bahagian belakang blog mereka, tetapi kaedah ini lebih menyusahkan untuk dilaksanakan dan memerlukan banyak konfigurasi. Artikel ini hanya akan memperkenalkan kaedah yang terakhir. Saya harap ia akan membantu anda.
1 Buat fail php baharu dalam direktori tema semasa, bernama tougao-page.php, dan kemudian tukar. page.php Salin semua kod dalam tougao-page.php; 🎜>
3. Cari: the_content, anda boleh mencari kod serupa ad6b846fe9dddef3bcf86ad346de87f2the_content
get_template_part
dengan kod berikut: Kod 1:
2. Tambahkan kod pemprosesan borang
<?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>Pada permulaan tougao-page.php, tukar
Akhir sekali simpan tougao-page.php dalam pengekodan UTF-8, jika tidak bahasa Cina Mungkin kacau-bilau. Kemudian masukkan latar belakang pengurusan WordPress - Halaman - Buat halaman dengan tajuk Sumbangan (anda boleh namakannya sendiri), isi kandungan dengan arahan penyerahan, dsb. Anda boleh memilih templat di sebelah kanan dan pilih tougao.
Halaman ini adalah halaman pendaftaran bahagian hadapan Letakkan pautan ke halaman ini di mana-mana di tapak web untuk diklik oleh pengguna untuk mendaftar.<?php /** * Template Name: tougao * 作者:露兜 * 博客:https://www.ludou.org/ * * 更新记录 * 2010年09月09日 : * 首个版本发布 * * 2011年03月17日 : * 修正时间戳函数,使用wp函数current_time('timestamp')替代time() * * 2011年04月12日 : * 修改了wp_die函数调用,使用合适的页面title * * 2013年01月30日 : * 错误提示,增加点此返回链接 * * 2013年07月24日 : * 去除了post type的限制;已登录用户投稿不用填写昵称、email和博客地址 * * 2015年03月08日 : * 使用date_i18n('U')代替current_time('timestamp') */ if( isset($_POST['tougao_form']) && $_POST['tougao_form'] == 'send') { global $wpdb; $current_url = 'http://你的投稿页面地址'; // 注意修改此处的链接地址 $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) > 3000 || mb_strlen($content) < 100) { wp_die('内容必须填写,且长度不得超过3000字,不得少于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>'); } }
Baik, fungsi penyerahan asas telah ditambah untuk gaya borang yang tidak kelihatan, borang kekurangan item yang anda inginkan, dan lain-lain, anda boleh menambah item css dan borang. diri sendiri. Akhir sekali, anda juga dialu-alukan untuk menyumbang ke laman web ini
Sudah tentu, kaedah penyerahan laman web ini adalah untuk membuka fungsi pendaftaran bahagian belakang, bukan borang di atas.'post_content' => $post_content,
2、如果你想让用户在投稿的同时,将投稿者注册成你本站的投稿者,并将文章的作者归到这个投稿者的名下,你可以参考此条回复的内容修改相应的代码:查看回复。
3、如果你的博客文章都有自定义栏目,并且想在用户投稿的同时添加自定义栏目,可以参考这条回复:查看回复。
4、如果你觉得本文提供的文章编辑框太过单调,需要一个富文本编辑,你可以看看这篇文章(包含图片上传功能):WordPress投稿功能添加富文本编辑器
5、如果你使用了一些富文本编辑器,文章提交后内容中的代码都被转义了,可以参考这条回复:查看回复。
6、如果你需要投稿的文章发布后通知投稿者,可以看看这篇文章(前提投稿的文章默认是草稿状态,而不是直接发布):WordPress投稿功能添加邮件提醒功能
7、如果你想给投稿页面增加验证码功能,可以 点此下载 验证码文件,解压后将captcha目录放到当前主题目录下,然后在代码一中,将35行的:
<br clear="all">
改成:
<br clear="all">
将代码二中的:
if( isset($_POST['tougao_form']) && $_POST['tougao_form'] == 'send') {
改成:
if (!isset($_SESSION)) { session_start(); session_regenerate_id(TRUE); } if( isset($_POST['tougao_form']) && $_POST['tougao_form'] == 'send') { if(empty($_POST['captcha_code']) || empty($_SESSION['ludou_lcr_secretword']) || (trim(strtolower($_POST['captcha_code'])) != $_SESSION['ludou_lcr_secretword']) ) { wp_die('验证码不正确!点此返回'); }
大功造成!
推荐学习:《WordPress教程》
Atas ialah kandungan terperinci Penjelasan terperinci tentang cara menambah fungsi penyerahan dalam WordPress. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!