abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:44 | IT novinky

    Společnost Valve aktualizovala přehled o hardwarovém a softwarovém vybavení uživatelů služby Steam. Podíl uživatelů Linuxu dosáhl v březnu 5,33 % (Windows -4,28 %, OSX +1,19 %, Linux +3,10 %). Nejčastěji používané linuxové distribuce jsou Arch Linux, Linux Mint a Ubuntu. Při výběru jenom Linuxu vede SteamOS Holo s 24,48 %. Procesor AMD používá 67,48 % hráčů na Linuxu.

    Ladislav Hagara | Komentářů: 0
    včera 23:22 | IT novinky

    Společnost Apple slaví padesáté narozeniny. Založena byla 1. dubna 1976.

    Ladislav Hagara | Komentářů: 0
    včera 22:33 | Nová verze

    FreeTube, desktopový klient pro YouTube využívající lokální API, byl vydán ve verzi 0.24.0. Toto velké opravné vydání implementuje SABR (Server-Based Adaptive Bit Rate), což řeší část nedávných problémů s načítáním videí z YouTube, a aktualizuje základní komponenty jako Electron nebo přehrávač Shaka Player.

    |🇵🇸 | Komentářů: 0
    včera 16:33 | Humor

    Je tu opět apríl. O víkendu zmizel kamion s 12 tunami tyčinek KitKat. Firmy to využívají k aprílovým žertům. Groupon má super akci. Koupíte 1 tyčinku a dostanete 100 zdarma. Ryanair si přelepil letadla. Šéf Outlooku se ptá, proč mají v baráku 14 beden tyčinek KitKat (𝕏). Prusa Research představuje Prusa Pro ACU a vysvětluje proč přílišné sušení škodí vaším filamentům. Telefon Sony Xperia má miliónnásobný zoom (𝕏). PC.net představil Super Ultrabox 2600 se zajímavými parametry. Další aprílové novinky například na April Fools' Day On The Web.

    Ladislav Hagara | Komentářů: 2
    včera 13:22 | IT novinky

    Společnost OpenAI, která stojí za chatovacím robotem s umělou inteligencí (AI) ChatGPT, získala od investorů 122 miliard USD (2,6 bilionu Kč). Hodnota společnosti tak dosáhla 852 miliard dolarů (více než 18 bilionů Kč). Nejnovější kolo investování se stalo největší, jaké zatím firma uskutečnila, a peníze mají posílit ambiciózní plány rozšíření výpočetní kapacity, datových center a nábor talentů.

    Ladislav Hagara | Komentářů: 9
    včera 13:11 | IT novinky

    Nástroj k identifikaci občanů v on-line komunikaci s úřady byl dnes dopoledne zhruba dvě hodiny částečně nedostupný. Problém se objevil kolem 09:00 a podařilo se ho vyřešit kolem 11:00. Částečně nedostupná byla služba Národní identitní autority (NIA), problémy podle DIA (Digitální a informační agentura) ovlivňovaly přihlašování například i přes bankovní identitu. „Dostupnost NIA byla plně obnovena, přihlášení k digitálním službám

    … více »
    Ladislav Hagara | Komentářů: 3
    včera 13:00 | IT novinky

    Eben Upton oznámil další zdražení počítačů Raspberry Pi kvůli růstu cen pamětí a představil Raspberry Pi 4 s 3 GB RAM za 83,75 dolarů.

    Ladislav Hagara | Komentářů: 0
    včera 04:33 | Humor

    Anthropic patrně omylem zveřejnil celý zdrojový kód svého CLI nástroje Claude Code prostřednictvím přiloženého sourcemap souboru v npm balíčku. Únik odhalil doposud nijak nezveřejněné funkce jako je například režim v utajení, autonomní agent 'KAIROS', orchestrace multi‑agentů, režim snění nebo dokonce virtuální mazlíček Buddy. Zajímavostí je detekce naštvání uživatele pomocí obyčejného regexpu. Anthropic rychle odstranil sourcemap a vydal opravu, nicméně kopie kódu se již stihly na GitHubu rozšířit mezi prostým lidem.

    NUKE GAZA! 🎆 | Komentářů: 12
    31.3. 14:33 | Humor

    Copilot automaticky vkládal do pull requestů 'propagační tipy', reklamní text se na GitHubu objevil ve více než jedenácti tisících pull requestech. Po vlně kritiky byla tato funkce zablokována a produktový manažer Tim Rogers připustil, že umožnit Copilotovi upravovat cizí pull requesty bez vědomí autorů byla chyba.

    NUKE GAZA! 🎆 | Komentářů: 4
    31.3. 12:55 | Upozornění

    Je 31. března a tedy Světový den zálohování (World Backup Day). Co by se stalo, kdyby Vám právě teď odešel počítač, tablet nebo telefon, který používáte?

    Ladislav Hagara | Komentářů: 4
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (12%)
     (30%)
     (3%)
     (5%)
     (1%)
     (14%)
     (24%)
    Celkem 1204 hlasů
     Komentářů: 29, poslední 31.3. 11:17
    Rozcestník

    Dotaz: Logovací systém - porovnávání výsledků z formuláře s údaji v databázi

    17.10.2011 22:32 Johny
    Logovací systém - porovnávání výsledků z formuláře s údaji v databázi
    Přečteno: 886×
    Zdravím :), Mám problém s porovnáním dat z formuláře v databázi MySQL. Vše běží zatím na localhostu jde o to, že uživatel zadá jméno a heslo zatím jen pomocí echa vypíše jestli operace proběhla správně a její výsledek. Problém je v tom, že k žádnému výstupu s datbáze se ani nedostanu a tím pádem je porovnávat dvě hodnoty nemožné :/.

    kód PHP:
    $path = "/wpplugins/";
    
    // funkce pro ošetření vstupních dat od uživatele
    function db_escape($str) 
    { 
        return mysql_real_escape_string(@get_magic_quotes_gpc() ? stripslashes($str) : $str);
    } 
    
    include "spojeni_db.php"; 
    
    $PHPSESSID=rand(1, 2000000);
    $_SESSION["test"]=0;
    $_SESSION["PHPSESSID"]=$PHPSESSID;
    $_SESSION["test"]=$_POST['test'];
    $IP=$_SERVER["REMOTE_ADDR"];
    
    if ($_SESSION["test"] = 1) {
    	$_SESSION["name"]=trim($_POST['name']);
    	$_SESSION["pass"]=trim($_POST['pass']);
    	if (!isset($_SESSION["name"])){$_SESSION['name']="NULL";}
    	if (!isset($_SESSION["pass"])){$_SESSION['pass']="NULL";}
    	if (!isset($_POST['test'])){$_SESSION['test']="NULL";}
    	
    	$tb = "logintable";
    	$username = $_SESSION["name"];
    	$userpass = $_SESSION["pass"];
    	$result = mysql_query("SELECT COUNT(*) FROM $tb WHERE Nick = '$username' AND Password = '$userpass' ");
    
    echo "$result";
    echo "jste úspěšně přihlášen";
    
    }
    else {zobraz formular}
    
    zobraz zakladni formular>
    

    kód souboru pro pripojeni k databázi:
    if ($_SERVER["SERVER_ADDR"]=="localhost")
    {
      define("SQL_HOST","localhost");
      define("SQL_DBNAME","users");
      define("SQL_USERNAME","root");
      define("SQL_PASSWORD","richter");
    }
    else
    {
    	echo "Nelze se pripojit k databazi";
    }
    

    Nemůžu se dopátrat problému, předem díky za odpovědi.

    Odpovědi

    17.10.2011 23:36 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Logovací systém - porovnávání výsledků z formuláře s údaji v databázi
    A co to tak dát do tagu <pre> a se to dá přečíst?
    echo "$result";
    
    je blbost, nějaké mysql_fetch_xxx tam chybí…, ale jinak nevím ani na co se ptáte…
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    18.10.2011 08:50 Johny
    Rozbalit Rozbalit vše Re: Logovací systém - porovnávání výsledků z formuláře s údaji v databázi
    Oprava: Vlastně mi šlo o to, aby se uživatel pomocí jednoduchého logovacího formuláře přihlásil k registrovanému obsahu stránky. Aby toto bylo možné musím provést kontrolu správnosti jména a hesla v databázi kam se jména a hesla ukládají.Uživatel zadá svůj Nick a Password a následně pomcí PHP se pokouším porovnávat udáje z POST->FORM s údaji v databázi, celkem jednoduchá logická operace jak si na stránky nepustit nikoho kdo není registrovaný (takový menší redakční systém. Jenže se mi zatím nepovedlo ani pomocí PHP v kombinaci s SQL tyto data správně porovnat a přesměrovat registrované na požadovaný obsah. Jde jen o kontrolu FORM x Databáze MySQL.

    18.10.2011 10:19 kuka
    Rozbalit Rozbalit vše Re: Logovací systém - porovnávání výsledků z formuláře s údaji v databázi
    To, ze jde o prihlasovani na strance, problem pouze zamlzuje. Podivej se do nejakeho tutorialu, jak v PHP udelat dotaz do mysql, zjistit co vraci atd.
    18.10.2011 11:02 Johny
    Rozbalit Rozbalit vše Re: Logovací systém - porovnávání výsledků z formuláře s údaji v databázi
    Aktualizuji problem:
    $id_spojeni = mysql_connect(`localhost`,`root`,`richter`);
    if (!$id_spojeni) {
    	echo "Spojení s MySQL databází se nezdařilo 
    "; } else { echo "Spojeni s databází navázáno
    "; } $vysledek_vybrani = mysql_select_db('users', $id_spojeni); if (!$vysledek_vybrani) { echo "Databázi users se nám nepodařilo vybrat
    "; } else { echo "Databáze users vybrána
    "; } $id_vysledku = mysql_query(`SELECT * FROM logintable`,$id_spojeni); if (!$id_vysledku) { echo "Nepodařilo se nám poslat SQL dotaz do databáze
    "; } else { echo "Podařilo se poslat SQL dotaz
    "; } Jméno Heslo while($radek = mysql_fetch_row($id_vysledku)) { for ($i=0; $i<2; ++$i) echo ``, $radek[$i], ``; } mysql_close($id_spojeni);
    výstup na stránce: Spojeni s databází navázáno Databázi users se nám nepodařilo vybrat Nepodařilo se nám poslat SQL dotaz do databáze Jméno Heslo ( ! ) Warning: mysql_fetch_row() expects parameter 1 to be resource, boolean given in C:\wamp\www\resultdb.php on line 39 Call Stack # Time Memory Function Location 1 0.0006 372944 {main}( ) ..\resultdb.php:0 2 0.1229 379056 mysql_fetch_row ( ) ..\resultdb.php:39 PS: nechápu jak může script připojit uživatele ROOT, ale neselectnout požadovanou datbázi když je syntaxe správně...nějaké rady?
    Josef Kufner avatar 18.10.2011 11:24 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Logovací systém - porovnávání výsledků z formuláře s údaji v databázi
    Proč tam máš všude obrácené apostrofy místo normálních?
    Hello world ! Segmentation fault (core dumped)
    18.10.2011 11:46 Johny
    Rozbalit Rozbalit vše Re: Logovací systém - porovnávání výsledků z formuláře s údaji v databázi
    protože bez nich mi nefunguje ani to mysql_connect(). to nebude podle mě tímhle...
    18.10.2011 12:22 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Logovací systém - porovnávání výsledků z formuláře s údaji v databázi
    Na to lze odpovědět jen: „to je pěkná blbost“.
    Je třeba znát základy jazyka, a u PHP prostě řetězce mohou být buď mezi " nebo ' a každý má jinou funkcionalitu (pro znalé, <<< je fčul zbytečné :-)).
    Zkuste si třeba v terminálu:
    php -r 'echo `ls`;'
    a pak:
    php -r 'echo "ls";'
    trochu rozdíl, že?
    Znak ` - v PHP nemá místo, krom toho, že je to znak jak každý jiný.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    18.10.2011 11:56 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Logovací systém - porovnávání výsledků z formuláře s údaji v databázi
    Rozlišujte ` ' ", v této kombinaci (MySQL a PHP):
    ` - má význam v MySQL příkazu pro názvy DB, tabulek, sloupců
    ' - PHP řetězec „jak je“
    " - PHP řetězec dosazující proměnné atd.

    Následující upravený(neříkám, že super správný) kód je normálně funkční.
    <?php
    $id_spojeni = mysql_connect('localhost','root','heslo');
    if (!$id_spojeni)
    {
      echo "Spojení s MySQL databází se nezdařilo\n";
      exit(1);
    }
    else
    {
      echo "Spojeni s databází navázáno\n";
    }
    
    $vysledek_vybrani = mysql_select_db('users', $id_spojeni);
    if (!$vysledek_vybrani)
    {
      echo "Databázi users se nám nepodařilo vybrat\n";
      echo "Error no. " . mysql_errno($id_spojeni) . ", Message: " . mysql_error($id_spojeni)  . "\n";
      exit(2);
    }
    else
    {
      echo "Databáze users vybrána\n";
    }
    
    $id_vysledku = mysql_query('SELECT * FROM logintable',$id_spojeni);
    if (!$id_vysledku)
    {
      echo "Nepodařilo se nám poslat SQL dotaz do databáze\n";
      echo "Error no. " . mysql_errno($id_spojeni) . ", Message: " . mysql_error($id_spojeni)  . "\n";
      exit(3);
    }
    else
    {
      echo "Podařilo se poslat SQL dotaz\n";
    }
    //Jméno
    //Heslo
    while($radek = mysql_fetch_row($id_vysledku))
    {
      for ($i=0; $i<2; ++$i)
        echo $radek[$i] . "\n";
    }
    mysql_close($id_spojeni);
    
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    Josef Kufner avatar 18.10.2011 14:38 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Logovací systém - porovnávání výsledků z formuláře s údaji v databázi
    Btw, tady je příklad, který výsledek SQL dotazu naformátuje do tabulky.

    Maličko upravený (hlavně doplněno escapování html značek ve výsledku):
    <?php
    $query="select * from user";
    $result=mysql_query($query);
    $numfields = mysql_num_fields($result);
    
    echo "<table>\n<tr>";
    
    // Header
    for ($i=0; $i < $numfields; $i++) {
       echo '<th>', htmlspecialchars(mysql_field_name($result, $i)), '</th>';
    }
    
    echo "</tr>\n";
    
    // Data
    while ($row = mysql_fetch_row($result)) {
       echo '<tr>';
       foreach ($row as $col) {
         echo '<td>', htmlspecialchars($col), '</td>';
       }
       echo "</tr>\n";
    }
    
    echo "</table>\n"
    ?>
    
    Jinak doporučuju se podívat na funkci mysql_fetch_assoc. Kód při jejím používání je mnohem čitelnější a prý to ani není nijak znatelně pomalejší.

    A pak také na mysql_real_escape_string.
    Hello world ! Segmentation fault (core dumped)
    rADOn avatar 18.10.2011 18:54 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: Logovací systém - porovnávání výsledků z formuláře s údaji v databázi
    Pokud potřebuješ jen jednoduché přihlášení, vybodni se na SQL a formuláře a použij http autentizaci. Je to otázka pár řádků v konfiguráku a plaintextového souboru s hesly. Zakryptovanými! (styď se).

    Pokud chceš něco složitějšího, máš to blbě od začátku do konce.
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    18.10.2011 19:09 l4m4
    Rozbalit Rozbalit vše Re: Logovací systém - porovnávání výsledků z formuláře s údaji v databázi
    s/jednoduché přihlášení/\0 ručně administrátorem udržované množiny uživatelů/
    To je dost velký rozdíl.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.