wordpress - 未定义的索引:第一个基本示例中的 name_of_your_nonce_field
问题描述
当我使用 wp nonce 字段的第一步时,我尝试了https://developer.wordpress.org/reference/functions/wp_nonce_field/中的“基本示例”
它在那里说:“省略所有参数的最简单实现”
在我的 htdocs/wp-content/plugins/abcd-plugin/abcd-plugin.php 的底部我写道:
function hi_in_wp_head() {
?>
<form name="f1">
<input name="i1" value="hi_in_wp_head">
<input type="submit" name="s1">
<?php wp_nonce_field('name_of_your_action', 'name_of_your_nonce_field'); ?>
</form>
<?php
if(wp_verify_nonce($_REQUEST['name_of_your_nonce_field'], 'name_of_your_action')){
// Nonce is matched and valid. do whatever you want now.
} else {
// Invalid nonce. you can throw an error here.
die("ups 19-02-28_17-09");
}
}
function hi_in_footer() {
echo '<h1>hi_in_footer</h1>';
}
完整来源: https ://gist.github.com/f9f0a853f0a71c5a2055b88802a1010c
这在网络浏览器中看起来像这样:
<meta name="generator" content="WordPress 5.0.3" />
<form name="f1">
<input name="i1" value="hi_in_wp_head">
<input type="submit" name="s1">
<input type="hidden" id="name_of_your_nonce_field" name="name_of_your_nonce_field" value="5a82357118" /><input type="hidden" name="_wp_http_referer" value="/wordpress/alecaddd-plugin.php" /> </form>
<br />
<b>Notice</b>: Undefined index: name_of_your_nonce_field in <b>G:\Bitnami\wordpress-5.0.3-2\apps\wordpress\htdocs\wp-content\plugins\alecaddd-plugin\alecaddd-plugin.php</b> on line <b>89</b><br />
ups 19-02-28_17-09
未定义的索引:第一个基本示例中的 name_of_your_nonce_field
我不知道错误来自哪里。我能做什么?
解决方案
如错误消息所述,$_REQUEST['name_of_your_nonce_field']
未设置。在使用它之前,您需要确保它已设置:
function hi_in_wp_head() {
?>
<form name="f1">
<input name="i1" value="hi_in_wp_head">
<input type="submit" name="s1">
<?php wp_nonce_field('name_of_your_action', 'name_of_your_nonce_field'); ?>
</form>
<?php
if(isset($_REQUEST['name_of_your_nonce_field']) {
if(wp_verify_nonce($_REQUEST['name_of_your_nonce_field'], 'name_of_your_action')){
// Nonce is matched and valid. do whatever you want now.
} else {
// Invalid nonce. you can throw an error here.
die("ups 19-02-28_17-09");
}
}
}
$_REQUEST['name_of_your_nonce_field']
将在您的表单提交后设置。这就是您需要额外检查的原因。
推荐阅读
- python-3.x - 为什么 lambda, list comprehensing 会这样?
- angular - 指令内的超时函数未调用
- mysql - 如何从不同 AWS 区域的数据库表(AWS RDS Mysql)中读取数据并根据结果更新其中一个区域的数据库?
- dataweave - 使用 DataWeave 组合两个有效负载
- c# - 按 Key 的第二个元素排序字典
- c++ - 打印/记录 c++ stings 函数调用的缩进 wrt 深度
- javascript - 如何在网络应用程序中打开具有多个站点的谷歌地图?
- openapi - 在 OpenAPI 3.0 中,我应该为具有指定格式的字符串指定 maxLength 吗?
- arrays - 如果结果在 vue 中相等,则检查 2 个数组
- python - 在 PuLP 中添加逻辑约束