将数据保存到表中

时间:2019-03-25 02:49:03

标签: mysqli sql-insert insert-update

我尝试将数据保存到表中,但是它不起作用。但是另一个具有类似代码的程序为什么呢?

<?php
    $nik =  $_POST['nik'];
    $no_kk =  $_POST['no_kk'];
    $nama =  $_POST['nama'];
    $lahir =  $_POST['lahir'];          
    $jenis_kelamin =  $_POST['jk'];
    $nope =  $_POST['no_hp']; 
    $no_tps =  $_POST['no_tps'];
    $pekerjaan =  $_POST['pekerjaan']; 
    $pendidikan =  $_POST['pendidikan'];
    $agama = $_POST['agama'];
    $tgl = $_POST['tgl'];      

    $simpan=$_POST['simpan'];
    $sql = "INSERT INTO tb_tj_beringin (NIK, NO_KK, NAMA_LENGKAP, JENIS_KELAMIN, TEMPAT_LAHIR, TANGGAL_LAHIR, AGAMA, PENDIDIKAN_AKHIR, JENIS_PEKERJAAN, NO_HP, NO_TPS) VALUES ('$nik', '$no_kk', '$nama','$alamat','$jenis_kelamin','$lahir','$tgl', '$agama', '$pendidikan', '$pekerjaan', '$nope', '$no_tps')";
    $data = mysqli_query('$koneksi, $sql');
    if(isset($simpan)){
         $data = $koneksi->query($sql);
         if($data){
             ?>
             <script type="text/javascript">
                alert ("Data Berhasil Disimpan");
                window.location.href="?page=anggota";
             </script>

             <?php
         }
         else{
              echo "error";
         }
    }
?>

1 个答案:

答案 0 :(得分:1)

这是错误的:...VALUES ('$nik', '$no_kk', '$nama'...)

在PHP中,单引号防止变量扩展的问题。因此,您实际上不会插入$nik(或其他任何值)的值。

第二个问题是,永远不要 EVER 将Web请求中的数据直接插入数据库中。 从不信任用户数据。这是一个巨大漏洞。

解决两个问题的简单方法是简单地使用prepared statements