75 lines
3.6 KiB
PHP
75 lines
3.6 KiB
PHP
<?php
|
|
|
|
/* 加强评论拦截功能 */
|
|
Typecho_Plugin::factory('Widget_Feedback')->comment = array('Intercept', 'message');
|
|
class Intercept
|
|
{
|
|
public static function message($comment)
|
|
{
|
|
/* 用户输入内容画图模式 */
|
|
if (preg_match('/\{!\{(.*)\}!\}/', $comment['text'], $matches)) {
|
|
/* 如果判断是否有双引号,如果有双引号,则禁止评论 */
|
|
if (strpos($matches[1], '"') !== false || _checkXSS($matches[1])) {
|
|
$comment['status'] = 'waiting';
|
|
}
|
|
/* 普通评论 */
|
|
} else {
|
|
/* 判断用户输入是否大于字符 */
|
|
if (Helper::options()->JTextLimit && strlen($comment['text']) > Helper::options()->JTextLimit) {
|
|
$comment['status'] = 'waiting';
|
|
} else {
|
|
/* 判断评论内容是否包含敏感词 */
|
|
if (Helper::options()->JSensitiveWords) {
|
|
if (_checkSensitiveWords(Helper::options()->JSensitiveWords, $comment['text'])) {
|
|
$comment['status'] = 'waiting';
|
|
}
|
|
}
|
|
/* 判断评论是否至少包含一个中文 */
|
|
if (Helper::options()->JLimitOneChinese === "on") {
|
|
if (preg_match("/[\x{4e00}-\x{9fa5}]/u", $comment['text']) == 0) {
|
|
$comment['status'] = 'waiting';
|
|
}
|
|
}
|
|
}
|
|
}
|
|
Typecho_Cookie::delete('__typecho_remember_text');
|
|
return $comment;
|
|
}
|
|
}
|
|
|
|
/* 加强后台编辑器功能 */
|
|
if (Helper::options()->JEditor !== 'off') {
|
|
Typecho_Plugin::factory('admin/write-post.php')->richEditor = array('Editor', 'Edit');
|
|
Typecho_Plugin::factory('admin/write-page.php')->richEditor = array('Editor', 'Edit');
|
|
}
|
|
|
|
class Editor
|
|
{
|
|
public static function Edit()
|
|
{
|
|
?>
|
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/aplayer@1.10.1/dist/APlayer.min.css">
|
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/prismjs@1.23.0/themes/prism-tomorrow.min.css">
|
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/font-awesome@4.7.0/css/font-awesome.min.css">
|
|
<link rel="stylesheet" href="<?php Helper::options()->themeUrl('typecho/write/css/joe.write.min.css?v=20210506') ?>">
|
|
<script>
|
|
window.JoeConfig = {
|
|
uploadAPI: '<?php Helper::security()->index('/action/upload'); ?>',
|
|
emojiAPI: '<?php Helper::options()->themeUrl('typecho/write/json/emoji.json') ?>',
|
|
expressionAPI: '<?php Helper::options()->themeUrl('typecho/write/json/expression.json') ?>',
|
|
characterAPI: '<?php Helper::options()->themeUrl('typecho/write/json/character.json') ?>',
|
|
playerAPI: '<?php Helper::options()->JCustomPlayer ? Helper::options()->JCustomPlayer() : Helper::options()->themeUrl('library/player.php?url=') ?>',
|
|
autoSave: <?php Helper::options()->autoSave(); ?>,
|
|
themeURL: '<?php Helper::options()->themeUrl(); ?>',
|
|
canPreview: false
|
|
}
|
|
</script>
|
|
<script src="https://cdn.jsdelivr.net/npm/aplayer@1.10.1/dist/APlayer.min.js"></script>
|
|
<script src="https://cdn.jsdelivr.net/npm/typecho-joe-next@6.2.4/plugin/prism/prism.min.js"></script>
|
|
<script src="<?php Helper::options()->themeUrl('typecho/write/js/joe.parse.min.js') ?>"></script>
|
|
<script src="<?php Helper::options()->themeUrl('typecho/write/js/joe.write.chunk.js?v=20210506') ?>"></script>
|
|
<script src="<?php Helper::options()->themeUrl('assets/js/joe.short.min.js?v=20210506') ?>"></script>
|
|
<?php
|
|
}
|
|
}
|