0

テキストを db に送信しようとしましたが、db フィールドにテキストが挿入されませんでした。

私のどこが間違っているか分析できますか?

私はこのようにしてみます。

ご協力いただきありがとうございます。

<script type="text/javascript">
$(document).ready(function() {
    $('#myForm').submit(function() {
        var namaklasifier = document.getElementByName("tfklasifier").value;
        var inputpos= document.getElementByName("tacaripos").value;
        var inputnet = document.getElementByName("tacarinet").value;
        var inputneg = document.getElementByName("tacarineg").value;    
   $.ajax({
        type: 'POST',
        url:  $(this).attr('action'),
        data: $(this).serialize(),
        success: function(data) {
        $('#resultcoba').html(data);}
    })
        return false;
  });
    })
</script>    
<form id="myForm" method="post" action="proses.php">
<td align="center" valign="top" style="width:420px"><textarea style="width:420px" name="tacaripos" rows="4" cols="70"><?PHP echo htmlspecialchars($_POST['tacaripos']);?></textarea></td>
<td align="center" valign="top" style="width:420px"><textarea style="width:420px" name="tacarinet" rows="4" cols="70"><?PHP echo htmlspecialchars($_POST['tacarinet']);?></textarea></td>
<td align="center" valign="top" style="width:420px"><textarea style="width:420px" name="tacarineg" rows="4" cols="70"><?PHP echo htmlspecialchars($_POST['tacarineg']);?></textarea></td>
</tr>
<td align="center"><input type="submit" name="btklasifier" id="btklasifier" value="Buat" /></td></form>

proses.php

    <?php    
       $namaklasifier=$_POST['namaklasifier'];
$jadipos=$_POST['inputpos'];
$jadinet=$_POST['inputnet'];
$jadineg=$_POST['inputneg'];

$link=mysqli_connect("localhost", "root", "","skripsi");
mysqli_select_db($link,"skripsi");
mysqli_query($link,"INSERT INTO namaklasifier(username,datapos,datanet,dataneg,user) VALUES('$namaklasifier','$jadipos','$jadinet','$jadineg','{$_SESSION['username']}')"); ?>

ありがとう :)

4

3 に答える 3

2

ここで宣言した変数名で GET データにアクセスしようとしています:

var namaklasifier = document.getElementByName("tfklasifier").value;
var inputpos= document.getElementByName("tacaripos").value;
var inputnet = document.getElementByName("tacarinet").value;
var inputneg = document.getElementByName("tacarineg").value;

これは、入力名を使用して GET 変数にアクセスする必要があること$(this).serialize()を意味します。これはシリアライズが行うことです (名前を使用してフォーム要素からオブジェクトを作成します)。例えば

$jadipos=$_POST['tacaripos'];
$jadinet=$_POST['tacarinet'];
$jadineg=$_POST['tacarineg'];

また、それが使用している方法であるため、に変更$_GETする必要があります。$_POST

于 2013-06-15T11:39:43.487 に答える
1

で、proses.phpを に変更$_GET$_POSTます。

メソッドを使用しPOSTてデータを送信しているため、当然、$_POST変数を使用する必要があります。

于 2013-06-15T11:38:02.713 に答える
1

それらはGET値ではなくPOST値です

$jadipos=$_POST['inputpos'];
$jadinet=$_POST['inputnet'];
$jadineg=$_POST['inputneg'];

また、非推奨であるため、mysql_* 関数の代わりに mysqli_* 関数または PDO ステートメントを使用してみてください。

編集:また試してみてください

var namaklasifier = document.getElementByName("tfklasifier").value;
    var inputpos= document.getElementByName("tacaripos").value;
    var inputnet = document.getElementByName("tacarinet").value;
    var inputneg = document.getElementByName("tacarineg").value;    
 $.ajax({
      type: 'POST',
      url:  $(this).attr('action'),
      data: {inputpos:inputpos,inputnet:inputnet,inputneg:inputneg},
      success: function(data) {
         $('#resultcoba').html(data);}
     })
    return false;
 });
于 2013-06-15T11:38:34.533 に答える