WordPress 支持中文用户名注册_WordPress教程

WordPress 支持中文用户名注册_WordPress教程

将以下php代码复制到当前主题目录下的functions.php中,即可让WordPress支持使用中文用户名注册和登录: function MBT_sanitize_user ($username, $raw_username, $strict) { $username = wp_strip_all_tags( $raw_username ); $username = re...

将以下php代码复制到当前主题目录下的functions.php中,即可让WordPress支持使用中文用户名注册和登录:

function MBT_sanitize_user ($username, $raw_username, $strict) {
 $username = wp_strip_all_tags( $raw_username );
 $username = remove_accents( $username );
 $username = preg_replace( '|%([a-fA-F0-9][a-fA-F0-9])|', '', $username );
 $username = preg_replace( '/&.+?;/', '', $username ); 
 if ($strict) {
 $username = preg_replace ('|[^a-z\p{Han}0-9 _.\-@]|iu', '', $username);
 }
 $username = trim( $username );
 $username = preg_replace( '|\s+|', ' ', $username );
 return $username;
}
add_filter ('sanitize_user', 'MBT_sanitize_user', 10, 3);

使用此方法仅允许最多5个中文汉字,那要注册6个及以上的中文用户名怎么办?

还需要修改数据库里面两个字段的长度,分别修改user_login\user_nicename,注意两个要同时修改,参考display_name改为250即可。

可使用代码修改长度,可以将以下代码加入到主题启用后的钩子里,例如after_switch_theme,通过add_action来添加。

$update1="ALTER TABLE `".$wpdb->users."` modify column user_login varchar(250), modify column user_nicename varchar(250)";
$wpdb->query($update1);

目前也没搞清为啥wordpress会限制中文数量为5个,尽管数据库中相关字符长度明明是VARCHAR60,而在UTF8下一个汉字应该是3个字符,可仍然不行,只能按上述的方法改为250或更大。

原文链接:https://www.dqzy.cn/2025/05/06/521.html,转载请注明出处。 1、本站所有源码资源(包括源代码、软件、学习资料等)仅供研究学习以及参考等合法使用,请勿用于商业用途以及违法使用。如本站不慎侵犯您的版权请联系我们,我们将及时处理,并撤下相关内容! 2、访问本站的用户必须明白,本站对所提供下载的软件和程序代码不拥有任何权利,其版权归该软件和程序代码的合法拥有者所有,请用户在下载使用前必须详细阅读并遵守软件作者的“使用许可协议”,本站仅仅是一个学习交流的平台。 3、如下载的压缩包需要解压密码,若无特殊说明,那么文件的解压密码则为:www.dqzy.cn。 4、点启资源网是一个免费且专业分享网站源码、图片素材、特效代码、教程文章、站长工具的平台。我们努力给站长提供好的资源!
0

评论0

请先
显示验证码
没有账号?注册  忘记密码?