wordpress邀请码的实现-利剑分享-科技生活
利剑分享-科技生活-利剑分享-科技生活
利剑分享-科技生活

wordpress邀请码的实现

wordpress邀请码的实现

有的客户需要邀请码注册,wp自学笔记这就将实现代码贡献出来,在实现邀请码的功能时有参考过一个插件。

思路:

1. 需要新建一个数据表来保存邀请码。

2. 后台需要两个页面:邀请码列表、添加邀请码。

3. 添加邀请码的时候需要能设置前缀,一次生成多个邀请码,邀请码长度可自定义,每个邀请码使用次数可设置。

数据表

code:邀请码、max:邀请码使用次数、users:使用这个验证码的所有用户、status:验证码是否可用。

数据库操作

数据库操作部分代码包括:1. 建立数据库。2.对数据的获取、增加、删除、更改等操作。

  1. <?php
  2. //第一次启用主题时执行
  3.  ashuwp_load_theme() {
  4.    $pagenow;
  5.    ( is_admin() && ‘themes.php’ == $pagenow && isset( $_GET[‘activated’] ) ){
  6.     ashuwp_invitation_code_install();
  7.   }
  8. }
  9. add_action( ‘load-themes.php’, ‘ashuwp_load_theme’ );
  10. //建立数据表
  11.  ashuwp_invitation_code_install(){
  12.    $wpdb;
  13.   $table_name = $wpdb->prefix . ‘invitation_code’;
  14.   ( $wpdb->get_var(“SHOW TABLES LIKE ‘$table_name'”) != $table_name ) :
  15.     $sql = ” CREATE TABLE `”.$wpdb->prefix.“invitation_code` (
  16.       `id` BIGINT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
  17.       `code` varchar(40),
  18.       `max` INT NOT NULL,
  19.       `users` varchar(20),
  20.       `status` tinyint
  21.       ) ENGINE = MYISAM DEFAULT CHARSET=utf8;”;
  22.     (ABSPATH . ‘wp-admin/includes/upgrade.php’);
  23.     dbDelta($sql);
  24.   ;
  25. }
  26. //插入数据
  27.  ashuwp_insert_invitation_code( $code$max = 1, $users$status){
  28.    $wpdb;
  29.   ($code==){
  30.      false;
  31.   }
  32.   $code = trim($code);
  33.   $code_exists = ashuwp_check_invitation_code($code);
  34.   (!$code_exists){
  35.     $insert = “insert into “.$wpdb->prefix.“invitation_code (code,max,users,status) values( ‘$code’, ‘$max’, ”,’1′)”;
  36.     $wpdb->query($insert);
  37.      true;
  38.   }{
  39.      false;
  40.   }
  41. }
  42. //检查邀请码是否已存在
  43.  ashuwp_check_invitation_code( $code ){
  44.    $wpdb;
  45.   $sql = “select * from “.$wpdb->prefix.“invitation_code where code=’$code'”;
  46.   $result = $wpdb->get_results($sql);
  47.   (!($result)){
  48.      true;
  49.   }{
  50.      false;
  51.   }
  52. }
  53. //获取邀请码
  54.  ashuwp_get_invitation_code($per_page=50, $page=1){
  55.    $wpdb;
  56.   $page = (int)$page;
  57.   $per_page = (int)$per_page;
  58.   (!$page){
  59.     $page = 1;
  60.   }
  61.   (!$per_page){
  62.     $per_page = 50;
  63.   }
  64.   $begin = $per_page*($page-1);
  65.   $end = $per_page*$page;
  66.   $sql = “select * from “.$wpdb->prefix.“invitation_code limit $begin,$end”;
  67.   $results = $wpdb->get_results($sql,’ARRAY_A’);
  68.    $results;
  69. }
  70. //邀请码的删除、启用、禁用。
  71.  ashuwp_operation_invitation_code( $id$action ){
  72.    $wpdb;
  73.   $id = (int)$id;
  74.   (!$id){
  75.      false;
  76.   }
  77.   (!in_array($action,(‘delete‘,’deactive’,’active’))){
  78.      false;
  79.   }
  80.   ($action ==’delete‘){
  81.     $sql = “delete from “.$wpdb->prefix .“invitation_code where id=’$id'”;
  82.   }
  83.   ($action ==’deactive’){
  84.     $sql = “update “.$wpdb->prefix .“invitation_code set status=0 where id=’$id'”;
  85.   }
  86.   ($action ==’active’){
  87.     $sql = “update “.$wpdb->prefix .“invitation_code set status=1 where id=’$id'”;
  88.   }
  89.   $result = $wpdb->query($sql);
  90.   ($result){
  91.      true;
  92.   }{
  93.      false;
  94.   }
  95. }

网站后台
网站后台部分代码包括:1. 邀请码列表页面。2. 邀请码增加页面。

  1. <?php
  2.  ashuwp_invitation_code_admin {
  3.     $instance;
  4.     __construct(){
  5.     add_action( ‘admin_menu’, (&$this, ‘ashuwp_invitation_code_menu’) );
  6.   }
  7.    ashuwp_invitation_code_menu(){
  8.     add_menu_page( ‘邀请码’, ‘邀请码’, ‘manage_options’, ‘invitation_code’, (&$this, ‘invitation_code_list’),,27);
  9.     add_submenu_page(‘invitation_code’, ‘添加邀请码’, ‘添加邀请码’, ‘manage_options’, ‘invitation_code_add’, (&$this, ‘invitation_code_add’));
  10.   }
  11.    invitation_code_list(){
  12.     ( isset($_GET[‘code_action’]) && in_array($_GET[‘code_action’],(‘delete‘,’deactive’,’active’)) && isset($_GET[‘code_id’]) ){
  13.       $code_id = (int)$_GET[‘code_id’];
  14.       (!$code_id){
  15.         ;
  16.       }
  17.       $result = ashuwp_operation_invitation_code( $code_id$_GET[‘code_action’] );
  18.     }
  19.     $code_lists = ashuwp_get_invitation_code(999,1);
  20.   ?>
  21.     <div =“wrap”>
  22.       <h1 =“wp-heading-inline”>邀请码</h1>
  23.       <a href=“<?php echo admin_url( ‘admin.php?page=invitation_code_add’ ); ?>” =“page-title-action”>添加</a>
  24.       <hr =“wp-header-end”>
  25.       <?php
  26.       (isset($result)){
  27.         ($result){
  28.       ?>
  29.       <div id=“message” =“notice notice-success”>操作成功。</div>
  30.       <?php
  31.         }{
  32.         ?>
  33.         <div id=“message” =“notice notice-error”>操作失败。</div>
  34.         <?php
  35.         }
  36.       }
  37.       ?>
  38.       <ul =“subsubsub”><li =“all”>全部<span =“count”>(<?php echo count($code_lists); ?>)</span></ul>
  39.       <table =“wp-list-table widefat fixed”>
  40.         <thead>
  41.           <tr>
  42.             <th scope=“col”>ID</th>
  43.             <th scope=“col”>邀请码</th>
  44.             <th scope=“col”>统计(最大使用数/已使用)</th>
  45.             <th scope=“col”>用户</th>
  46.             <th scope=“col”>操作</th>
  47.           </tr>
  48.         </thead>
  49.         <tbody>
  50.         <?php
  51.         ($code_lists){
  52.           ($code_lists  $code){
  53.             $users = ();
  54.             (!($code[‘users’])){
  55.               $users = explode( ‘,’, $code[‘users’] );
  56.             }
  57.             $used = count($users);
  58.           ?>
  59.           <tr>
  60.             <td><?php echo $code[‘id’]; ?></td>
  61.             <td>
  62.               <?php echo $code[‘code’]; ?>
  63.               <?php
  64.               (($code[‘status’]) || !$code[‘status’]){
  65.                 echo ‘-已禁用’;
  66.               }
  67.               ?>
  68.             </td>
  69.             <td>
  70.               <?php echo $code[‘max’].’/’.$used; ?>
  71.             </td>
  72.             <td>
  73.               <?php
  74.               ( $users  $user_id ){
  75.                 $user = get_user_by(‘id’, $user_id);
  76.                 (!($user)){
  77.                 ?>
  78.                 <a href=“<?php echo admin_url( ‘user-edit.php?user_id=’.$user->ID ); ?>”><?php echo $user->user_login; ?></a>,
  79.                 <?php
  80.                 }
  81.               }
  82.               ?>
  83.             </td>
  84.             <td>
  85.               <a href=“<?php echo admin_url( ‘admin.php?page=invitation_code&code_action=delete&code_id=’.$code[‘id’] ); ?>”>删除</a>
  86.               <?php
  87.               (($code[‘status’]) || !$code[‘status’]){
  88.               ?>
  89.               <a href=“<?php echo admin_url( ‘admin.php?page=invitation_code&code_action=active&code_id=’.$code[‘id’] ); ?>”>启用</a>
  90.               <?php
  91.               }{
  92.               ?>
  93.               <a href=“<?php echo admin_url( ‘admin.php?page=invitation_code&code_action=deactive&code_id=’.$code[‘id’] ); ?>”>禁用</a>
  94.               <?php
  95.               }
  96.               ?>
  97.             </td>
  98.           </tr>
  99.           <?php
  100.           }
  101.         }
  102.         ?>
  103.         </tbody>
  104.         <tfoot>
  105.           <tr>
  106.             <th scope=“col”>ID</th>
  107.             <th scope=“col”>邀请码</th>
  108.             <th scope=“col”>统计</th>
  109.             <th scope=“col”>用户</th>
  110.             <th scope=“col”>操作</th>
  111.           </tr>
  112.         </tfoot>
  113.       </table>
  114.       <div =“tablenav bottom”>
  115.         <div =“tablenav-pages”>
  116.           <span =“pagination-links”>
  117.           </span>
  118.         </div>
  119.       </div>
  120.     </div>
  121.   <?php
  122.   }
  123.    invitation_code_add(){
  124.     $data_codes = ashuwp_get_invitation_code(999,1);
  125.     $code_list = ();
  126.     ($data_codes  $code){
  127.       $code_list[] = $code[‘code’];
  128.     }
  129.     (isset($_REQUEST[‘submit’]) && isset($_REQUEST[‘ashuwp_invitation_code_field’]) && check_admin_referer(‘ashuwp_invitation_code_action’, ‘ashuwp_invitation_code_field’) ) {
  130.       $code_prefix = ;
  131.       (!($_POST[‘code_prefix’])){
  132.         $code_prefix = trim($_POST[‘code_prefix’]);
  133.       }
  134.       $code_length = ;
  135.       (!($_POST[‘code_length’])){
  136.         $code_length = (int)$_POST[‘code_length’];
  137.       }
  138.       (!$code_length){
  139.         $code_length = 8;
  140.       }
  141.       $code_number = 1;
  142.       (!($_POST[‘code_number’])){
  143.         $code_number = (int)$_POST[‘code_number’];
  144.       }
  145.       (!$code_number){
  146.         $code_number = 1;
  147.       }
  148.       $code_counter = ;
  149.       (!($_POST[‘code_counter’])){
  150.         $code_counter = (int)$_POST[‘code_counter’];
  151.       }
  152.       (!$code_counter){
  153.         $code_counter = 1;
  154.       }
  155.       $i=1;
  156.       $code_tem = ();
  157.        ( $i <= $code_number ){
  158.         $tem = strtoupper$code_prefix . wp_generate_password( $code_length, false ) );
  159.         (!in_array($tem,$code_list)){
  160.           $i++;
  161.           $code_tem[] = $tem;
  162.           ashuwp_insert_invitation_code( $tem$code_counter, 1);
  163.         }
  164.       }
  165.     }
  166.   ?>
  167.     <div =“wrap”>
  168.       <h1 =“wp-heading-inline”>添加邀请码</h1>
  169.       <a href=“<?php echo admin_url( ‘admin.php?page=invitation_code_add’ ); ?>” =“page-title-action”>添加</a>
  170.       <hr =“wp-header-end”>
  171.       <?php
  172.       (!($code_tem)){
  173.       ?>
  174.       <div id=“message” =“notice notice-success”>
  175.         <p>邀请码添加成功:</p>
  176.         <?php
  177.         ($code_tem  $text){
  178.           echo ‘<p>’.$text.'</p>’;
  179.         }
  180.         ?>
  181.       </div>
  182.       <?php
  183.       }
  184.       ?>
  185.       <form action=“” method=“post”>
  186.         <table =“form-table”>
  187.           <tbody>
  188.             <tr>
  189.               <td><label =“code_prefix”>邀请码前缀</label></td>
  190.               <td>
  191.                 <input type=“text” id=“code_prefix” name=“code_prefix” =“regular-text”  value=“”/>
  192.                 <p =“description”>前缀可不填。</p>
  193.               </td>
  194.             </tr>
  195.             <tr>
  196.               <td><label =“code_length”>邀请码字符长度</label></td>
  197.               <td>
  198.                 <input type=“text” id=“code_length” name=“code_length” =“regular-text”  value=“”/>
  199.                 <p =“description”>字符长度不包括前缀,默认8个字符。</p>
  200.               </td>
  201.             </tr>
  202.             <tr>
  203.               <td><label =“code_number”>邀请码个数</label></td>
  204.               <td>
  205.                 <input type=“text” id=“code_number” name=“code_number” =“regular-text” value=“”/>
  206.                 <p =“description”>本次生成多少个邀请码,默认1个。</p>
  207.               </td>
  208.             </tr>
  209.             <tr>
  210.               <td><label =“code_counter”>允许使用的次数</label></td>
  211.               <td>
  212.                 <input type=“text” id=“code_counter” name=“code_counter” =“regular-text”  value=“”/>
  213.                 <p =“description”>每个邀请码允许使用的次数,默认1次。</p>
  214.               </td>
  215.             </tr>
  216.           </tbody>
  217.         </table>
  218.         <p =“submit”>
  219.           <?php wp_nonce_field( ‘ashuwp_invitation_code_action’,’ashuwp_invitation_code_field’ ); ?>
  220.           <input type=“submit” name=“submit” id=“submit” =“button button-primary” value=“生成邀请码”>
  221.         </p>
  222.       </form>
  223.     </div>
  224.   <?php
  225.   }
  226. }
  227. $invitation_code =  ashuwp_invitation_code_admin();

效果展示

1. 增加邀请码

2. 邀请码列表

结束语

上面范例代码,仅做参考使用,可根据实际自行优化,具体如何使用邀请码也请自行斟酌。

 

后记

阿树得空的时候,写了一个验证码插件,发布在了github上,有需要的朋友可直接下载使用。

https://github.com/ashuwp/Ashuwp_Invitation_Code

后记的后记

阿树将插件发布在了worpdress官网,在wordpress官网搜索ashuwp-invitaion-code即可找到。

地址:https://wordpress.org/plugins/ashuwp-invitaion-code/

© 版权声明
THE END
喜欢就支持一下吧
点赞11 分享