用PDO编写插入代码的最佳方法是什么?

时间:2018-06-22 16:30:17

标签: php mysql mysqli

我最近学习了面向对象编程PHP,并且尝试测试有关该知识的知识,所以我尝试自己编写一些查询...

(示例做法:插入新行,更新行并删除行)。

下面是我为自己编写的模板,以便将新行插入数据库

class Register
{   
    protected $notice = array();
    private $_db;
    public function __construct()
    {
        $this->_db = new Connection();
        $this->_db = $this->_db->dbConnect();
    }
    public function CheckUname($username,$email,$password,$groups,$level)
    {
        if(!empty($username)&&!empty($email)&&!empty($password)&&!empty($groups)&&!empty($level))
        {
            $chk1 = $this->_db->prepare("SELECT user_name FROM admins WHERE user_name = ?");
            $chk1->bindParam(1,$username);
            $chk1->execute();
            if($chk1->rowCount() == 1)
            {
                $notice['username_exists'] = "Try different username";
                return $this->notice;
            }else{
                $chk2 = $this->_db->prepare("SELECT email_address FROM admins WHERE email_address = ?");
                $chk2->bindParam(1,$email);
                $chk2->execute();
                if($chk2->rowCount() == 1)
                {
                    $notice['email_exists'] = "The email address that you have entered is already exists in database";
                    return $this->notice;
                }else{
                    $this->NewAdmin($username,$email,$password,$groups,$level);
                    $notice['success_message'] = "New admin was successfully added";
                    return $this->notice;
                }
            }
        }
    }
    public function NewAdmin($username,$email,$password,$groups,$level)
    {
        if(!empty($username)&&!empty($email)&&!empty($password)&&!empty($groups)&&!empty($level))
        {
            $reg = $this->_db->prepare("INSERT INTO admins (user_name, email_address, password_hash, group_admin, date_joined, admin_level) VALUES ( ?, ?, ?, ?, NOW(), ?)");
            $reg->bindParam(1,$username);
            $reg->bindParam(2,$email);
            $reg->bindParam(3,$password);
            $reg->bindParam(4,$groups);
            $reg->bindParam(5,$level);
            $reg->execute();
        }
    }
    public function getNotice()
    {
        return $this->notice;
    }
}

然后我将此类称为索引:

    <?php 
if (isset($_POST['submit'])){
    $username = $_POST['uname'];
    $email = $_POST['email'];
    $password = $_POST['pass'];
    $groups = $_POST['groups'];
    if($groups == "Administrator"){
        $level = 2;
    }else if($groups == "ContentCreatorBlog"){
        $level = 3;
    }else if($groups == "ContentCreatorShop"){
        $level = 4;
    }else if($groups == "ContentCreatorGallery"){
        $level = 5;
    }else if($groups == "Secretary"){
        $level = 6;
    }else if($groups == "SocialMediaManager"){
        $level = 7;
    }else if($groups == "Analyst"){
        $level = 8;
    }else{
        $level = Null;
    }
    if (filter_var($email, FILTER_VALIDATE_EMAIL) === false) {
        $notice['email_validation'] = "The email that you have entered is not a valid one";
    }else{
        $registration = new Register();
        $notice[] = $registration->CheckUname($username,$email,$password,$groups,$level);   
    }   
}
?>
<div class="content-wrapper">
    <section class="content-header">
        <h1>
            Add New Admin
            <small>You can add new admin here</small>
        </h1>
        <ol class="breadcrumb">
            <li class="active">addnewadmin.php</li>
        </ol>
    </section>
    <section class="content">
        <div class="row">
            <div class="col-md-12">
                <div class="box box-primary" id="myModal1">
                    <div class="box-header with-border">
                        <h3 class="box-title">Required Information</h3>
                    </div>
                    <?php 
                    if(isset($notice['email_validation'])) {
                        echo "
                            <div class='alert alert-danger'>
                                <strong>Hey!</strong> ".$notice['email_validation'].".
                            </div>
                        ";
                    }
                    if(isset($notice['username_exists'])) {
                        echo "
                            <div class='alert alert-danger'>
                                <strong>Hey!</strong> ".$notice['username_exists'].".
                            </div>
                        ";
                    }
                    if(isset($notice['email_exists'])) {
                        echo "
                            <div class='alert alert-danger'>
                                <strong>Hey!</strong> ".$notice['email_exists'].".
                            </div>
                        ";
                    }
                    if(isset($notice['success_message'])) {
                        echo "
                            <div class='alert alert-success'>
                                <strong>Hey!</strong> ".$notice['success_message'].".
                            </div>
                        ";
                    }
                    ?>
                    <form role="form" method="POST" action="" data-tour-index="1" data-tour-title="Card Type" data-tour-description="A card will usually be one of multiple similar type items on a page.">
                        <div class="box-body">
                            <div class="form-group">
                                <label>User name</label>
                                <input type="text" class="form-control" placeholder="Enter username" name="uname" required>
                            </div>
                            <div class="form-group">
                                <label for="exampleInputEmail1">Email address</label>
                                <input type="email" class="form-control" id="exampleInputEmail1" placeholder="Enter email" name="email" required>
                            </div>
                            <div class="form-group">
                                <label for="exampleInputPassword1">Temporary password</label>
                                <input type="password" class="form-control" id="exampleInputPassword1" placeholder="Enter password" name="pass" required>
                            </div>
                            <div class="form-group">
                                <label>Group admin</label>
                                <select class="form-control" name="groups">
                                    <option value="Administrator">Administrator</option>
                                    <option value="ContentCreatorBlog">Blog Content Creator</option>
                                    <option value="ContentCreatorShop">Shop Content Creator</option>
                                    <option value="ContentCreatorGallery">Gallery Content Creator</option>
                                    <option value="Secretary">Secretary</option>
                                    <option value="SocialMediaManager">Social Media Manager</option>
                                    <option value="Analyst">Analyst</option>
                                </select>
                            </div>
                        </div>
                        <div class="box-footer">
                            Visit <a href="https://zite.pouyavagefi.com/documentation/adminnew.php">admin new</a> documentation to know more about this page.
                        </div>
                        <div class="box-footer">
                            <button name="submit" type="submit" class="btn btn-primary">Submit</button>
                        </div>
                    </form>
                </div>
            </div>
        </div>
    </section>
</div>

很快,它所做的就是显示表单并获取一些信息并分配给参数,然后调用Class:

$registration = new Register();
$notice[] =      $registration->CheckUname($username,$email,$password,$groups,$level);  

因此,如果表单遇到任何错误,例如:

already registerd username error
already exists email address error

它应该简单地收回一个error message并通过索引页上的以下代码向用户显示:

if(isset($notice['email_validation'])) {
    echo "
        <div class='alert alert-danger'>
            <strong>Hey!</strong> ".$notice['email_validation'].".
        </div>
    ";
}
if(isset($notice['username_exists'])) {
    echo "
        <div class='alert alert-danger'>
        <strong>Hey!</strong> ".$notice['username_exists'].".
        </div>
    ";
}
if(isset($notice['email_exists'])) {
    echo "
        <div class='alert alert-danger'>
            <strong>Hey!</strong> ".$notice['email_exists'].".
        </div>
    ";
}
if(isset($notice['success_message'])) {
    echo "
        <div class='alert alert-success'>
            <strong>Hey!</strong> ".$notice['success_message'].".
        </div>
    ";
}

问题:

此代码的问题是,尽管有规则,但用户输入信息时错误消息不会弹出。但是,它仍然可以正确地向表中添加新行。

所以现在的问题是“当用户输入错误的信息时,为什么错误不会显示在页面上?我弄错了哪一部分”

2 个答案:

答案 0 :(得分:1)

$notice$this->notice之间存在差异。 $notice是局部变量,$this->notice是类变量。在您的情况下,您只能创建一个本地var,分配一个值,但返回仍然为空的类var。

要解决此问题,只需将其替换为$this->notice[..] = ...

但是还有其他逻辑问题。为什么CheckUname创建用户?调用NewAdminCheckUname的任务。您也可以将两个数据库查询合并为一个,询问是否存在带有用户名或密码的条目。还有更多要修复/更改的内容,但这将是代码审查的一部分

答案 1 :(得分:0)

您的$ notice变量在下面始终为“未设置”。后处理后,所有变量将被重置。但是,您可以重定向到具有$ notice变量的URL。例如,经过所有处理后,您可以:

redirect_to('index.php?notice=1');

其中redirect_to是一个带有URL的函数。

function redirect_to($path){
    die("<meta http-equiv='refresh' content=0;URL='".$path."' />");
}

然后在index.php中,可以检查notice变量是否已设置。但是,有多种方法可以做到这一点。

编辑:

function redirect_to($path){
   header("Location: " . $path);
}