/** * Plugin Name: WP文章自动刷新插件 * Plugin URI: https://www.imwpweb.com/ * Description: 真正意义上的文章翻新插件,模拟手工重新发布,让老旧文章重新获得搜索引擎青睐,提升网站流量 * Version: 1.0.0 * Author: IMWPWEB * Author URI: https://www.imwpweb.com/ * Text Domain: wp-article-refresh * Domain Path: /languages * License: GPL v2 or later */ if (!defined('ABSPATH')) { exit; } // 插件常量定义 define('WP_ARTICLE_REFRESH_VERSION', '1.0.0'); define('WP_ARTICLE_REFRESH_PLUGIN_DIR', plugin_dir_path(__FILE__)); define('WP_ARTICLE_REFRESH_PLUGIN_URL', plugin_dir_url(__FILE__)); /** * 主插件类 */ class WP_Article_Refresh { /** * 单例实例 */ private static $instance = null; /** * 获取单例实例 */ public static function get_instance() { if (null === self::$instance) { self::$instance = new self(); } return self::$instance; } /** * 构造函数 */ private function __construct() { // 注册激活/停用钩子 register_activation_hook(__FILE__, array($this, 'activate')); register_deactivation_hook(__FILE__, array($this, 'deactivate')); // 初始化插件 add_action('init', array($this, 'init')); // 添加定时任务钩子 add_action('wp_article_refresh_event', array($this, 'do_refresh')); } /** * 插件激活 */ public function activate() { // 设置默认选项 $default_options = array( 'enabled' => 1, 'refresh_interval' => 60, // 分钟 'days_range' => 365, // 1年内 'daily_limit' => 10, // 每天最多翻新10篇 'time_window_start' => '00:00', 'time_window_end' => '23:59', 'categories' => array(), // 空数组表示所有分类 'exclude_categories' => array(), 'refresh_mode' => 'today', // today:今天, random:随机前几天, gradual:逐渐递增 'refreshed_today' => 0, 'last_refresh_date' => date('Y-m-d'), 'total_refreshed' => 0 ); if (!get_option('wp_article_refresh_options')) { add_option('wp_article_refresh_options', $default_options); } // 设置定时任务 if (!wp_next_scheduled('wp_article_refresh_event')) { wp_schedule_event(time(), 'wp_article_refresh_interval', 'wp_article_refresh_event'); } // 刷新重写规则 flush_rewrite_rules(); } /** * 插件停用 */ public function deactivate() { // 清除定时任务 wp_clear_scheduled_hook('wp_article_refresh_event'); // 刷新重写规则 flush_rewrite_rules(); } /** * 初始化插件 */ public function init() { // 加载文本域 load_plugin_textdomain('wp-article-refresh', false, dirname(plugin_basename(__FILE__)) . '/languages'); // 添加自定义定时间隔 add_filter('cron_schedules', array($this, 'add_cron_interval')); // 添加管理菜单 add_action('admin_menu', array($this, 'add_admin_menu')); // 注册AJAX处理 add_action('wp_ajax_wp_article_refresh', array($this, 'handle_ajax')); // 添加设置链接 add_filter('plugin_action_links_' . plugin_basename(__FILE__), array($this, 'add_settings_link')); // 加载前端资源(仅在插件页面加载) add_action('admin_enqueue_scripts', array($this, 'enqueue_assets')); } /** * 添加自定义Cron间隔 */ public function add_cron_interval($schedules) { $options = get_option('wp_article_refresh_options'); $interval = isset($options['refresh_interval']) ? $options['refresh_interval'] : 60; $schedules['wp_article_refresh_interval'] = array( 'interval' => $interval * 60, 'display' => sprintf(__('每 %d 分钟', 'wp-article-refresh'), $interval) ); return $schedules; } /** * 添加管理菜单 */ public function add_admin_menu() { add_menu_page( __('文章自动刷新', 'wp-article-refresh'), __('文章刷新', 'wp-article_refresh'), 'manage_options', 'wp-article-refresh', array($this, 'render_admin_page'), 'dashicons-update', 30 ); } /** * 渲染管理页面 */ public function render_admin_page() { // 处理表单提交 if (isset($_POST['wp_article_refresh_nonce']) && wp_verify_nonce($_POST['wp_article_refresh_nonce'], 'wp_article_refresh_save')) { $this->save_options(); echo '

' . __('设置已保存!', 'wp-article-refresh') . '

'; } // 处理手动刷新 if (isset($_POST['wp_article_refresh_manual']) && wp_verify_nonce($_POST['wp_article_refresh_manual_nonce'], 'wp_article_refresh_manual')) { $result = $this->do_refresh(); if ($result) { echo '

' . sprintf(__('成功刷新了 %d 篇文章!', 'wp-article-refresh'), $result) . '

'; } else { echo '

' . __('没有找到符合条件的文章或已达今日上限!', 'wp-article-refresh') . '

'; } } $options = get_option('wp_article_refresh_options'); $stats = $this->get_statistics(); $categories = get_categories(array('hide_empty' => false)); include WP_ARTICLE_REFRESH_PLUGIN_DIR . 'templates/admin-page.php'; } /** * 保存设置选项 */ private function save_options() { $options = array( 'enabled' => isset($_POST['enabled']) ? 1 : 0, 'refresh_interval' => absint($_POST['refresh_interval']), 'days_range' => absint($_POST['days_range']), 'daily_limit' => absint($_POST['daily_limit']), 'time_window_start' => sanitize_text_field($_POST['time_window_start']), 'time_window_end' => sanitize_text_field($_POST['time_window_end']), 'categories' => isset($_POST['categories']) ? array_map('absint', $_POST['categories']) : array(), 'exclude_categories' => isset($_POST['exclude_categories']) ? array_map('absint', $_POST['exclude_categories']) : array(), 'refresh_mode' => sanitize_text_field($_POST['refresh_mode']), 'refreshed_today' => isset($_POST['reset_count']) ? 0 : get_option('wp_article_refresh_options', array()) ); // 获取之前的设置 $prev_options = get_option('wp_article_refresh_options', array()); $options['refreshed_today'] = isset($prev_options['refreshed_today']) ? $prev_options['refreshed_today'] : 0; $options['last_refresh_date'] = isset($prev_options['last_refresh_date']) ? $prev_options['last_refresh_date'] : date('Y-m-d'); $options['total_refreshed'] = isset($prev_options['total_refreshed']) ? $prev_options['total_refreshed'] : 0; update_option('wp_article_refresh_options', $options); // 重新设置定时任务 wp_clear_scheduled_hook('wp_article_refresh_event'); if ($options['enabled']) { wp_schedule_event(time(), 'wp_article_refresh_interval', 'wp_article_refresh_event'); } } /** * 执行文章刷新 */ public function do_refresh() { $options = get_option('wp_article_refresh_options'); // 检查插件是否启用 if (!$options['enabled']) { return 0; } // 检查时间窗口 $current_time = current_time('H:i'); if ($current_time < $options['time_window_start'] || $current_time > $options['time_window_end']) { return 0; } // 重置每日计数 $today = date('Y-m-d'); if ($options['last_refresh_date'] !== $today) { $options['refreshed_today'] = 0; $options['last_refresh_date'] = $today; } // 检查每日限制 if ($options['refreshed_today'] >= $options['daily_limit']) { return 0; } // 获取符合条件的文章 $args = array( 'post_type' => 'post', 'post_status' => 'publish', 'posts_per_page' => $options['daily_limit'] - $options['refreshed_today'], 'date_query' => array( 'before' => date('Y-m-d H:i:s', strtotime('-1 day')), 'after' => date('Y-m-d H:i:s', strtotime('-' . $options['days_range'] . ' days')) ), 'orderby' => 'rand', 'no_found_rows' => true ); // 分类筛选 if (!empty($options['categories'])) { $args['category__in'] = $options['categories']; } if (!empty($options['exclude_categories'])) { $args['category__not_in'] = $options['exclude_categories']; } $query = new WP_Query($args); $refreshed = 0; if ($query->have_posts()) { foreach ($query->posts as $post) { // 更新文章日期 $new_date = $this->calculate_new_date($post->post_date, $options['refresh_mode']); wp_update_post(array( 'ID' => $post->ID, 'post_date' => $new_date, 'post_date_gmt' => get_gmt_from_date($new_date), 'post_modified' => current_time('mysql'), 'post_modified_gmt' => current_time('mysql', 1) )); // 清理缓存 clean_post_cache($post->ID); $refreshed++; } wp_reset_postdata(); } // 更新统计 $options['refreshed_today'] += $refreshed; $options['total_refreshed'] += $refreshed; update_option('wp_article_refresh_options', $options); return $refreshed; } /** * 计算新日期 */ private function calculate_new_date($original_date, $mode) { $original = strtotime($original_date); $now = time(); switch ($mode) { case 'today': // 设置为今天 return date('Y-m-d H:i:s', time()); case 'random': // 随机1-7天前 $random_days = wp_rand(1, 7); $new_time = strtotime("-{$random_days} days"); return date('Y-m-d H:i:s', $new_time); case 'gradual': // 逐渐递增(基于原日期递减) $days_diff = floor(($now - $original) / 86400); if ($days_diff > 7) { $new_time = strtotime('-7 days'); } else { $new_time = $original + 86400; // 往后推一天 } return date('Y-m-d H:i:s', $new_time); default: return date('Y-m-d H:i:s', time()); } } /** * 获取统计信息 */ public function get_statistics() { $options = get_option('wp_article_refresh_options'); // 统计文章总数 $total_posts = wp_count_posts('post'); // 统计符合条件的文章数量 $args = array( 'post_type' => 'post', 'post_status' => 'publish', 'date_query' => array( 'before' => date('Y-m-d H:i:s', strtotime('-1 day')), 'after' => date('Y-m-d H:i:s', strtotime('-' . $options['days_range'] . ' days')) ), 'no_found_rows' => true ); if (!empty($options['categories'])) { $args['category__in'] = $options['categories']; } if (!empty($options['exclude_categories'])) { $args['category__not_in'] = $options['exclude_categories']; } $query = new WP_Query($args); $eligible_posts = $query->found_posts; return array( 'total_posts' => $total_posts->publish, 'eligible_posts' => $eligible_posts, 'refreshed_today' => $options['refreshed_today'], 'daily_limit' => $options['daily_limit'], 'total_refreshed' => $options['total_refreshed'], 'is_enabled' => $options['enabled'], 'next_refresh' => wp_next_scheduled('wp_article_refresh_event') ? date('Y-m-d H:i:s', wp_next_scheduled('wp_article_refresh_event')) : __('未设置', 'wp-article-refresh') ); } /** * 处理AJAX请求 */ public function handle_ajax() { if (!current_user_can('manage_options') || !wp_verify_nonce($_POST['nonce'], 'wp_article_refresh_ajax')) { wp_die(__('无权限', 'wp-article-refresh')); } $action = sanitize_text_field($_POST['sub_action']); switch ($action) { case 'get_stats': $stats = $this->get_statistics(); wp_send_json_success($stats); break; case 'refresh_now': $result = $this->do_refresh(); wp_send_json_success(array('refreshed' => $result)); break; default: wp_send_json_error(__('未知操作', 'wp-article-refresh')); } } /** * 添加设置链接 */ public function add_settings_link($links) { $settings_link = '' . __('设置', 'wp-article-refresh') . ''; array_unshift($links, $settings_link); return $links; } /** * 加载资源文件 */ public function enqueue_assets($hook) { if ('toplevel_page_wp-article-refresh' !== $hook) { return; } wp_enqueue_style('wp-article-refresh-admin', WP_ARTICLE_REFRESH_PLUGIN_URL . 'assets/css/admin.css', array(), WP_ARTICLE_REFRESH_VERSION); wp_enqueue_script('wp-article-refresh-admin', WP_ARTICLE_REFRESH_PLUGIN_URL . 'assets/js/admin.js', array('jquery'), WP_ARTICLE_REFRESH_VERSION, true); wp_localize_script('wp-article-refresh-admin', 'wpArticleRefresh', array( 'ajaxUrl' => admin_url('admin-ajax.php'), 'nonce' => wp_create_nonce('wp_article_refresh_ajax'), 'strings' => array( 'confirm' => __('确定要手动刷新吗?', 'wp-article-refresh'), 'refreshing' => __('刷新中...', 'wp-article-refresh'), 'success' => __('刷新成功!', 'wp-article-refresh'), 'error' => __('刷新失败!', 'wp-article-refresh') ) )); } } // 初始化插件 WP_Article_Refresh::get_instance(); // 创建模板目录 function wp_article_refresh_create_templates_dir() { $dir = WP_ARTICLE_REFRESH_PLUGIN_DIR . 'templates'; if (!file_exists($dir)) { mkdir($dir, 0755, true); } } add_action('admin_init', 'wp_article_refresh_create_templates_dir'); 稳定币_第32页_创想鸟

稳定币

  • 如何计算比特币合约的盈亏?比特币合约盈亏计算公式

    在进行比特币合约交易时,精确计算盈亏是每位投资者必备的核心技能。不同的合约类型,其盈亏计算方式也存在显著差异,理解这些公式是成功交易的第一步。 正向合约(U本位)盈亏计算 1、多仓(买入做多)盈亏 = (平仓价格 – 开仓价格) * 合约数量。这种合约的计价和结算都使用稳定币(如USDT…

    2025年12月11日
    000
  • 什么是USDC(美元硬币)?USDC如何运作、利弊及未来

    USDC(美元硬币)作为一种备受关注的加密资产,它将美元的稳定价值与区块链技术的去中心化和透明性相结合。USDC是一种由中心化实体发行的抵押型稳定币,旨在1:1锚定美元价值,即1个USDC始终等于1美元。这种锚定机制通过储备金来支撑,发行方会持有等值的美元或其他高流动性资产作为抵押,并定期接受审计以…

    2025年12月11日
    000
  • 2025USDT泰达币完整介绍,十分钟带你了解USDT、诈 骗风险及购买方法

    泰达币(USDT)作为一种备受关注的数字资产,其全称为Tether,自问世以来便在加密货币市场中占据了举足轻重的地位。它旨在提供一种价格稳定的数字货币,与美元1:1挂钩,从而在波动剧烈的加密货币世界中扮演“避风港”的角色。USDT的出现,极大地便利了数字资产的交易、存储和跨境结算,为全球用户提供了一…

    2025年12月11日
    000
  • 2025年如何购买 USDT?最新费率对比与安全购买指南

    随着加密货币市场的快速发展,稳定币USDT(Tether)成为投资者常用的交易和避险工具。那么2025年新手如何安全、高效地购买USDT?本文将为您提供最新购买渠道、费率对比及安全指南。 一、USDT概述与用途 USDT是一种与美元挂钩的稳定币,具有价格稳定、流动性高的特点。投资者通常用于数字资产交…

    2025年12月11日
    000
  • 百亿抛压遇45%销毁提案,Hyperliquid估值大战升级

    近期,Hyperliquid市场再次引发关注。百亿级别的代币抛压遇到45%销毁提案,市场对代币价值重估的讨论持续升温。 一、Hyperliquid估值争夺背景 Hyperliquid作为新兴稳定币生态,短期内面临巨量抛压。百亿级代币的流动性释放,引发投资者担忧市场供给过剩可能压低价格。 二、抛压应对…

    2025年12月11日
    000
  • 2025年如何用 PayPal 购买 USDT?最新费率对比和安全指南

    USDT(泰达币)作为一种重要的稳定币,在加密市场中扮演着不可或缺的角色。它与美元1:1挂钩,为投资者提供了规避市场波动风险的工具,同时也成为进入加密世界的便捷入口。而PayPal,作为全球领先的在线支付平台,其用户基础和便捷性使其成为许多人购买数字资产的潜在选择。2025年,随着支付技术的不断进步…

    2025年12月11日
    100
  • 币安合约交易最全指南:一步步教大家从开合约账户到交易完成

    开立币安合约账户需先注册/登录,点击“衍生品”开通合约账户并完成KYC。资金从现货划转至合约账户作为保证金。币安提供U本位(如USDT结算)和币本位合约,支持1-125倍杠杆,新手建议低杠杆。交易时选择交易对、订单类型,进行开多/开空操作,并设置止盈止损以控制风险。平仓后盈亏结算,需注意合约高风险,…

    2025年12月11日
    000
  • 如何购买wifi币 wifi币购买教程(内附平台地址)

    本文旨在为初次接触wifi币的朋友提供一份清晰易懂的购买指南,将详细拆解从选择平台到完成交易的每一个步骤,帮助您快速上手并安全地获得这一数字资产。 一、选择合适的交易平台 1、选择一个安全可靠的平台是首要任务。在做决定时,应重点考量平台的安全性、用户规模和流动性。一个成熟的平台能提供更稳定的交易环境…

    2025年12月11日
    000
  • 币圈一级市场怎么进入?普通人进入币圈一级市场的方法

    Binance币安 官网直达: 安卓安装包下载: 欧易OKX ️ 官网直达: 安卓安装包下载: Huobi火币️ 官网直达: 安卓安装包下载: 想进币圈一级市场,普通人其实有几种实际的路子可走。关键是要明白一级市场就是买项目最早期的代币,通常风险高但潜在回报也大。下面说说常见的进入方法。 关注官方渠…

    2025年12月11日
    000
  • 在币圈如何进行合约交易?欧意OKX交易所合约交易新手指南大全

    OKX官方合作伙伴认证 · 一站式安全交易体验 官网直达: 安卓安装包下载: 想在币圈做合约交易,欧意(OKX)是主流选择之一。新手上手关键在于理解流程、控制风险,而不是一上来就追求高收益。下面从开户到操作,一步步讲清楚怎么开始。 注册与安全设置 打开OKX官网,先完成账号注册。这一步要提供手机号或…

    2025年12月11日
    000
关注微信