Php 数据未插入WordPress数据库
我正在使用下面的代码在我的WordPress数据库中插入数据。这段代码工作不正常,当我插入数据时,它显示相同的页面,并且数据没有插入到数据库中Php 数据未插入WordPress数据库,php,wordpress,sql-insert,Php,Wordpress,Sql Insert,我正在使用下面的代码在我的WordPress数据库中插入数据。这段代码工作不正常,当我插入数据时,它显示相同的页面,并且数据没有插入到数据库中 <?php get_header(); ?> <div class="content"> <form> Job Title: <input type="text" name="jtitle"><br><br> Job Link: <inp
<?php get_header(); ?>
<div class="content">
<form>
Job Title: <input type="text" name="jtitle"><br><br>
Job Link: <input type="text" name="jlink"><br><br>
Job Last date: <input type="text" name="jld"><br><br>
<input type="submit" value="Add Job" name="insert"><br><br>
</form>
<?php
if (isset($_POST['insert'])) {
$jt=$_POST['jtitle'];
$jl=$_POST['jlink'];
$jld=$_POST['jld'];
global $wpdb;
$sql=$wpdb->insert("wp_job",array("jtitle"=>$jt,"jlink"=>$jl,"jld"=>$jld));
if ($sql==true) {
echo "<script>alert('New Job Added')</script>";
}
else {
echo "<script>alert('New Job Not Added!')</script>";
}
}
?>
</div><!-- .content /-->
职位名称:
作业链接:
作业最后日期:
您正在使用默认的HTTPGET方法而不是POST方法提交表单数据。由于HTML表单标记没有指定提交方法,因此它默认为GENT not POST
将HTML中的表单标记更改为,或者在PHP中将$\u POST值更改为$\u GET
如果需要的话,这里有更多的HTML5表单文档
PS:您不需要检查变量$\u POST['insert']是否设置为提交。您只需执行isset($\u POST)即可查看是否已提交任何表单数据
祝你好运 您需要在表单标签中添加值为“Post”的“action”属性
<div class="content">
<?php
if (isset($_POST['insert'])) {
global $wpdb;
$wp_job = $wp_prefix.'job';
$jt = $_POST['jtitle'];
$jl = $_POST['jlink'];
$jld = $_POST['jld'];
$sql = $wpdb->insert( $wp_job , array( "jtitle"=>$jt, "jlink"=>$jl, "jld"=>$jld ) );
if ($sql==true) {
echo "<script>alert('New Job Added')</script>";
}
else {
echo "<script>alert('New Job Not Added!')</script>";
}
}
?>
<form method="post" action="">
Job Title: <input type="text" name="jtitle"><br><br>
Job Link: <input type="text" name="jlink"><br><br>
Job Last date: <input type="text" name="jld"><br><br>
<input type="submit" value="Add Job" name="insert"><br><br>
</form>
</div><!-- .content /-->
您提交表单时没有指定方法属性,您应该定义method=“post”以通过isset($\u post['insert'])获取数据,或者您也可以使用$\u请求获取所有数据,但我建议您定义操作和方法属性
这里还可以看到默认的表单方法是GET
祝你好运
谢谢如果你在WordPress工作,你需要以WordPress的方式处理POST请求
From:
<form>
To:
<form action="<?php echo esc_url( admin_url('admin-post.php') ); ?>"
method="post">
/* add this line somewhere in between the <form> tag. */
<input type="hidden" name="action" value="job_form">
/* Open up functions.php of your current theme and add these lines in: */
function addNewJob() {
/**
* At this point, $_GET/$_POST variable are available
* eg: $jld = $_POST['jld'];
*
* We can do our normal processing here
*/
}
add_action( 'admin_post_nopriv_job_form', 'addNewJob` );
add_action( 'admin_post_job_form', 'addNewJob` );
来自:
致:
您需要在表单标记中添加值为“Post”的“action”属性。