• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

dane nie dodają się do bazy

Object Storage Arubacloud
0 głosów
136 wizyt
pytanie zadane 27 listopada 2016 w PHP przez Meenti Nowicjusz (160 p.)
edycja 27 listopada 2016 przez HaKIM

Witam,

Mam problem z dodawaniem danych generowanych przez formularz do bazy danych. Gdy zamieniam je na statyczne wszystko fajnie się dodaję .Nie mam już pomysłów co może być nie tak.

Kod html:
 

<!DOCTYPE html >
<html lang="pl">
<head>
    <meta content="text/html; charset=ISO-8859-1" http-equiv="content-type">
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
    <link rel="stylesheet" href="style.css">
    <title>stronadziwna</title>
    <script src="script.js"></script>
</head>
<body>

    <div class="container text-center">
        <form class ="form-horizontal">
               <div class="row">
                 <form action="add_user.php" method="post">
                    <div class="form-group">
                        <label for="name" id="imie" class="col-md-4 control-label" >Imie</label>
                            <div class="col-md-8">
                                <input type="text" class="form-control " id="name" placeholder="wpiszimie" name="namee">
                            </div>
                    </div>
                </div>
                 <div class="row">
                    <div class="form-group">
                        <label for="surname" id="nazwisko" class="col-md-4 control-label" >Nazwisko</label>
                            <div class="col-md-8">
                                <input type="text" class="form-control " id="surname" placeholder="wpisznazwisko" name="surname">
                            </div>
                    </div>
                </div>
                 <div class="row">
                    <div class="form-group">
                        <label for="number" id="numer_telefonu" class="col-md-4 control-label" >Numer telefonu</label>
                            <div class="col-md-8">
                                <input type="number" class="form-control col-md-8" id="number" placeholder="wpisznumertelefonu" name="number">
                            </div>
                    </div>
                </div>
                 <div class="row">
                       <div class="form-group">
                            <label for="mail" id="email" class="col-md-4 control-label"  >Email</label>
                            <div class="col-md-8">
                                <input type="text" class="form-control col-md-8" id="mail" placeholder="wpiszemail" name="mail">
                           </div>
                     </div>
                </div>
                <input type ="submit" >
            <button type="button" id="dalej" class="btn btn-primary btn-lg " >Dodaj</button>

            </form>
        </form>
    </div>
</body>
</html>



 

Kod php -połączenie z bazą :
 

<?php

$servername = "localhost";
$username = "root";
$password = "";
$dbname = "user";

$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error){

    die("Nie udało się połączyć z bazą: " .$conn->connect_error);
}

?>

php- Dodawania użytkownika

<?php

require_once "sql_connect.php";
include "index.html";

//$name=ble;
//$surname=ble;
//$number=342444;
//$email=ble;

$name=$_POST['namee'];
$surname=$_POST['surname'];
$number=$_POST['number'];
$email=$_POST['mail'];

$sql = "INSERT INTO useradd(imie,nazwisko,numer,email)VALUES('".$name."','".$surname."','".$number."','".$email."')";

if ($conn->query($sql) === TRUE) {
    echo "Dodano pomyślnie";
} else {
    echo "Błąd: " . $sql . "<br>" . $conn->error;
}

$conn->close();
?>

 

1 odpowiedź

0 głosów
odpowiedź 27 listopada 2016 przez HaKIM Szeryf (87,590 p.)

Zacznijmy od tego, że masz skopane elementy HTML:

    <div class="container text-center">
        <form class ="form-horizontal">
               <div class="row">
                 <form action="add_user.php" method="post">
            </form>
        </form>
    </div>

Skorzystaj z jednego form (Ten z action).

$name=$_POST['namee']; - Powinno być $_POST['name'].

W którym momencie występują błąd? Dodatkowo, podaj jego zawartość.

1
komentarz 27 listopada 2016 przez hoktaur Pasjonat (22,250 p.)
Ja się tu dokleje jeszcze daj na php

var_dump($_POST)

i pokaż co wyświetli
komentarz 27 listopada 2016 przez HaKIM Szeryf (87,590 p.)
Właśnie. Zapomniałem dodać. :p
komentarz 27 listopada 2016 przez Meenti Nowicjusz (160 p.)
edycja 27 listopada 2016 przez Meenti

html

<!DOCTYPE html >
<html lang="pl">
<head>
    <meta content="text/html; charset=ISO-8859-1" http-equiv="content-type">
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
    <link rel="stylesheet" href="style.css">
    <title>stronadziwna</title>
    <script src="script.js"></script>
</head>
<body>
 <form action="add_user.php" method="post" class ="form-horizontal">
    <div class="container text-center">
               <div class="row">

                    <div class="form-group">
                        <label for="name" id="imie" class="col-md-4 control-label" >Imie</label>
                            <div class="col-md-8">
                                <input type="text" class="form-control " id="name" placeholder="wpiszimie" name="name">
                            </div>
                    </div>
                </div>
                 <div class="row">
                    <div class="form-group">
                        <label for="surname" id="nazwisko" class="col-md-4 control-label" >Nazwisko</label>
                            <div class="col-md-8">
                                <input type="text" class="form-control " id="surname" placeholder="wpisznazwisko" name="surname">
                            </div>
                    </div>
                </div>
                 <div class="row">
                    <div class="form-group">
                        <label for="number" id="numer_telefonu" class="col-md-4 control-label" >Numer telefonu</label>
                            <div class="col-md-8">
                                <input type="number" class="form-control col-md-8" id="number" placeholder="wpisznumertelefonu" name="number">
                            </div>
                    </div>
                </div>
                 <div class="row">
                       <div class="form-group">
                            <label for="mail" id="email" class="col-md-4 control-label"  >Email</label>
                            <div class="col-md-8">
                                <input type="text" class="form-control col-md-8" id="mail" placeholder="wpiszemail" name="mail">
                           </div>
                     </div>
                </div>
                <input type ="submit" >
            <button type="button" id="dalej" class="btn btn-primary btn-lg " >Dodaj</button>
    </div>
  </form>
</body>
</html>


 

połączenie z bazą:

<?php

$servername = "localhost";
$username = "root";
$password = "";
$dbname = "user";

$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error){

    die("Nie udało się połączyć z bazą: " .$conn->connect_error);
}

?>


 

dodawanie użytkownika

<?php

require_once "sql_connect.php";
require_once "index.html";

//$name=ble;
//$surname=ble;
//$number=342444;
//$email=ble;

$name=var_dump($_POST['name']);
$surname=var_dump($_POST['surname']);
$number=var_dump($_POST['number']);
$email=var_dump($_POST['mail']);

$sql = "INSERT INTO useradd(imie,nazwisko,numer,email)VALUES('".$name."','".$surname."','".$number."','".$email."')";

if ($conn->query($sql) === TRUE) {
    echo "Dodano pomyślnie";
} else {
    echo "Błąd: " . $sql . "<br>" . $conn->error;
}

$conn->close();
?>


 

Dodałam var_dump i zmodernizowałam form.

Tak wygląda formularz:

Dodają się puste pola do bazy.

string(1) "u" string(1) "h" string(2) "66" string(3) "hhh" Dodano pomyślnie

komentarz 27 listopada 2016 przez HaKIM Szeryf (87,590 p.)

Hmm... Dziwne. Powinno śmigać.

Spróbuj zastosować takie zapytanie:

"INSERT INTO useradd (imie, nazwisko, numer, email) 
             VALUES('$name', '$surname', '$number', '$email')";
komentarz 28 listopada 2016 przez Meenti Nowicjusz (160 p.)

Dzięki za pomoc ,musiałam dodać do zmiennych :

 $name=mysqli_real_escape_string($conn, $_POST['name']);
$surname=mysqli_real_escape_string($conn, $_POST['surname']);
$number=mysqli_real_escape_string($conn, $_POST['number']);
$email=mysqli_real_escape_string($conn, $_POST['mail']);
Działa ;>>

komentarz 28 listopada 2016 przez HaKIM Szeryf (87,590 p.)

A było od razu zajrzeć do dokumentacji... Głupi ja. angry

http://php.net/manual/en/mysqli.real-escape-string.php#refsect1-mysqli.real-escape-string-examples

* this query will fail, cause we didn't escape $city */ 

Podobne pytania

0 głosów
0 odpowiedzi 114 wizyt
pytanie zadane 12 maja 2019 w PHP przez r.mar Początkujący (470 p.)
+1 głos
3 odpowiedzi 267 wizyt
0 głosów
1 odpowiedź 350 wizyt

92,579 zapytań

141,432 odpowiedzi

319,664 komentarzy

61,965 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...