Diskuze: Problém s databází
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Tvůrce
Zobrazeno 15 zpráv z 15.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Databázi si vyber rovnou při připojení jako další parametr.
<?php
class MyDatabaze
{
private $spojeni;
function ConnectDatabaze($hostitel,$login,$pass)
{
$spojeni=mysqli_connect($hostitel,$login,$pass,'zirkoadmin');
$databaze='zirkoadmin';
return $spojeni;
}
function CreateTable()
{
$OK=mysqli_query('CREATE TABLE pocitadlo(id CHAR(1), hodnota INT UNSIGNED)','zirkoadmin');
if($OK)
return true;
else return false;
}
}
$myDb=new MyDatabaze();
$connectDb=$myDb->ConnectDatabaze('localhost','zirkoAdmin','admin');
if(!$connectDb)
{Die('Error - databaze nenalezena');}
/*$db=$myDb->SelectDB();
if($db)
echo "Databaze zvolena";
else Die('Databaze nezvolena');
*/
$ok=$myDb->CreateTable();
if($ok)
echo "Bingo tabulka vytovřena";
else Die('Tabulka nevytvořena');
?>
Dostal jsem jeden warning
Warning: mysqli_query() expects parameter 1 to be mysqli, string given in
C:\xampp\htdocs\Test\index.php on line 16
Jedná se o jakýsi result_mode a nevím co tam patří.
A tabulka se stále nevytvoří. Nečekal jsem že se zaseknu takhle rychle
mysqli_query($spojeni,'CREATE TABLE pocitadlo(id CHAR(1), hodnota INT UNSIGNED)','zirkoadmin');
jelikož to nemáš objektový tak tam musíš všude cpát proměnou s číslem spojení k databázi
Nechci vytvářet nové vlákno, tak píšu sem.
Mám formulář
<form name="formular" action="send.php" method="post">
<table class="formular">
<tr>
<td><label for="name">* Vaše jméno:</label> </td>
<td><input class="inputText" type="text" name="name"/></td>
</tr>
<tr>
<td><label for="email">* Váš e-mail:</label> </td>
<td><input class="inputText" type="text" name="email" /></td>
</tr>
<tr>
<td><label for="zprava">* Vaše zpráva</label></td>
<td><textarea name="zprava"></textarea></td>
</tr>
<tr>
<td><label for="antispam">* Kolik je 0*5+2</label></td>
<td><input class="inputText" type="text" name="antispam" />(antispamová ochrana)</td>
</tr>
<tr>
<td></td>
<td><input type="submit" class="inputButton" value="Odeslat zprávu" name="ok" /></td>
</tr>
</table>
</form>
a k němu patřičný velmi primitivní php kód
<?php
$name=$_POST['name'];
$email=$_POST['email'];
$zprava=$_POST['zprava'];
$antispam=$_POST['antispam'];
if (isset($name) && isset($email) && $zprava && isset($antispam) && ($antispam =='2') )
// && isset($_POST['hidespam'])==false)
{
mail('[email protected]',$_POST['predmet'],$_POST['od'].': '.$_POST['zprava']);
echo "Odesláno";
}
else//chyby
{
echo "Neodesláno";
}
//header('Location: http://localhost/Zirko/#Kontakt');
?>
Píše mi to že $zprava není definovaná, repsketive v poli $_POST není index $zprava. Ale nemůžu přijít na to proč. Poradí někdo prosím ?
mozna mas policko ZPRAVA v databazi pojmenovany jinak
Nemám to vůbec v databázi ale posílám ty data metodou pos přes formulář, ostatní data jako jméno, email, antispam přijdou v pořádku
ja si to vzdycky delam pres databazi a funguje mi to
Moc jsem to nezkoumal, ale na první pohled bych řekl, že ti tám chybí "isset($zprava)" - máš jenom "$zprava"...Tedy bez "isset()" by to asi mělo vracet true/false, takže by to mohlo fungovat, ale když všude jinde isset() máš..
Jak jsem psa, do $zprava se ani nic neuloží protože není $_POST vložená hodnota z formuláře, i když by měla
To se mi nějak nezdá... zkus dát var_dump($_POST) ať vidíš, co ti to pošle.. Mě to html normálně funguje a var_dump($_POST) mi vrátilo:
array(5) { ["name"]=> string(12) "Pavel Vosyka" ["email"]=> string(21) "[email protected]" ["zprava"]=> string(20) "zpráva, zprávička" ["antispam"]=> string(1) "2" ["ok"]=> string(15) "Odeslat zprávu" }
Je to tím, že se proměnné snaží deklarovat i v případě, že formulář neodešleš. Z toho vyplývá, že pokud neodešleš formulář, pole $_POST v sobě nemá žádné prvky. Proto ti to hlásí, že $_POST['zprava'] neexistuje.
Ostatní proměnné se zaregistrují v pohodě, resp. odešlou.
Nebylo by špatné, kdybys sem konečně poslal požadovaný výstup příkazu
var_dump($_POST);
jo omlouvám se, no var_dump mi vypsal a ukázalo se že proměnná zpráva je odeslána. A nevím proč, ale to náhle funguje. V k´du jsem nic neměnil, jediný co jsme udělal, bylo že jsme restartoval Apache
Zobrazeno 15 zpráv z 15.