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 18:44 | IT novinky

    Vojenské zpravodajství (VZ) se v březnu zapojilo do mezinárodní operace proti aktivitám hackerské skupiny APT28, která je spojovaná s ruskou vojenskou zpravodajskou službou GRU a která přes slabě zabezpečené routery prováděla kybernetické útoky na státní a další organizace v ČR i zahraničí. Operaci vedl americký Federální úřad pro vyšetřování (FBI) a jejím cílem bylo odebrat útočníkům přístup k napadeným zařízením a ty následně … více »

    Ladislav Hagara | Komentářů: 3
    včera 16:44 | IT novinky

    Tvůrcem nejpopulárnější kryptoměny bitcoin, který se skrývá za pseudonymem Satoši Nakamoto (Satoshi Nakamoto), je britský kryptograf Adam Back. Na základě vlastní investigativní práce to tvrdí americký deník The New York Times (NYT). Několik indicií podle autorů jasně ukazuje na to, že Back a Nakamoto jsou stejný člověk. Jde mimo jiné o podobný odborný a osobnostní profil či totožné chyby a manýry v psaném projevu.

    Ladislav Hagara | Komentářů: 6
    včera 14:44 | Nová verze

    Google Chrome 147 byl prohlášen za stabilní. Nejnovější stabilní verze 147.0.7727.55 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Vylepšeny byly také nástroje pro vývojáře. Přehled novinek v Chrome DevTools 145 až 147 také na YouTube.

    Ladislav Hagara | Komentářů: 0
    včera 12:44 | Nová verze

    Vývojáři z Laboratoří CZ.NIC vydali nové verze aplikací Datovka (Datovka 4.29.0, Mobilní Datovka 2.6.2). V případě desktopové verze přibyly možnosti projít všechny uložené zprávy, zkontrolovat časy expirací časových razítek a přerazítkovat datové zprávy, které lze v ISDS přerazítkovat. Novinkou je také možnost vytahovat myší ze seznamu ZFO soubory datových zpráv, tento úkon jde udělat i pomocí tlačítek Ctrl+C. Nová verze Mobilní Datovky přináší jen drobné úpravy.

    VSladek | Komentářů: 0
    7.4. 21:55 | Nová verze

    MicroPython (Wikipedie), tj. implementace Pythonu 3 optimalizovaná pro jednočipové počítače, byl vydán ve verzi 1.28.0. Z novinek lze vypíchnout novou třídu machine.CAN.

    Ladislav Hagara | Komentářů: 0
    7.4. 10:22 | Komunita

    Michael Meeks, CEO společnosti Collabora, na apríla oznámil, nebyl to ale apríl, že nadace The Document Foundation zastřešující vývoj kancelářského balíku LibreOffice vyloučila ze svých řad všechny zaměstnance a partnery společnosti Collabora, tj. více než třicet lidí, kteří po mnoho let přispívali do LibreOffice. Nadace The Document Foundation po několika dnech publikovala oficiální vyjádření. Přiznává pochybení při zakládání

    … více »
    Ladislav Hagara | Komentářů: 9
    6.4. 05:33 | Pozvánky

    Protože je už po aprílu, můžou strahováci opět zveřejnit program další Virtuální Bastlírny, aniž by připravená témata působila dojmem, že jde o žert. Vězte tedy, že v úterý 14. dubna (změna!!!) od 20:00 proběhne VB, kde se setkají bastlíři, technici, učitelé i nadšenci do techniky a kde i vy se můžete zapojit do družného hovoru, jako by všichni seděli u pomyslného piva. Co mají bastlíři tento měsíc na srdci? Pravděpodobně by nás musel zasáhnout

    … více »
    bkralik | Komentářů: 3
    5.4. 23:33 | Nová verze

    Byla vydána verze 26.1 aneb čtvrtletní aktualizace open source počítačového planetária Stellarium (Wikipedie, GitHub). Vyzkoušet lze webovou verzi Stellaria na Stellarium Web.

    Ladislav Hagara | Komentářů: 1
    5.4. 23:00 | Zajímavý projekt

    VOID (Video Object and Interaction Deletion) je nový open-source VLM model pro editaci videa, který dokáže z videí odstraňovat objekty včetně všech jejich fyzikálních interakcí v rámci scény (pády, kolize, stíny...) pomocí quadmaskingu (čtyřhodnotová maska, která člení pixely scény do čtyř kategorií: objekt určený k odstranění, překrývající se oblasti, objektem ovlivněné oblasti a pozadí scény) a dvoufázového inpaintingu. Za projektem stojí výzkumníci ze společnosti Netflix.

    NUKE GAZA! 🎆 | Komentářů: 8
    5.4. 05:22 | Zajímavý software

    Design (GitHub) je 2D CAD pro GNOME. Instalovat lze i z Flathubu. Běží také ve webovém prohlížeči.

    Ladislav Hagara | Komentářů: 20
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (7%)
     (1%)
     (12%)
     (30%)
     (3%)
     (6%)
     (1%)
     (14%)
     (24%)
    Celkem 1245 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    php menu

    11.1.2007 12:41 | Přečteno: 4562× | Programování

    Zrovna se učím php na jednom projektu pro kamaráda(bude se jednat o ovládací panel na wi-fi router, protože on je totální BFU a webmin se mi nezamlouvá) a právě se mi podařilo dokončit algoritmus na vykreslení stromového menu a protože se na tom to PHP učím tak bych se chtěl zeptat, jestli by se na následujícím kódu dalo ještě něco upravit, nebo optimalizovat(jinak kdyby se tento kód někomi zalíbil, tak si jej klidně může použít;-)):

    function showmenu() {
    	$sql= "SELECT * FROM menu ORDER BY position, menu_id";
    	$menu= dbcon($sql);
    	$sqlm= "SELECT MAX(level) AS level from menu";
    	$rowsm= dbcon(($sqlm));
    	$rows= array ();
    	//Pole pro uchovávání indexů, kde jsme v předchozí úrovní menu zkončili
    	$oldn= array ();
    	for ($i= 0; $i lt; count($menu); $i ++) {
    		if ($menu[$i]["level"] == '0') {
    			array_push($rows, $menu[$i]);
    		}
    	}
    	echo "<table>\n";
    	menu_rec(0, $rowsm[0]["level"], $rows, 0, $oldn, $menu);
    	echo "</table>\n";
    }
    
    function menu_rec($level, $maxlevel, $rowd, $next, $oldn, $menu) {
    	if ($level <= $maxlevel) {
    		if (isset ($rowd[$next]) && $rowd[$next]["level"] == $level) {
    			echo "<tr><td>";
    			for ($i= 0; $i < $level; $i ++) {
    				echo "*";
    			}
    			echo "<a href=\"index.php?".$rowd[$next]["url"]."\">".$rowd[$next]["title"]."</td></tr>\n";
    		}
    		$rowdo= $rowd;
    		$rowd= array ();
    		for ($i= 0; $i < count($menu); $i ++) {
    			if ($menu[$i]["parent"] == $rowdo[$next]["menu_id"]) {
    				array_push($rowd, $menu[$i]);
    			}
    		}
    		//Pokud existuje potomek, pokračuj zde.
    		if (isset ($rowd[0])) {
    			// a ulož kde jsme zkončili
    			array_push($oldn, $next);
    			menu_rec(++ $level, $maxlevel, $rowd, 0, $oldn, $menu);
    		}
    		//Jinak jdi na následující položku v řadě
    		elseif (isset ($rowdo[++ $next])) {
    			menu_rec($level, $maxlevel, $rowdo, $next, $oldn, $menu);
    		}
    		//Pokud neexistuje dálší v řadě(next je inkrementováno z předchozího elseif) a neexistije potomek, jdi zpět nahoru
    		elseif ((!(isset ($rowdo[$next]))) && (!(isset ($rowd[0])))) {
    			$row= array ();
    			//Sniž hodnotu next, protože je zvýšená od elseif
    			-- $next;
    			//Získej předka aktuální položky
    			for ($i=0; $i < count($menu); $i ++) {
    				if ($menu[$i]["menu_id"] == $rowdo[$next]["parent"]) {
    					array_push($row, $menu[$i]);
    				}
    			}
    			//Pokud existuje předek pokračuj
    			if (isset ($row[0])) {
    				$rows= array ();
    				// a získej přechozí úroveň menu
    				for ($i=0; $i < count($menu); $i ++) {
    					if ($menu[$i]["parent"] == $row[0]["parent"]) {
    						array_push($rows, $menu[$i]);
    					}
    				}
    			// Jinak menu ukonči
    			} else {
    				return;
    			}
    			//Zjisti, kde jsme v přechozí úrovni zkončili
    			$next= array_pop($oldn);
    			//Dokud neexistuje další položka v předcozí úrovni jdi nahoru
    			while (!(isset ($rows[$next +1]))) {
    				$row= array ();
    				// a získej  předka v předchozí úrovni
    				for ($i= 0; $i < count($menu); $i ++) {
    					if ($menu[$i]["menu_id"] == $rows[$next]["parent"]) {
    						array_push($row, $menu[$i]);
    					}
    				}
    				$rows= array ();
    				// Získej předchozí úroveň
    				for ($i= 0; $i < count($menu); $i ++) {
    					if ($menu[$i]["parent"] == $row[0]["parent"]) {
    						array_push($rows, $menu[$i]);
    					}
    				}
    				// a zjisti, kde jsme v ní zkončili
    				$next= array_pop($oldn);
    				//odečti čislo úrovně
    				-- $level;
    			}
    			menu_rec(-- $level, $maxlevel, $rows, ++ $next, $oldn, $menu);
    		}
    	}
    }
    

    Celé menu volám ze stránky pomocí funkce showmenu()

    Menu je pak uloženo v takové tabulce:
    mysql> SELECT * FROM menu;
    +---------------+------------------------------------------------+---------+---------+----------+--------+-------+
    | title         | url                                            | type    | menu_id | position | parent | level |
    +---------------+------------------------------------------------+---------+---------+----------+--------+-------+
    | Návody       | com=article&task=lists&cat=2           | article |      16 |        2 |      0 |     0 |
    | test          | com=article&task=listp&cat=1&cat=6 | article |      15 |        1 |      0 |     0 |
    | UpozornÄí\ | com=article&task=listp&cat=1           | article |      12 |        0 |      0 |     0 |
    | test1         | com=article&task=listp&cat=1           | article |      21 |        0 |     15 |     1 |
    | test3         | com=article&task=listp&cat=2           | article |      22 |        0 |     21 |     2 |
    | ahoj          | com=article&task=listp&cat=6           | article |      23 |        0 |      0 |     0 |
    | ahoj2         | com=article&task=listp&cat=6           | article |      24 |        0 |     23 |     1 |
    | ahoj3         | com=article&task=listp&cat=2           | article |      25 |        0 |     23 |     1 |
    | ahoj4         | com=article&task=lists&cat=2           | article |      26 |        0 |     25 |     2 |
    | ahoj5         | com=article&task=listp&cat=6           | article |      27 |        0 |     24 |     2 |
    | ahoj6         | com=article&task=listp&cat=2           | article |      28 |        0 |     23 |     1 |
    | test5         | com=article&task=listp&cat=1&cat=6 | article |      32 |        1 |     22 |     3 |
    | test4         | com=article&task=listp&cat=1&cat=6 | article |      31 |        0 |     22 |     3 |
    +---------------+------------------------------------------------+---------+---------+----------+--------+-------+
    
           

    Hodnocení: 100 %

            špatnédobré        

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

    Komentáře

    Vložit další komentář

    xxx avatar 11.1.2007 13:13 xxx | skóre: 42 | blog: Na Kafíčko
    Rozbalit Rozbalit vše Re: php menu
    V php se nevyznam, ale v ty db mas redundanci. Ve sloupci url mas com=article, pricemz tam mas pak jeste sloupec type.
    Please rise for the Futurama theme song.
    11.1.2007 13:43 filbar | skóre: 36 | blog: Denicek_programatora | Ostrava
    Rozbalit Rozbalit vše Re: php menu
    Mám to tam proto, abych v jiné částí kódu nemusel parsovat to url, kvůli zjištění typu komponenty.
    xxx avatar 11.1.2007 13:58 xxx | skóre: 42 | blog: Na Kafíčko
    Rozbalit Rozbalit vše Re: php menu
    Ale to url, lze cele sestavit z tech ostatnich sloupcu.
    Please rise for the Futurama theme song.
    xxx avatar 11.1.2007 14:08 xxx | skóre: 42 | blog: Na Kafíčko
    Rozbalit Rozbalit vše Re: php menu
    Teda ne uplne cele, ale cast. Tudiz jsem to myslel tak, ze by ten dotaz mel byt spise SELECT CONCAT('com=',CONCAT(type,zbytekurl)) FROM tabulka. (Nevim jak presne se ty sloupce a tabulka jmenuji). Protoze si predstav, ze zmenis typ nektere polozky.
    Please rise for the Futurama theme song.
    11.1.2007 14:30 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: php menu
    select 'com=' || type || zbytekurl from tabulka

    btw, v tom prípade by mal celú url skladať zo dát (a pridať stĺpce)
    11.1.2007 13:45 Lu-Tze | skóre: 15 | blog: Lu-Tzeho blog
    Rozbalit Rozbalit vše Re: php menu
    Spíš se mi zdá, že je tam zbytečná položka level.
    11.1.2007 18:57 Käyttäjä 11133 | skóre: 58 | blog: Ajattelee menneisyyttä
    Rozbalit Rozbalit vše Re: php menu
    Proč sis vytvořil nový profil?
    11.1.2007 19:02 Lu-Tze | skóre: 15 | blog: Lu-Tzeho blog
    Rozbalit Rozbalit vše Re: php menu
    Protože jsem blázen. Na druhou stranu si to uvědomuju, takže možná blázen nejsem. Asi jenom chvilkama.
    11.1.2007 19:19 Käyttäjä 11133 | skóre: 58 | blog: Ajattelee menneisyyttä
    Rozbalit Rozbalit vše Re: php menu
    Hmm zrovna tebe jsem za blázna nikdy nepovažoval, ale co se dá dělat. :-) Kdyby si chtěl pokecat napiš na jabber. ;-)
    12.1.2007 11:36 Aleš Kapica | skóre: 52 | blog: kenyho_stesky | Ostrava
    Rozbalit Rozbalit vše Re: php menu
    Musím říct že mě od tebe nic tak nepobavilo jako tohle. Fakt to cením.
    11.1.2007 17:02 Goffix | skóre: 25 | blog: Powered by ArchLinux | Hradec Králové
    Rozbalit Rozbalit vše Re: php menu
    Myslim, ze celej ten sloupec s URL je takovej divnej a zbytecnej. Co takhle ukladat ten typ, cislo clanku a popripade dalsi veci ze kterych se bude skladat url, kazdou informaci do jednoho sloupce. URL pak z toho jednoduse poskladas.

    Jo a btw, zajimalo by me co sledujes napriklad tim com=article&task=listp&cat=1&cat=6. Promenna cat bude mit ve vysledku stejne hodnotu 6. Pokud by si to chtel cpat do pole, tak by si to musel oznacit v url jako cat[].
    11.1.2007 17:17 filbar | skóre: 36 | blog: Denicek_programatora | Ostrava
    Rozbalit Rozbalit vše Re: php menu
    S tím jsem si pohrál a neberu tu url přes $_GET["cat"], ale přes $_SERVER["REQUEST_URI"] a to pársuju pomocí tohoto kódu:
    case "lists" :
    		$url= clean($_SERVER["REQUEST_URI"]);
    		$url= ereg_replace("(.*)(\?)", "", $url);
    		$cats= array ();
    		$cats= split("&", $url);
    		$sql= "SELECT cat_id FROM category";
    		$rows= dbcon($sql);
    		foreach ($rows as $row) {
    			if (in_array("cat=".$row["cat_id"], $cats)) {
    				$sql1= "SELECT con_id, title, pretxt FROM content WHERE state='1' AND cat_id=\"".$row["cat_id"]."\" ORDER BY con_id DESC";
    				$rows1= dbcon($sql1);
    				foreach ($rows1 as $row1) {
    					echo "<h4><a href=\"index.php?com=article&task=view&id=".$row1["con_id"]."\">".$row1["title"]."</a></h4>";
    				}
    			}
    		}
    		break;
    
    Pokud by si to chtel cpat do pole, tak by si to musel oznacit v url jako cat[].
    To by mě docela zajímalo jak, abych to nemusel řešit tím složitým procházením URL, protože jak dát do url a do databáze PHP pole, na to jsem ještě nepřišel.
    11.1.2007 21:20 Goffix | skóre: 25 | blog: Powered by ArchLinux | Hradec Králové
    Rozbalit Rozbalit vše Re: php menu
    To je prasarna ;-).

    Co jak? Kdyz zadas v URL neco jako index.php?test[]=a&test[]=b, tak ti v php vznikne pole $test = array('a', b'). Proc to cpat do databaze nechapu, ale pole tam nacpes napriklad pres funkci serialize.

    Jo a neodpovedel jsi proc cpes do DB tu celou URL a ne jen ty casti jak jsem napsal? Tohle je fakt hrozny a do budoucna spatne pouzitelny.
    11.1.2007 22:30 filbar | skóre: 36 | blog: Denicek_programatora | Ostrava
    Rozbalit Rozbalit vše Re: php menu
    S tou celou url v DB jsem se inspiroval u Joomly, ve které mám svoje stránky. ;-)

    A k poli v DB, to znamená, že pro veřejnou část, kde to mám v URL jako test[]=a&test[]=b jsem to teda vyřešil přes $_GET["test"].

    Ale jak v admin části, abych to pole nemusel pársovat čísla kategorií jako v příspěvku výše?

    Mám použít (un)serialize, nebo existuje nějaká možnost jak ze zápisu test[]=a&test[]=b zpětně zrekonstruovat pole?
    12.1.2007 17:23 Goffix | skóre: 25 | blog: Powered by ArchLinux | Hradec Králové
    Rozbalit Rozbalit vše Re: php menu
    Ja vubec nevim vo cem to tu tocis :-)

    Ja myslel, ze kdyz zacinas, tak chces rady? To, ze jsi se inspiroval v nejake jine aplikaci neznamena, ze je to nejlepsi postup. Furt nechapu co se snazis cpat za blbosti do DB. Kdyby si to udelal, jak jsem psal ja i jini vyse, tak muzes nejaky parsovani vyhodit a mas hned zivot jedndussi ;-).
    11.1.2007 14:39 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: php menu
    >nešlo by to zjednodušiť? napr niečo ako:
                      
    function showmenu () {
        $sql= "SELECT * FROM menu ORDER BY parent, position, menu_id";
        $menu = dbcon($sql);
    
        $menu_def = array (0 => array ('-children' => array ()));
    
        foreach ($menu as $row) {
            $menu_def[ $row['menu_id'] ] = $row;
            if (! array_key_exists ('-children', $menu_def[ $row['parent'] ]))
                $menu_def[ $row['parent'] ]['-children'] = array ();
            array_push ($menu_def[ $row['parent'] ]['-children'], $row['menu_id']);
        }
    
        echo '<table>';
        menu_rec ($menu_def, 0);
        echo '</table>';
    }
    
    function menu_rec ($menu_def, $id) {
        $entry = $menu_def[ $id ];
    
        if (array_key_exists ('title', $entry)) {
            echo '<tr><td>';
            echo '<a href="index.php?' . $entry['url'] . '">' . $entry['title'] . '</a>';
            echo '</td></tr>';
            echo "\n";
        }
    
        if (array_key_exists ('-children', $entry)) {
            foreach ($entry['-children'] as $next_id) {
                menu_rec ($menu_def, $next_id);
            }
        }
    }
    
    php nemám, ani mať nebudem, možno som ani pôvodné zadanie správne neprelúštil
    btw, tabuľky? fuj
    11.1.2007 19:22 12345 | skóre: 41 | blog:
    Rozbalit Rozbalit vše Re: php menu
    Drobná poznámka – zbytečně používáš double quoted řetězce na místech, kde je vůbec není nutné parsovat (indexy polí, SQL,…). Viz http://www.php.net/manual/en/language.types.string.php.
    11.1.2007 19:24 12345 | skóre: 41 | blog:
    Rozbalit Rozbalit vše Re: php menu
    A ještě rýpnutí – skončili ;-)
    Daniel Kvasnička ml. avatar 11.1.2007 22:26 Daniel Kvasnička ml. | skóre: 52 | blog: The Joys and Sorrows of Being an IT Freak | Ostrava
    Rozbalit Rozbalit vše Re: php menu
    Uz jsem tady i jinde videl par uchylnych pripadu pouziti databaze, ale co je moc, to je moc. Tohle je snad ten nejtypictejsi pripad pro pouziti XML sitemapy a renderovani menu pomoci XSLT. Nechapu k cemu takovahle monstrozni konstrukce...
    FSF: “screw you for not wanting the stuff we produce”, People: “screw you for not producing the stuff we want."
    11.1.2007 22:38 filbar | skóre: 36 | blog: Denicek_programatora | Ostrava
    Rozbalit Rozbalit vše Re: php menu
    S programováním PHP+SQL teprve začínám (toto je moje první větší aplikaceú a co se týče mých informací o PHP, tak ty pocházejí z PHP a MySQL:Vytváříme webové databázové aplikace od O'REILLY a Computer Pressu a tady toto programuji, abych se v PHP naučil dělat.;-)

    Kde bych teda mohl ty informace o XML sitemapách a renderování pomocí XSLT mohl najít? Stačí jenom nějaký link na nasměrování. A šlo by to použít i pro diskusní fórum s thready(které si taky chci vyzkoušet udělat)? Protože jsem tuto "monstrózní" konstrukci použil, že se bude hodit i pro fórum.
    No bud si muzes vytvorit svuj XML format pro sitemapu nebo pouzit (resp. rozsirit) oficialni XML Sitemaps protokol od Google, MS a Yahoo (ktery bys stejne pouzivat mel -- tedy pro prezentace, ktere chces, aby Google bral na vedomi). Nicmene ten googli neni tak uplne delany na generovani menu -- osobne ho pouzivam jen pro google.

    O zadnem konkretnim clanku konkretne o renderovani XML sitemap pomoci XSLT nevim, ale pres Google urcite najdes tuny dobrych tutorialu o XSLT (obecne moc dobry server na veci kolem XML je Zvon.org a tamni paradni XSLT reference). Zasadni vyhoda XML v tomto pripade je schopnost zaznamenat tu hierarchicnost (to co ty zaznamenavas polem "parent").
    FSF: “screw you for not wanting the stuff we produce”, People: “screw you for not producing the stuff we want."
    Josef Kufner avatar 13.1.2007 15:39 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: php menu
    Pak se nabízí ještě jedna značně primitivní, ale pravděpodobně naprosto dostačující možnost:
    $main_menu = array (
       'neco.php?bla+bla' => 'Nadpis',
       array(
          'bla.php' => 'Podnadpis',
          ...
       ),
       'dalsi.php' => Jiny nadpis,
       ...
    );
    
    Hello world ! Segmentation fault (core dumped)

    Založit nové vláknoNahoru

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