Back to Blog

wp_nonce_fieldの使い方

WordPress

2024/06/05

在WordPress中,wp_nonce_field 函数用于生成一个一次性的安全密钥(nonce),并输出一个包含该密钥的隐藏表单字段。这个机制主要用于保护网站免受CSRF攻击(跨站请求伪造攻击)。Nonce是一种唯一的、只能使用一次的数字或字符串,WordPress通过它来验证用户提交的表单数据或URL请求确实来源于他们的网站,并且具有合法的用户意图。

当您创建一个表单并希望向WordPress网站提交数据时,通过使用wp_nonce_field函数可以确保最终用户或客户端在与服务器交互时的合法性和安全性。

这里有几个关键点需要理解:

・Nonce的创建:每个nonce都是独特的,并且通常依赖于用户会话、动作或其他因素。
・Nonce的验证:当接收到请求时,WordPress会检查和验证nonce是否有效。
・Nonce的寿命:Nonce有一个设定的生命周期,在这段时间内它们是有效的。过了这个时间窗口,nonce将会失效。

wp_nonce_field通常被用于WordPress开发中。下面是一个简单的例子:


<form method="post">
    <?php wp_nonce_field( 'アクションの名前', 'nonce フィールドの名前' ); ?>
</form>

这将输出类似以下的HTML:


<form method="post">
    <input type="hidden" id="フィールドの名前" name="フィールドの名前" value="生成された値">
    <input type="hidden" name="_wp_http_referer" value="/current-page-url/" />
</form>

_wp_http_referer 字段包含当前页面的URL。

提交表单时,您应在处理逻辑中调用 check_admin_referer 或 wp_verify_nonce 函数来验证nonce:


if ( isset( $_POST['nonce フィールドの名前'] ) && check_admin_referer( 'アクションの名前' ) ) {
    // 验证通过,处理表单数据
} else {
    // 验证失败,处理异常
}

在上述代码中,如果nonce校验成功,则可以继续处理表单提交的数据;如果失败,则可能是由于非法请求或者nonce已经过期无效。

Related Posts