Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/230.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 数据未插入WordPress数据库_Php_Wordpress_Sql Insert - Fatal编程技术网

Php 数据未插入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

我正在使用下面的代码在我的WordPress数据库中插入数据。这段代码工作不正常,当我插入数据时,它显示相同的页面,并且数据没有插入到数据库中

<?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”属性。