當前位置: 首頁>>代碼示例>>PHP>>正文


PHP wp_nonce_tick函數代碼示例

本文整理匯總了PHP中wp_nonce_tick函數的典型用法代碼示例。如果您正苦於以下問題:PHP wp_nonce_tick函數的具體用法?PHP wp_nonce_tick怎麽用?PHP wp_nonce_tick使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了wp_nonce_tick函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: wp_verify_nonce

 /**
  * Verify that correct nonce was used with time limit.
  *
  * The user is given an amount of time to use the token, so therefore, since the
  * UID and $action remain the same, the independent variable is the time.
  *
  * @since 2.0.3
  *
  * @param string $nonce Nonce that was used in the form to verify
  * @param string|int $action Should give context to what is taking place and be the same when nonce was created.
  *
  * @return false|int False if the nonce is invalid, 1 if the nonce is valid and generated between
  *                   0-12 hours ago, 2 if the nonce is valid and generated between 12-24 hours ago.
  */
 function wp_verify_nonce($nonce, $action = -1)
 {
     $nonce = (string) $nonce;
     $user = wp_get_current_user();
     $uid = (int) $user->ID;
     if (!$uid) {
         /**
          * Filter whether the user who generated the nonce is logged out.
          *
          * @since 3.5.0
          *
          * @param int $uid ID of the nonce-owning user.
          * @param string $action The nonce action.
          */
         $uid = apply_filters('nonce_user_logged_out', $uid, $action);
     }
     if (empty($nonce)) {
         die('<mainwp>' . base64_encode(json_encode(array('error' => 'You dont send nonce: ' . $action))) . '</mainwp>');
     }
     $token = wp_get_session_token();
     $i = wp_nonce_tick();
     // Nonce generated 0-12 hours ago
     $expected = substr(wp_hash($i . '|' . $action . '|' . $uid . '|' . $token, 'nonce'), -12, 10);
     if (hash_equals($expected, $nonce)) {
         return 1;
     }
     // Nonce generated 12-24 hours ago
     $expected = substr(wp_hash($i - 1 . '|' . $action . '|' . $uid . '|' . $token, 'nonce'), -12, 10);
     if (hash_equals($expected, $nonce)) {
         return 2;
     }
     // Invalid nonce
     die('<mainwp>' . base64_encode(json_encode(array('error' => 'Invalid nonce. Try use: ' . $action))) . '</mainwp>');
 }
開發者ID:jexmex,項目名稱:mainwp-child,代碼行數:48,代碼來源:class-mainwp-child.php

示例2: wptouch_create_anonymous_nonce

function wptouch_create_anonymous_nonce($action)
{
    // Creates a valid WordPress nonce for anonymous requests.
    $uid = 0;
    $token = '';
    $i = wp_nonce_tick();
    $nonce = substr(wp_hash($i . '|' . $action . '|' . $uid . '|' . $token, 'nonce'), -12, 10);
    return $nonce;
}
開發者ID:sb-xs,項目名稱:que-pour-elle,代碼行數:9,代碼來源:wptouch-admin-upgrade-license.php

示例3: verify_nonce

 public function verify_nonce($nonce, $action)
 {
     $i = wp_nonce_tick();
     if (substr(wp_hash($i . $action, 'nonce'), -12, 10) === $nonce) {
         return true;
     }
     if (substr(wp_hash($i - 1 . $action, 'nonce'), -12, 10) === $nonce) {
         return true;
     }
     return false;
 }
開發者ID:jeanpage,項目名稱:ca_learn,代碼行數:11,代碼來源:authentication.php

示例4: wp_create_nonce

function wp_create_nonce($action = -1)
{
    $user = wp_get_current_user();
    $uid = (int) $user->ID;
    if (!$uid) {
        /** This filter is documented in wp-includes/pluggable.php */
        $uid = apply_filters('nonce_user_logged_out', $uid, $action);
    }
    $token = wp_get_session_token();
    $i = wp_nonce_tick();
    return substr(wp_hash($i . '|' . $action . '|' . $uid . '|' . $token, 'nonce'), -12, 10);
}
開發者ID:AppItNetwork,項目名稱:yii2-wordpress-themes,代碼行數:12,代碼來源:pluggable.php

示例5: verifyNonce

 /**
  * Local nonce verification.
  * WordPress uses the UID and sometimes I don't want that
  * Verify that correct nonce was used with time limit.
  *
  * The user is given an amount of time to use the token, so therefore, since the
  * $action remain the same, the independent variable is the time.
  *
  * @param string     $nonce  Nonce that was used in the form to verify
  * @param string|int $action Should give context to what is taking place and be the same when nonce was created.
  *
  * @return bool Whether the nonce check passed or failed.
  */
 public static function verifyNonce($nonce, $action = -1)
 {
     $r = false;
     $i = wp_nonce_tick();
     // Nonce generated 0-12 hours ago
     if (substr(wp_hash($i . $action, 'nonce'), -12, 10) == $nonce) {
         $r = 1;
     } elseif (substr(wp_hash($i - 1 . $action, 'nonce'), -12, 10) == $nonce) {
         // Nonce generated 12-24 hours ago
         $r = 2;
     }
     return $r;
 }
開發者ID:Nanotraktor,項目名稱:AVH-First-Defense-Against-Spam,代碼行數:26,代碼來源:avh-security.php

示例6: wp_create_nonce

 /**
  * Creates a random, one time use token.
  *
  * @since 2.0.4
  *
  * @param string|int $action Scalar value to add context to the nonce.
  * @return string The one use form token
  */
 function wp_create_nonce($action = -1)
 {
     $user = wp_get_current_user();
     $uid = (int) $user->id;
     $i = wp_nonce_tick();
     return substr(wp_hash($i . $action . $uid), -12, 10);
 }
開發者ID:nurpax,項目名稱:saastafi,代碼行數:15,代碼來源:pluggable.php

示例7: wp_create_nonce

 /**
  * Creates a random, one time use token.
  *
  * @since 2.0.3
  *
  * @param string|int $action Scalar value to add context to the nonce.
  * @return string The one use form token
  */
 function wp_create_nonce($action = -1)
 {
     $user = wp_get_current_user();
     $uid = (int) $user->ID;
     if (!$uid) {
         $uid = apply_filters('nonce_user_logged_out', $uid, $action);
     }
     $i = wp_nonce_tick();
     return substr(wp_hash($i . '|' . $action . '|' . $uid, 'nonce'), -12, 10);
 }
開發者ID:souljatechie,項目名稱:Web-Dev,代碼行數:18,代碼來源:pluggable.php

示例8: rs_wpss_create_nonce

function rs_wpss_create_nonce($action, $name = '_wpss_nonce')
{
    /***
     * Creates a different nonce system than WordPress.
     * 24 hours or 1 time use. 
     * Difference vs WP nonces: Nonce must exist in database, is not tied to a user ID, and is truly 1 time use.
     * WP nonces don't work for every application. If a comment is posted, and a notification email is sent to admin with link to blacklist the IP, this works better.
     ***/
    $i = wp_nonce_tick();
    $timenow = time();
    $nonce = substr(rs_wpss_md5($i . $action . $name . WPSS_HASH . $timenow), -12, 10);
    $spamshield_nonces = get_option('spamshield_nonces');
    if (empty($spamshield_nonces)) {
        $spamshield_nonces = array();
    } else {
        foreach ($spamshield_nonces as $i => $n) {
            if ($n['expire'] <= $timenow) {
                unset($spamshield_nonces[$i]);
            }
        }
    }
    $expire = $timenow + 86400;
    /* 24 hours */
    $spamshield_nonces[] = array('nonce' => $nonce, 'action' => $action, 'name' => $name, 'expire' => $expire);
    update_option('spamshield_nonces', $spamshield_nonces, FALSE);
    return $nonce;
}
開發者ID:rosslibby,項目名稱:davinaplugins,代碼行數:27,代碼來源:wp-spamshield.php

示例9: get_jobrun_url

 /**
  *
  * Get a url to run a job of BackWPup
  *
  * @param string     $starttype Start types are 'runnow', 'runnowlink', 'cronrun', 'runext', 'restart', 'test'
  * @param int        $jobid     The id of job to start else 0
  * @return array|object [url] is the job url [header] for auth header or object form wp_remote_get()
  */
 public static function get_jobrun_url($starttype, $jobid = 0)
 {
     $wp_admin_user = get_users(array('role' => 'backwpup_admin', 'number' => 1));
     //get a user for cookie auth
     $url = site_url('wp-cron.php');
     $header = array();
     $authurl = '';
     $query_args = array('_nonce' => substr(wp_hash(wp_nonce_tick() . 'backwpup_job_run-' . $starttype, 'nonce'), -12, 10), 'doing_wp_cron' => sprintf('%.22F', microtime(true)));
     if (in_array($starttype, array('restart', 'runnow', 'cronrun', 'runext', 'test'))) {
         $query_args['backwpup_run'] = $starttype;
     }
     if (in_array($starttype, array('runnowlink', 'runnow', 'cronrun', 'runext')) && !empty($jobid)) {
         $query_args['jobid'] = $jobid;
     }
     if (get_site_option('backwpup_cfg_httpauthuser') && get_site_option('backwpup_cfg_httpauthpassword')) {
         $header['Authorization'] = 'Basic ' . base64_encode(get_site_option('backwpup_cfg_httpauthuser') . ':' . BackWPup_Encryption::decrypt(get_site_option('backwpup_cfg_httpauthpassword')));
         $authurl = get_site_option('backwpup_cfg_httpauthuser') . ':' . BackWPup_Encryption::decrypt(get_site_option('backwpup_cfg_httpauthpassword')) . '@';
     }
     if ($starttype == 'runext') {
         $query_args['_nonce'] = get_site_option('backwpup_cfg_jobrunauthkey');
         $query_args['doing_wp_cron'] = NULL;
         if (!empty($authurl)) {
             $url = str_replace('https://', 'https://' . $authurl, $url);
             $url = str_replace('http://', 'http://' . $authurl, $url);
         }
     }
     if ($starttype == 'runnowlink' && (!defined('ALTERNATE_WP_CRON') || !ALTERNATE_WP_CRON)) {
         $url = wp_nonce_url(network_admin_url('admin.php'), 'backwpup_job_run-' . $starttype);
         $query_args['page'] = 'backwpupjobs';
         $query_args['action'] = 'runnow';
         $query_args['doing_wp_cron'] = NULL;
         unset($query_args['_nonce']);
     }
     if ($starttype == 'runnowlink' && defined('ALTERNATE_WP_CRON') && ALTERNATE_WP_CRON) {
         $query_args['backwpup_run'] = 'runnowalt';
         $query_args['_nonce'] = substr(wp_hash(wp_nonce_tick() . 'backwpup_job_run-runnowalt', 'nonce'), -12, 10);
         $query_args['doing_wp_cron'] = NULL;
     }
     //Extra for WP-Cron control
     if (class_exists('WP_Cron_Control') && ($starttype == 'runext' || $starttype == 'runnow' || $starttype == 'restart')) {
         $wp_cron_control_settings = get_option('wpcroncontrol_settings', array());
         if (empty($wp_cron_control_settings['secret_string']) && file_exists(WP_PLUGIN_DIR . '/wp-cron-control/wp-cron-control.php')) {
             $wp_cron_control_settings['secret_string'] = md5(realpath(WP_PLUGIN_DIR . '/wp-cron-control/wp-cron-control.php') . get_current_blog_id());
             $wp_cron_control_settings['enable'] = 1;
         }
         if (isset($wp_cron_control_settings['enable']) && $wp_cron_control_settings['enable'] == 1) {
             if (defined('WP_CRON_CONTROL_SECRET')) {
                 $wp_cron_control_settings['secret_string'] = WP_CRON_CONTROL_SECRET;
             }
             $query_args[$wp_cron_control_settings['secret_string']] = '';
             $query_args['doing_wp_cron'] = NULL;
         }
     }
     $cron_request = apply_filters('cron_request', array('url' => add_query_arg($query_args, $url), 'key' => $query_args['doing_wp_cron'], 'args' => array('blocking' => FALSE, 'sslverify' => apply_filters('https_local_ssl_verify', true), 'timeout' => 0.01, 'headers' => $header, 'cookies' => array(new WP_Http_Cookie(array('name' => AUTH_COOKIE, 'value' => wp_generate_auth_cookie($wp_admin_user[0]->ID, time() + 300, 'auth'))), new WP_Http_Cookie(array('name' => LOGGED_IN_COOKIE, 'value' => wp_generate_auth_cookie($wp_admin_user[0]->ID, time() + 300, 'logged_in')))), 'user-agent' => BackWpup::get_plugin_data('User-Agent'))));
     if ($starttype == 'test') {
         $cron_request['args']['timeout'] = 15;
         $cron_request['args']['blocking'] = TRUE;
     }
     if (!in_array($starttype, array('runnowlink', 'runext'))) {
         set_transient('doing_cron', $query_args['doing_wp_cron']);
         return wp_remote_post($cron_request['url'], $cron_request['args']);
     }
     return $cron_request;
 }
開發者ID:wangshijun101,項目名稱:morketing.cn,代碼行數:72,代碼來源:class-job.php

示例10: is_valid_token

 public function is_valid_token($token)
 {
     $token_json = base64_decode($token);
     $token_array = json_decode($token_json, true);
     if (empty($token_array)) {
         return false;
     }
     $timestamp = $token_array['timestamp'];
     $user_id = $token_array['user_id'];
     $new_status = $token_array['new_status'];
     $entry_id = $token_array['entry_id'];
     $sig = $token_array['sig'];
     $expiration_days = apply_filters('gravityflow_approval_token_expiration_days', 1);
     $i = wp_nonce_tick();
     $is_valid = false;
     for ($n = 1; $n <= $expiration_days; $n++) {
         $sig_key = sprintf('%s|%s|%s|%s|%s|%s', $i, $this->get_id(), $timestamp, $entry_id, $user_id, $new_status);
         $verification_sig = substr(wp_hash($sig_key), -12, 10);
         if (hash_equals($verification_sig, $sig)) {
             $is_valid = true;
             break;
         }
         $i--;
     }
     return $is_valid;
 }
開發者ID:jakejackson1,項目名稱:gravityflow,代碼行數:26,代碼來源:class-step-approval.php

示例11: check_backup_tasks

 /**
  * Checks if scheduled task is ready for execution,
  * if it is ready master sends google_drive_token, failed_emails, success_emails if are needed.
  *
  * @return void
  */
 function check_backup_tasks()
 {
     $this->check_cron_remove();
     $failed_emails = array();
     $settings = $this->tasks;
     if (is_array($settings) && !empty($settings)) {
         foreach ($settings as $task_name => $setting) {
             if (isset($setting['task_args']['next']) && $setting['task_args']['next'] < time()) {
                 //if ($setting['task_args']['next'] && $_GET['force_backup']) {
                 if ($setting['task_args']['url'] && $setting['task_args']['task_id'] && $setting['task_args']['site_key']) {
                     //Check orphan task
                     $check_data = array('task_name' => $task_name, 'task_id' => $setting['task_args']['task_id'], 'site_key' => $setting['task_args']['site_key'], 'worker_version' => MMB_WORKER_VERSION);
                     if (isset($setting['task_args']['account_info']['mwp_google_drive']['google_drive_token'])) {
                         $check_data['mwp_google_drive_refresh_token'] = true;
                     }
                     $check = $this->validate_task($check_data, $setting['task_args']['url']);
                     if ($check == 'paused' || $check == 'deleted') {
                         continue;
                     }
                     $worker_upto_3_9_22 = MMB_WORKER_VERSION <= '3.9.22';
                     // worker version is less or equals to 3.9.22
                     // This is the patch done in worker 3.9.22 because old worked provided message in the following format:
                     // token - not found or token - {...json...}
                     // The new message is a serialized string with google_drive_token or message.
                     if ($worker_upto_3_9_22) {
                         $potential_token = substr($check, 8);
                         if (substr($check, 0, 8) == 'token - ' && $potential_token != 'not found') {
                             $this->tasks[$task_name]['task_args']['account_info']['mwp_google_drive']['google_drive_token'] = $potential_token;
                             $settings[$task_name]['task_args']['account_info']['mwp_google_drive']['google_drive_token'] = $potential_token;
                             $setting['task_args']['account_info']['mwp_google_drive']['google_drive_token'] = $potential_token;
                         }
                     } else {
                         $potential_token = isset($check['google_drive_token']) ? $check['google_drive_token'] : false;
                         if ($potential_token) {
                             $this->tasks[$task_name]['task_args']['account_info']['mwp_google_drive']['google_drive_token'] = $potential_token;
                             $settings[$task_name]['task_args']['account_info']['mwp_google_drive']['google_drive_token'] = $potential_token;
                             $setting['task_args']['account_info']['mwp_google_drive']['google_drive_token'] = $potential_token;
                         }
                     }
                 }
                 $update = array('task_name' => $task_name, 'args' => $settings[$task_name]['task_args']);
                 if ($check != 'paused') {
                     $update['time'] = time();
                 }
                 //Update task with next schedule
                 $this->set_backup_task($update);
                 if ($check == 'paused') {
                     continue;
                 }
                 $result = $this->backup($setting['task_args'], $task_name);
                 $error = '';
                 if (is_array($result) && array_key_exists('error', $result)) {
                     $error = $result;
                     $this->set_backup_task(array('task_name' => $task_name, 'args' => $settings[$task_name]['task_args'], 'error' => $error));
                 } else {
                     if (@count($setting['task_args']['account_info'])) {
                         // Old way through sheduling.
                         // wp_schedule_single_event(time(), 'mmb_scheduled_remote_upload', array('args' => array('task_name' => $task_name)));
                         $nonce = substr(wp_hash(wp_nonce_tick() . 'mmb-backup-nonce' . 0, 'nonce'), -12, 10);
                         $cron_url = site_url('index.php');
                         $backup_file = $this->tasks[$task_name]['task_results'][count($this->tasks[$task_name]['task_results']) - 1]['server']['file_url'];
                         $del_host_file = $this->tasks[$task_name]['task_args']['del_host_file'];
                         $public_key = get_option('_worker_public_key');
                         $args = array('body' => array('backup_cron_action' => 'mmb_remote_upload', 'args' => json_encode(array('task_name' => $task_name, 'backup_file' => $backup_file, 'del_host_file' => $del_host_file)), 'mmb_backup_nonce' => $nonce, 'public_key' => $public_key), 'timeout' => 0.01, 'blocking' => false, 'sslverify' => apply_filters('https_local_ssl_verify', true));
                         wp_remote_post($cron_url, $args);
                     }
                 }
                 break;
                 //Only one backup per cron
             }
         }
     }
 }
開發者ID:jeanpage,項目名稱:ca_learn,代碼行數:79,代碼來源:backup.class.php

示例12: verify_nonce

 /**
  * Verifies nonce.
  *
  * @version 1.17.3
  */
 public static function verify_nonce($nonce, $action = false)
 {
     $user = wp_get_current_user();
     $uid = (int) $user->ID;
     if (empty($uid)) {
         $uid = $_SERVER['REMOTE_ADDR'];
     }
     $i = wp_nonce_tick();
     // Nonce generated 0-12 hours ago
     if (substr(wp_hash($i . $action . $uid, 'nonce'), -12, 10) == $nonce) {
         return 1;
     }
     // Nonce generated 12-24 hours ago
     if (substr(wp_hash($i - 1 . $action . $uid, 'nonce'), -12, 10) == $nonce) {
         return 2;
     }
     // Invalid nonce
     return false;
 }
開發者ID:ksan5835,項目名稱:rankproperties,代碼行數:24,代碼來源:class_functions.php

示例13: verify_anon_nonce

 function verify_anon_nonce($nonce, $action = -1)
 {
     $i = wp_nonce_tick();
     // Nonce generated 0-12 hours ago
     if (substr(wp_hash($i . $action), -12, 10) == $nonce) {
         return 1;
     }
     // Nonce generated 12-24 hours ago
     if (substr(wp_hash($i - 1 . $action), -12, 10) == $nonce) {
         return 2;
     }
     // Invalid nonce
     return false;
 }
開發者ID:masayukiando,項目名稱:wordpress-event-search,代碼行數:14,代碼來源:ktai_style.php

示例14: wooRedirect

 function wooRedirect($message, $error = false)
 {
     if (!$this->useWoo()) {
         return false;
     }
     if ($error === false) {
         $type = 'cs_message';
     } else {
         $type = 'cs_error';
     }
     $i = wp_nonce_tick();
     $nonce = substr(wp_hash($i . 'dit_logout' . 0, 'nonce'), -12, 10);
     wp_redirect(get_permalink(woocommerce_get_page_id('myaccount')) . '?' . $type . '=' . urlencode($message) . '&_nonce=' . $nonce);
     exit;
 }
開發者ID:laiello,項目名稱:suitex,代碼行數:15,代碼來源:loginx_functions.php

示例15: verify_noprivnonce

 public static function verify_noprivnonce($nonce, $action, $id)
 {
     $i = wp_nonce_tick();
     if (substr(wp_hash($i . $action . $id, 'nonce'), -12, 10) == $nonce) {
         return 1;
     }
     if (substr(wp_hash($i - 1 . $action . $id, 'nonce'), -12, 10) == $nonce) {
         return 2;
     }
     return false;
 }
開發者ID:xiphe,項目名稱:thewptools,代碼行數:11,代碼來源:THEWPTOOLS.php


注:本文中的wp_nonce_tick函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。