屏蔽WordPress 注册/重置密码/更改密码邮件通知管理员
WordPress网站用户注册账户、重置更改密码时,通常会自动发送邮件通知。有时候管理员希望禁止这些邮件通知以避免用户受到不必要垃圾邮件或保护用户隐私。本篇介绍如何使用代码禁止WordPress在注册新用户、重置密码和更改密码时发送邮件通知。
如果不需要邮件通知,可以将下面代码添加到主题函数模板 functions.php中:
// 禁止用户注册时发送邮件给管理员
add_filter( 'wp_new_user_notification_email_admin', '__return_false' );
// 禁止用户重置修改密码时发送邮件给管理员
add_filter( 'wp_password_change_notification_email', '__return_false' );
// 禁止用户注册时发送邮件给注册者
add_filter( 'wp_new_user_notification_email', '__return_false' );
// 禁止邮箱地址改变时发送邮件给注册者
add_filter( 'send_email_change_email', '__return_false' );
// 禁止更改密码时发送邮件给注册者
add_filter( 'send_password_change_email', '__return_false' );
以下代码是用来禁止WordPress在用户注册、重置密码、更改密码时发送邮件通知的。具体来说,它包括了五个过滤器,每个过滤器都有不同的功能。
wp_new_user_notification_email_admin
这个过滤器是用来禁止用户注册时向管理员发送邮件通知的。默认情况下,当有新用户注册时,WordPress会向网站管理员发送一封邮件通知,告知管理员有新用户注册了。使用这个过滤器后,当有新用户注册时,管理员将不会收到任何邮件通知。
// 禁止用户注册时发送邮件给管理员
add_filter( 'wp_new_user_notification_email_admin', '__return_false' );
wp_password_change_notification_email
这个过滤器是用来禁止重置密码时向管理员发送邮件通知的。默认情况当用户重置密码时,WordPress会向管理员发送一封邮件告知管理员有用户重置了密码。使用这个过滤器后,重置密码管理员将再收到邮件通知。
// 禁止重置密码时发送邮件给管理员
add_filter( 'wp_password_change_notification_email', '__return_false' );
wp_new_user_notification_email
这个过滤器是用来禁止用户注册时向注册者发送邮件通知的。默认情况下,当用户注册新账户时,WordPress会向注册者发送一封邮件通知,告知用户账户已经创建成功。使用这个过滤器后,当用户注册新账户时,注册者将不会收到任何邮件通知。
// 禁止用户注册时发送邮件给注册者
add_filter( 'wp_new_user_notification_email', '__return_false' );
send_email_change_email
这个过滤器是用来禁止邮箱地址改变时向注册者发送邮件通知的。默认情况下,当用户更改其注册邮箱的时候,WordPress会向新邮箱地址发送一封邮件通知,告知用户邮箱地址已经更改成功。使用这个过滤器后,当用户更改其注册邮箱时,新邮箱地址将不会收到任何邮件通知。
// 禁止邮箱地址改变时发送禁止给注册者
add_filter( 'send_email_change_email', '__return_false' );
send_password_change_email
这个过滤器是用来禁止更改密码时向注册者发送邮件通知的。默认情况下,当用户更改其密码时,WordPress会向用户发送一封邮件通知,告知用户密码已经更改成功。使用这个过滤器后,当用户更改密码时,用户将不会收到任何邮件通知。
// 禁止更改密码时发送邮件给注册者
add_filter( 'send_password_change_email', '__return_false' );
需要注意的是,禁用这些邮件通知可能会影响网站的功能。因此,在使用这段代码之前,请确保您了解其影响,并在进行修改之前备份您的网站数据。
-------------------------------------------------------
WordPress 搜索添加人机验证
WordPress搜索功能很占内存,特别是机器扫描到了我们的搜索页面,可能直接导致内存爆满数据库进程终止,影响网站的正常运行。可有效防止恶意扫描导致内存崩溃,防止恶意请求关键字生成结果页面。
温馨提醒:操作之前请务必做好网站的备份工作,防范于未然,避免产生不必要的麻烦!
操作很简单,将下面代码添加到主题的 functions.php 里即可。
function esc_search_captcha( $query, $error = true ) {
if ( is_search() && !is_admin() ) {
if ( ! isset( $_COOKIE['esc_search_captcha'] ) ) {
$query->is_search = false;
$query->query_vars['s'] = false;
$query->query['s'] = false;
if ( $error == true ){
//$query->is_404 = true;
if ( isset( $_POST['result'] ) ) {
if ( $_POST['result'] == $_COOKIE['result'] ) {
$_COOKIE['esc_search_captcha'] = 1;
setcookie('esc_search_captcha',1,0,'/');
echo '<script>location.reload();</script>';
}
}
$num1 = rand(1,50);
$num2 = rand(1,50);
$result = $num1+$num2;
$_COOKIE['result'] = $result;
setcookie('result',urldecode($result),0,'/');
?>
<html>
<head>
<meta charset="UTF-8">
<title>人机验证</title>
<style>
body{color: #333;text-align: center;font-size: 16px;}
.erphp-search-captcha{margin: 50px auto 15px;max-width: 250px;width: 100%;padding: 40px 20px;border: 1px solid #ddd;text-align: center;border-radius: 5px;}
.erphp-search-captcha form{margin: 0}
.erphp-search-captcha input{border: none;border-bottom: 1px solid #666;width: 50px;text-align: center;font-size: 16px;}
.erphp-search-captcha input:focus{outline: none;}
.erphp-search-captcha button{border: none;background: transparent;color: #ff5f33;cursor: pointer;}
.erphp-search-captcha button:focus{outline: none;}
a{color: #000;font-size: 12px;}
</style>
</head>
<body>
<div class="erphp-search-captcha">
<form action="" method="post"><?php echo $num1;?> + <?php echo $num2;?> = <input type="text" name="result" required /> <button type="submit">验证</button></form>
</div>
<a href="<?php echo home_url();?>">返回首页</a>
</body>
</html>
<?php
exit;
}
}
}
}
add_action( 'parse_query', 'esc_search_captcha' );
添加之后,搜索就需输入验证码,防止机器人,验证过一次后,只有清空浏览器cookie才会需要再次验证。
文章末尾固定信息
我的微信
微信号已复制
我的微信
微信扫一扫


评论