/**
* 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');
华夏千秋地图服装获取攻略_创想鸟
创想鸟 首页用户投稿
华夏千秋地图服装获取攻略
程序猿
•
2025年11月28日 23:13:00
•
用户投稿 •
阅读 0
冠缦胡缨(发型):景德镇裁缝铺 昨夜东风(配饰):景德镇裁缝铺 此岸拂名(衣服):上饶裁缝铺 杯酒龙泉(配饰):上饶裁缝铺 青铜面具(配饰):上饶傩面店 口舌生津(配饰):上饶客%ign%ignore_a _1% re_a_1% 湖目玉蛹(发型):杭州裁缝铺 金鲤田田(衣服):杭州裁缝铺 潋滟其中(配饰):杭州裁缝铺 剑坯(配饰):杭州铁匠铺 拂莲说(发型):姑苏绣坊 瑶台寻鹤(衣服):姑苏绣坊 寻百草(配饰):姑苏医馆 晚回舟(发型):春明镇裁缝铺 咏孟春(配饰):春明镇裁缝铺 村烟(发型):宁波绣坊 丰年(衣服):宁波绣坊 荷日(配饰):杨家村裁缝铺 溯游(发型):余东镇裁衣铺 道跻(衣服):扬州裁缝铺 兼葭(配饰):扬州裁缝铺 单手小斧(配饰):炼剑村铁匠铺 枫叶眼罩(配饰):枫叶镇木匠铺 点心食盒(配饰):华溪村客栈 解牛刀(配饰):金华镇金华餐馆 健步飞(配饰):烂柯棋社忘忧阁 点红朱(配饰):龙游镇木匠铺 松鹤临(配饰):万松书院毓秀阁 布衣身(衣服):织锦园百家布行 骄阳影(发型):织锦园绣纺 棉不弃(配饰):织锦园绣纺 登仙丹(配饰):瀛洲回春堂
以上就是3DM小编整理带来的华夏千秋金币 兑换的服装有哪些,地图服装获取攻略,更多相关游戏攻略 ,请关注网!**
Stable Diffusion 2.1 Demo
最新体验版 Stable Diffusion 2.1
101 查看详情
以上就是华夏千秋地图服装获取攻略的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/906027.html
赞 (0)
打赏
微信扫一扫
支付宝扫一扫
0xc0000005怎么解决,解决方法
下一篇
2025年11月28日 23:13:05
相关推荐
应通过 HTTP 服务运行打包后的 HTML5 页面,而非双击打开:一、Webpack 配 webpack-dev-server 启动本地服务;二、Gulp 配 BrowserSync 提供实时重载;三、用 Python/Node.js 轻量 HTTP 工具托管 dist 目录;四、仅当必须双击运行…
在HTML5中实现黑体及加粗需用CSS的font-family和font-weight:一、font-family按优先级列“SimHei”,“Microsoft YaHei”,“Heiti SC”,sans-serif;二、font-weight用700或bold;三、组合声明并注意继承;四、可用…
可通过CSS的font-family、font-weight、font-size等属性精确控制HTML5文字外观:font-family设字体栈并兜底通用族;font-weight用数值或关键字设字重;font-size支持绝对/相对单位;font简写需固定顺序且必含font-size和font-f…
要在HTML5页面中正确显示文字,需用语义化标签(如p、span)并配合CSS设置字体、颜色、尺寸等样式,确保可见性、可访问性及响应式适配。 如果您希望在HTML5页面中正确显示文字,需使用语义化标签并配合CSS控制样式。以下是实现文字显示的具体方法: 一、使用p标签显示段落文字 p标签用于定义段落…
需移除分屏类名、重置CSS样式、禁用Grid/Flex规则、撤销JS动态逻辑、调整viewport及媒体查询,并强制重绘以恢复单屏滚动。 如果网页通过HTML5技术实现了分屏布局,例如使用CSS Grid、Flexbox或JavaScript动态分割视口,导致内容被强制显示在多个并列区域中,用户希望…
掌握HTML解析需五步:一、识别%ignore_a_1%根元素及head/body骨架;二、依缩进分析嵌套层级;三、辨识header、nav等语义标签功能;四、解析class、href等属性与文本关联;五、用浏览器开发者工具验证DOM结构。 如果您看到一段HTML代码但无法快速识别其组织方式和各标签…
可通过focus()方法使文本框自动获焦,具体包括:一、用ID获取元素后调用focus();二、用querySelector按选择器聚焦;三、用setTimeout延迟聚焦防渲染未完成;四、结合scrollIntoView确保可见;五、表单验证失败时聚焦首个错误字段。 如果您希望在HTML5页面中通…
HTML5网页发布有两种常用方式:一是通过FTP上传至托管服务器,需配置FTP客户端并上传文件至网站根目录;二是使用GitHub Pages免费托管,将项目推送到用户名.github.io仓库。发布后须验证资源路径正确性,确保CSS、JS和图片等无404错误。 如果您已完成 HTML5 网页开发,希…
HTML5提供五种Flash动画替代方案:一、Canvas逐帧重绘;二、SVG结合CSS/JS动画;三、WebGL框架(如PixiJS/Three.js);四、视频标签嵌入预渲染内容;五、Lottie Web播放AE导出的JSON动画。 如果您正在寻找将网页中已有的Flash动画替换为现代、兼容性更…
可在手机上用Dcoder、Acode+Live Server、JSBox或Codeanywhere实现HTML5编写与实时预览:Dcoder内置WebView运行;Acode需装Live Server插件并用浏览器访问本地服务;JSBox通过JavaScript脚本内建WebView渲染;Codea…
可通过CSS覆盖浏览器默认样式美化HTML按钮:一、调整边框、背景色与文字色;二、添加圆角和阴影增强层次;三、统一字体、尺寸与内边距;四、用:hover/:active实现悬停点击动效;五、嵌入图标并精细对齐。 如果您希望改变网页中HTML按钮的默认外观,使其更符合页面整体设计风格,则需要通过CSS…
Sketch无法直接导出HTML,需借助插件或工具:一、Anima插件自动生成响应式HTML/CSS;二、Zeplin提取样式参数辅助手写HTML;三、Sketch2React生成JSX再渲染为HTML字符串;四、Avocode一键导出静态HTML页面。 如果您使用 Sketch 设计界面后需要将设…
HTML5游戏修改需掌握五种技术路径:一、分析资源文件结构定位主逻辑脚本;二、动态调试劫持变量;三、篡改localStorage或IndexedDB数据;四、重写关键函数逻辑;五、拦截并伪造网络请求响应。 如果您尝试修改或绕过HTML5游戏的限制,例如跳过验证、获取未解锁内容或调整游戏逻辑,则需要理…
应启用VS脚本调试、使用浏览器F12工具、配置Chrome协同调试,并检查HTML5语法与API兼容性。具体包括:启用JavaScript调试选项、设断点、用F12查看控制台错误、判断API存在性、确保DOCTYPE声明及module路径正确。 如果您在 Visual Studio 中开发 HTML…
可在%ignore_a_1%中用前端库直接生成Excel:一、SheetJS适合快速导出JSON/HTML为.xlsx;二、exceljs支持样式和公式但体积大;三、HTML表格转.xls为轻量兼容方案。 如果您希望在浏览器中直接生成并导出 Excel 文件,而无需后端参与,则可以借助轻量级前端 J…
HTML5页面跳转到本页特定位置可通过四种方法:一、HTML锚点链接(href=”https://www.php.cn/link/16a8dbbbdbb3056273cbf39955c6f7b0″);二、JavaScript scrollIntoView();三、JavaSc…
HTML页面添加错误提示有五种方法:一、用try-catch捕获运行时错误并显示于DOM;二、用window.onerror监听未捕获脚本错误;三、用HTML5 validity API实现表单原生验证提示;四、重写console.error同步输出日志与界面提示;五、通过CustomEvent抛出…
需将HTML解析为JS对象树,可用五种方法:一、DOMParser安全解析字符串;二、递归遍历现有DOM元素;三、innerHTML+临时div兼容旧环境;四、XMLSerializer反向序列化(限XML兼容HTML);五、htmlparser2流式解析大型HTML。 如果您拥有HTML字符串或D…
使用开发者工具精准定位HTML代码片段有五种方法:一、元素面板搜索;二、Sources面板全局源码搜索;三、控制台执行DOM查询语句;四、Search across all sources快捷入口;五、DOM Breakpoints定位动态插入内容。 如果您在网页中需要快速定位特定的HTML代码片段…