增加一个随机阅读的独立页面
This commit is contained in:
浪子 2025-08-02 14:29:25 +08:00
parent d268bd10bb
commit 0017693c81
2 changed files with 45 additions and 1 deletions

View File

@ -65,4 +65,5 @@
- 1.2.2
- 增加侧边栏显示的全局开关
- 修复代码块中的短代码解析问题
- 修复代码块中的短代码解析问题
- 新增一个随机文章阅读的独立页面

43
page-random.php Normal file
View File

@ -0,0 +1,43 @@
<?php
/**
* 随机阅读
*
* @package custom
*/
if (!defined('__TYPECHO_ROOT_DIR__')) exit;
$db = Typecho_Db::get();
// 统计符合条件的文章总数
$countSql = $db->select('COUNT(*) AS count')
->from('table.contents')
->where('status = ?', 'publish')
->where('type = ?', 'post')
->where('created <= ?', time());
$countResult = $db->fetchRow($countSql);
$total = $countResult['count'];
if ($total > 0) {
// 随机选择一个偏移量
$offset = mt_rand(0, $total - 1);
// 根据偏移量获取一篇文章
$sql = $db->select()
->from('table.contents')
->where('status = ?', 'publish')
->where('type = ?', 'post')
->where('created <= ?', time())
->limit(1)
->offset($offset);
$result = $db->fetchRow($sql);
if (!empty($result)) {
$target = Typecho_Widget::widget('Widget_Abstract_Contents')->filter($result);
$this->response->redirect($target['permalink'], 307);
}
}
// 如果没有找到文章,重定向到首页
$this->response->redirect($this->options->siteUrl, 307);
?>