/**
* 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');
如何在移动开发中选择 Java 框架_创想鸟
- 创想鸟首页
- 用户投稿
如何在移动开发中选择 Java 框架
程序猿
•
•
用户投稿 •
阅读 1
在移动开发中选择 java 框架时,需要考虑适用性、性能、可扩展性、开发效率、社区支持等标准。流行的 java 框架包括 android jetpack(适用于 android 平台)、rxjava(处理异步操作)、dagger(简化对象实例化)。根据这些标准选择合适的 java 框架对于构建高效、可维护的移动应用程序至关重要。

在移动开发中选择 Java 框架
在移动开发领域,Java框架以其稳定性、可扩展性和代码重用性而著称。选择合适的Java框架对于构建高效、可维护的应用程序至关重要。本文将介绍如何在移动开发中选择 Java 框架,并提供一些实战案例。
选择标准
立即学习“Java免费学习笔记(深入)”;
选择 Java 框架时,需要考虑以下标准:
适用性:框架是否符合您的应用程序要求和目标平台。性能:框架在特定平台上的性能表现如何。可扩展性:框架是否可以随着应用程序的增长而轻松扩展。开发效率:框架提供的工具和特性,影响开发效率。社区支持:框架的活跃度和社区支持质量。
流行的 Java 框架
以下是移动开发中一些流行的 Java 框架:
Android Jetpack:谷歌官方推荐的框架集合,提供广泛的组件和库。RxJava:反应式编程框架,简化异步操作的管理。Dagger:依赖注入框架,简化对象实例化和管理。Retrofit:HTTP客户端框架,用于与REST API交互。Glide:图片加载和缓存库,优化了图像管理。
实战案例
如知AI笔记
如知笔记——支持markdown的在线笔记,支持ai智能写作、AI搜索,支持DeepseekR1满血大模型
27 查看详情
选择 Android Jetpack
如果您正在开发适用于 Android 平台的应用程序,Android Jetpack 是一个不错的选择。它提供了一系列组件,包括UI、导航、生命周期管理等,有助于加快开发过程并提高应用程序质量。
选择 RxJava
如果您需要处理异步操作,例如网络请求或事件处理,RxJava 是一个很好的选择。它提供了一个响应式编程模型,使您可以异步管理多个操作,同时保持代码可读性和可维护性。
选择 Dagger
如果您ต้องการ简化对象实例化和管理,Dagger 是一个有用的框架。它使用依赖注入来根据应用程序的配置自动创建和提供对象,减少代码重复和复杂性。
结论
选择合适的 Java 框架对于构建 başarılı的移动应用程序至关重要。通过考虑选择标准和研究可用的框架,您可以找到最适合您的具体项目的框架。本文中讨论的实战案例提供了如何在移动开发中应用这些框架的示例。
以上就是如何在移动开发中选择 Java 框架的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/553805.html
赞 (0)
打赏
微信扫一扫
支付宝扫一扫
iPhone电池突然掉落如何修复
上一篇
2025年11月9日 21:18:19
linux bash是什么?
下一篇
2025年11月9日 21:18:22
相关推荐
-
理解功能类优先 tailwind css 是一款功能类优先的 css 框架,用户可以通过组合功能类轻松构建设计。为了理解功能类优先,我们首先要区分语义类和功能类这两种 css 类名命名方式。 语义类 以前比较常见的 css 命名方式是根据页面中模块的功能来命名。例如: 立即学习“前端免费学习笔记(深…
-
在本文中,我们将探索 scss (sassy css),这是一个 css 预处理器,它通过允许变量、嵌套规则、mixins、函数等来扩展 css 的功能。 scss 使 css 的编写和维护变得更加容易,尤其是对于大型项目。 1.什么是scss? scss 是 sass(syntropically …
-
CSS3 选择器优化技巧可提升网页性能:减少选择器层级,提高浏览器解析效率。避免通配符选择器,减少性能损耗。优先使用 ID 选择器,快速定位目标元素。用类选择器代替标签选择器,精确匹配。使用属性选择器,增强匹配精度。巧用伪类和伪元素,提升性能。组合多个选择器,简化代码。利用 CSS 预处理器,增强代…
-
开始新事物的兴奋感永远不会消失,尤其是当它涉及到像 HNG 实习这样的强化项目时 [https://hng.tech/internship 和 https://hng.tech/premium]。这就像再次参加编码训练营,但这一次有令人兴奋的机会来突破我的极限并加快学习速度。 HNG 实习中真正令我…
-
CSS 代码规范对于保持一致性、可读性和可维护性至关重要,常见的规范包括:命名约定:使用小写字母和短划线,命名特定且描述性。缩进和对齐:按特定规则缩进、对齐选择器、声明和值。属性和值顺序:遵循特定顺序排列属性和值。注释:解释复杂代码,并使用正确的语法。分号:每个声明后添加分号。大括号:左大括号前换行…
-
需用JavaScript加载解析XML:一、XMLHttpRequest异步获取并解析;二、DOMParser解析内联XML字符串;三、fetch API配合DOMParser处理;四、XMLSerializer序列化调试;五、getElementsByTagNameNS处理命名空间。 如果您希望在…
-
需更新DOCTYPE为,设置lang属性,用语义化元素替代div,升级表单输入类型,以audio/video替代Flash嵌入多媒体。 如果您正在维护一个传统HTML网页,希望将其升级为符合现代标准的HTML5格式,则需要对文档结构、元素语义、语法规范及媒体支持等方面进行系统性调整。以下是将HTML…
-
可通过五种JavaScript方法实现网页中多数值实时相加:一、内联事件+ID获取;二、表单submit+preventDefault;三、input事件实时计算;四、ES6箭头函数与解构;五、data属性批量处理多组。 如果您在网页中需要实现两个或多个数值的相加运算,并将结果实时显示,可以通过嵌入…
-
HTML5表格需用定义结构,含等标签,支持标题、rowspan/colspan合并、CSS边框及语义分组。 如果您希望在HTML5页面中创建结构化数据展示区域,则需要使用标准的表格标签来构建行列布局。以下是添加表格的具体步骤: 一、基础表格结构定义 HTML5中表格必须以 标签为容器,内部使用定义行…
-
需将HTML特殊字符转义为实体以实现代码原样显示,常用方法包括:手动实体替换、pre/code标签配合转义、JavaScript动态转义、CSS white-space控制、highlight.js语法高亮。 如果您希望在网页中直接显示HTML代码本身,而不是让浏览器解析并渲染这些代码,则需要将HT…
-
实现HTML元素点击响应有五种方法:一、内联onclick属性;二、JavaScript获取元素后用addEventListener绑定;三、事件委托绑定到父容器;四、自定义函数配合onclick调用;五、用preventDefault和stopPropagation控制默认行为与冒泡。 如果您希望…
-
HTML代码质量优化需遵循五项规范:一、正确使用语义化标签提升可访问性与SEO;二、属性值强制双引号并显式书写布尔属性;三、精简嵌套层级,统一双空格缩进;四、class/id采用kebab-case命名,强调语义与唯一性;五、必须声明DOCTYPE、lang和UTF-8编码。 如果您在编写HTML代…
-
Flexbox通过display: flex、flex-direction: row、justify-content、flex-wrap: nowrap及子项flex属性实现元素横向排列。 如果您希望在HTML页面中实现元素的横向排列,Flexbox提供了一种简洁且强大的布局方式。以下是实现横向布局…
-
C语言动态生成HTML文件有五种方法:一、用fprintf逐行写入;二、构建缓冲区后fwrite一次性写入;三、用宏简化标签输出;四、从模板文件加载并替换变量;五、用结构体组织元素并序列化。 如果您希望使用C语言程序动态生成HTML格式的文件,则需要通过标准文件I/O操作将符合HTML语法的文本内容…
-
HTML表格通过table、tr、td构建基础结构,用th和thead/tbody实现语义化表头,CSS控制边框、尺寸、对齐及类名复用样式。 如果您需要在网页中展示结构化数据,HTML表格是实现这一目标的基础方式。以下是创建HTML数据表格并设置样式的具体步骤: 一、使用table、tr、td标签构…
-
可通过margin、padding、空元素、br标签或CSS类五种方式控制HTML元素间距:margin设外边距,padding设内边距,空元素设高度,br强制换行,CSS类统一管理。 如果您希望在HTML元素之间创建空白距离,可以通过多种方式控制元素间的垂直或水平间距。以下是实现此效果的具体方法:…
-
使用标签组合并转义特殊字符可安全显示HTML代码;通过JavaScript动态设置textContent能防止解析执行;引入Highlight.js等高亮库还可实现语法着色与行号功能,提升代码可读性。 如果您在编写HTML文件时希望其中的代码片段能够被正确显示而非被浏览器解析执行,则需要采取特定方法…
-
掌握HTML需系统学习:一、理解基本结构,如doctype、html、head、body;二、反向学习现成网页;三、用在线平台实时练习;四、构建最小可运行项目;五、用开发者工具排查错误。 如果您希望掌握HTML代码编写能力,但对基础语法和实践方法感到困惑,则可能是由于缺乏系统的学习路径和有效的练习方…
-
校正HTML背景图需配置background-position控制位置、background-size调整尺寸、background复合属性整合设置、background-origin指定定位基准,并检查盒模型与父容器影响。 如果您在HTML中设置了背景图,但图像显示位置偏移或尺寸拉伸变形,则可能是…
-
本教程旨在解决网页开发中常见的搜索栏输入框与提交按钮的对齐难题。文章将深入分析导致元素错位的常见CSS属性,并提供两种现代且高效的解决方案:Flexbox布局和`display: inline-block`。通过优化HTML结构和应用精确的CSS规则,确保搜索栏在不同场景下都能实现完美的视觉对齐,同…