gpt4 book ai didi

php - 将表单数据发送到 WordPress 数据库表

转载 作者:行者123 更新时间:2023-12-04 02:58:44 24 4
gpt4 key购买 nike

我正在尝试构建一个插件,允许管理员添加有关特定包的数据(就像创建用户一样)。在前端,我将有一个表单,允许访问者使用管理员分配给该包的 ID 搜索特定包。

我使用 php 构建了系统并且它工作正常。现在我想把它变成一个 WordPress 插件,我发现很难将表单数据发送到激活插件时创建的 wpdb 表 (wp_demo)。

这是表格:

function registration_init(){
echo '<form action="demo.php" method="post" />';
echo "<h1>Britchi Tracking</h1>";
echo '<p>';
echo 'Costumers Name (required) <br/>';
echo '<input type="text" name="cname" placeholder="Emmanuel John"/>';
echo '</p>';
echo '<p>';
echo 'Tracking number (required) <br/>';
echo '<input type="text" name="ctracking" placeholder="EEX28PDS"/>';
echo '</p>';
echo '<p>';
echo 'Email (required) <br/>';
echo '<input type="email" name="cemail" placeholder="Email"/>';
echo '</p>';
echo '<p>';
echo 'Recived Port (required) <br/>';
echo '<input type="text" name="crport" placeholder="Brazil Port"/>';
echo '</p>';
echo '<p>';
echo 'Delivered Port (required) <br/>';
echo '<input type="text" name="cdport" placeholder="Lagos Port"/>';
echo '</p>';
echo '<p>';
echo 'Current Location (required) <br/>';
echo '<input type="text" name="clocation" placeholder="Abuja" />';
echo '</p>';
echo '<p>';
echo 'Destination (required) <br/>';
echo '<input type="text" name="cdestination" placeholder="Total filling Station, Abuja"/>';
echo '</p>';
echo '<p><input type="submit" name="cregistered" value="Register"></p>';
echo '</form>';
}

这是表单处理代码:

<?php

define('DB_NAME', 'wordpree2');
define('DB_USER', 'root');
define('DB_PASSWORD', 'chimezie12');
define('DB_HOST', 'localhost');

$link = mysql_connect(DB_HOST, DB_USER, DB_PASSWORD);

if (!$link) {
die('Could not connect: ' . mysql_error());
error_reporting(E_ALL);
ini_set('display_errors', 1);
}

$db_selected = mysql_selected_db(DB_NAME, $link);

if (!$db_select) {
die('Can\'t use ' . DB_NAME . ': ' . mysql_error());
}

$cname = $_POST['cname'];
$cemail = $_POST['cemail'];
$ctracking = $_POST['ctracking'];
$crport = $_POST['crport'];
$cdport = $_POST['cdport'];
$clocation = $_POST['clocation'];
$cdestination = $_POST['cdestination'];

$sql = "INSERT INTO `wp_demo` (cname, cemail, ctracking, erport, cdport, clocation, cdestination) VALUES ('$cname', '$cemail', '$ctracking', '$crport', '$cdport', '$clocation', '$cdestination')";

if (!mysql_query($sql)) {
die('ERROR: ' . mysql_error());
}

mysql_close();
?>

我知道这不是向 wpdb 表插入数据的正确方法,但我不知道该怎么做。

最佳答案

这只是一个如何以 Wordpress 方式在数据库中插入数据的简短示例:

<?php 
global $wpdb;
$wpdb->insert('wp_demo', [
'cname' => $_POST['cname'],
'cemail' => $_POST['cemail'],
'ctracking' => $_POST['ctracking']
], ['%s','%s', '%s']
);

有关完整引用,请参阅:https://codex.wordpress.org/Class_Reference/wpdb#INSERT_row

此外,不要忘记清理输入: https://codex.wordpress.org/Validating_Sanitizing_and_Escaping_User_Data

关于php - 将表单数据发送到 WordPress 数据库表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51341800/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com