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í
×

včera 23:55 | Zajímavý projekt

Byl spuštěn Humble Classics Return Bundle. Za vlastní cenu lze koupit hry Broken Sword 5 - The Serpent's Curse, Shadowrun Returns a Shadowrun: Dragonfall - Director's Cut. Při nadprůměrné platbě (aktuálně 8,48 $) také Shadowrun: Hong Kong - Extended Edition, Wasteland 2: Director's Cut - Standard Edition, Age of Wonders III a Xenonauts. Při platbě 15 $ a více lze získat navíc Torment: Tides of Numenera a Dreamfall Chapters: The Final Cut Edition.

Ladislav Hagara | Komentářů: 0
včera 00:11 | Bezpečnostní upozornění

Vývojáři linuxové distribuce Mageia na svém blogu upozorňují na narušení bezpečnosti Mageia Identity. Narušitel získal přístup k LDAP databázi a zveřejnil jména uživatelů, jejich emailové adresy a haše hesel. Hesla uživatelů byla resetována.

Ladislav Hagara | Komentářů: 1
20.2. 21:55 | Nová verze

Byla vydána verze 2.0.0 nástroje pro záznam a sdílení terminálových sezení asciinema (GitHub). Z novinek je nutno upozornit na nový zpětně nekompatibilní formát záznamu asciicast v2. S novým formátem si poradí nové verze asciinema-playeru a asciinema-serveru [Hacker News].

Ladislav Hagara | Komentářů: 0
20.2. 05:55 | Zajímavý projekt

Dle příspěvku na blogu zaměstnanců CZ.NIC byl spuštěn ostrý provoz služby Honeypot as a Service (HaaS). Zapojit se může kdokoli. Stačí se zaregistrovat a nainstalovat HaaS proxy, která začne příchozí komunikaci z portu 22 (běžně používaného pro SSH) přeposílat na server HaaS, kde honeypot Cowrie (GitHub) simuluje zařízení a zaznamenává provedené příkazy. Získat lze tak zajímavé informace o provedených útocích. K dispozici jsou globální statistiky.

Ladislav Hagara | Komentářů: 7
20.2. 04:44 | Komunita

Před týdnem společnost Feral Interactive zabývající se vydáváním počítačových her pro operační systémy macOS a Linux oznámila, že pro macOS a Linux vydají hru Rise of the Tomb Raider. Včera společnost oznámila (YouTube), že pro macOS a Linux vydají také hru Total War Saga: Thrones of Britannia. Verze pro Windows by měla vyjít 19. dubna. Verze pro macOS a Linux krátce na to.

Ladislav Hagara | Komentářů: 0
19.2. 21:33 | Nová verze

Byla vydána nová major verze 7.10 svobodného systému pro řízení vztahů se zákazníky (CRM) s názvem SuiteCRM (Wikipedie). Jedná se o fork systému SugarCRM (Wikipedie). Zdrojové kódy SuiteCRM jsou k dispozici na GitHubu pod licencí AGPL.

Ladislav Hagara | Komentářů: 0
19.2. 16:44 | Nová verze

Byla vydána nová verze 0.30 display serveru Mir (Wikipedie) a nová verze 2.31 nástrojů snapd pro práci s balíčky ve formátu snap (Wikipedie). Z novinek Miru vývojáři zdůrazňují vylepšenou podporu Waylandu nebo možnost sestavení a spouštění Miru ve Fedoře. Nová verze snapd umí Mir spouštět jako snap.

Ladislav Hagara | Komentářů: 0
19.2. 14:00 | Komunita

Na Indiegogo běží kampaň na podporu Sway Hackathonu, tj. pracovního setkání klíčových vývojářů s i3 kompatibilního dlaždicového (tiling) správce oken pro Wayland Sway. Cílová částka 1 500 dolarů byla vybrána již za 9 hodin. Nový cíl 2 000 dolarů byl dosažen záhy. Vývojáři přemýšlejí nad dalšími cíli.

Ladislav Hagara | Komentářů: 1
19.2. 11:11 | Nasazení Linuxu

Před dvěma týdny se skupina fail0verflow (Blog, Twitter, GitHub) pochlubila, že se jim podařilo dostat Linux na herní konzoli Nintendo Switch. O víkendu bylo Twitteru zveřejněno další video. Povedlo se jim na Nintendo Switch rozchodit KDE Plasmu [reddit].

Ladislav Hagara | Komentářů: 3
19.2. 05:55 | Komunita

Byla vydána vývojová verze 3.2 softwaru Wine (Wikipedie), tj. softwaru, který vytváří aplikační rozhraní umožňující chod aplikací pro Microsoft Windows také pod GNU/Linuxem. Z novinek lze zdůraznit například podporu HID gamepadů. Aktuální stabilní verze Wine je 3.0, viz verzování. Nejistá je budoucnost testovací větve Wine Staging s řadou experimentálních vlastností. Současní vývojáři na ni již nemají čas. Alexandre Julliard, vedoucí projektu Wine, otevřel v diskusním listu wine-devel diskusi o její budoucnosti.

Ladislav Hagara | Komentářů: 4
Který webový vyhledávač používáte nejčastěji?
 (2%)
 (28%)
 (62%)
 (2%)
 (3%)
 (0%)
 (1%)
 (1%)
Celkem 417 hlasů
 Komentářů: 35, poslední včera 19:51
    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: 793×
    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: 67
    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: 67
    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.