Bylo vydáno OpenBSD 7.9. Po dlouhé době opět se songem: Diamond in the Rough.
Dnes a zítra probíhá vývojářská konference Google I/O 2026. Sledovat lze na YouTube a na síti 𝕏 (#GoogleIO).
Byl vydán Mozilla Firefox 151.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 151 bude brzy k dispozici také na Flathubu a Snapcraftu.
Elon Musk prohrál soudní spor se společností OpenAI, která se podle jeho žaloby odchýlila od původně uváděného cíle vyvíjet umělou inteligenci (AI) ku prospěchu lidstva. Porota včera po necelých dvou hodinách dospěla k jednomyslnému závěru, že Musk žalobu podal příliš pozdě. Musk byl jedním ze spoluzakladatelů společnosti OpenAI, která vznikla v roce 2015 a vyvinula populární chatovací systém ChatGPT. V roce 2018 na svůj post ve vedení
… více »Byla vydána nová verze 10.4 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Opraveny jsou zranitelnosti Copy Fail a Dirty Frag. Přibyl nový obraz pro Orange Pi 5B.
Pokud je zranitelnost Linuxu v nepoužívaném jaderném modulu, lze ji jednoduše vyřešit zakázáním automatického načítání tohoto konkrétního zranitelného modulu. Projekt ModuleJail si klade za cíl zvýšit bezpečnost Linuxu zakázáním automatického načítání všech nepoužívaných jaderných modulů. Jedná se o skript, který dá všechny nepoužívané jaderné moduly na blacklist (/etc/modprobe.d/modulejail-blacklist.conf).
Odborníci z Penn State University zkoumají způsob ukládání informací na lepicí pásku. Principiálně by podle nich bylo možné kombinací odlepení a zpětného přilepení dosáhnout uložení informace, kterou opětovným odlepením dokážou přečíst. Výhodou je, že způsob uložení i přečtení je čistě mechanický. Zde o tom referují ve volně dostupném článku. Zajímavé bude sledovat zda se jim v rámci výzkumu podaří prokázat použitelnost i v jiné než
… více »Na GitHubu byl publikován reprodukovatelný návod, jak rozchodit Adobe Lightroom CC na Linuxu a Wine. Návod byl vytvořený pomocí AI Claude Code.
Pokud by někdo potřeboval Wayland kompozitor uvnitř počítačové hry Minecraft, aby mohl zobrazovat okna desktopových aplikací přímo v herním prostředí, může sáhnout po Waylandcraftu. Ukázka na YouTube.
Uroš Popović v krátkém článku vysvětluje, co jsou emulátor terminálu, TTY a shell a jaké jsou mezi nimi rozdíly. Jde o první díl seriálu na jeho novém webu Linux Field Guide věnovaném nízkoúrovňové práci s linuxovými systémy.
Ještě mám dvě otázky na PHP. V tom softu(viz minulý zápis) zkouším používat komponenty podle tvaru url, takže např.: main.php?com=article&task=edit&item=13 nastartuje komponentu pro psaní článků a editaci položky 13
A problém mám právě s tím com=neco. Prozatím to řeším tak, že z hlavní stránky main.php(ukázka je z admin rozhraní, takže index.php slouží pro přihlášení) zavolám funkci :
$menu= isset ($_GET["com"]) ? $_GET["com"] : NULL; showamenu($menu);, která je definována takto:
function showacontent($com) {
global $basePath;
//To je jenom prozatím, než mě napadne co dát na úvod.
if (is_null($com)) {
echo "domů";
} else {
if (!(file_exists($basePath.'/components/'.$com.'/'.$com.'.php'))) {
msg('NE_COMPONENT', 0);
} else {
include_once $basePath.'/components/'.$com.'/'.$com.'.php';
}
}
}
Tedy pomocí includování různých souborů. Protože se na tom to PHP učím, tak by mě zajímalo, jestli se to dá řešit ještě nějak lépe?
A ještě ta druhá otázka: Když mám html hlavičku definovanou v main.php, dá se nějak upravit v těch komponentách? Něco jsem zahlédnul o ob_start/flush. Pomůžou mi tyto funkce.
Za odpovědi předem děkuji.
Tiskni
Sdílej:
switch($parametr):
case 'p1':
include('./Inc/soubor1.php');
break;
case 'p2':
include('./Inc/soubor2.php');
break;
case 'p3':
include('./Inc/soubor3.php');
break;
default:
echo 'Chybny parametr'; exit;
endswitch;
Samozrejme osetreni chyby atp. je treba napsat tak, aby to bylo podle predstav ...
$map = array ( 'p1' => 'inc/service1.php', 'p2' => 'inc/service2.php', ... );a funkcia
array_key_exists
- "konfiguračný súbor": v tom prípade bude bezpečné, ak budete vstupný parameter kontrolovať, napr, nesmie obsahovať iné znaky ako "[-.a-zA-Z0-9]"
To je něco takového co jsem hledal, akorát že lepší to bude asi dát do databáze, ještě přemýšlím jestli by to nešlo udělat úplně bez includování, že zavolám funki, která se rozhodne zavolá podle com=neco a zavolá to neco.
. Kdybych tam udělal instalátor, tak mi komponentu do databáze přidá jednoduše, zatímco do souboru by už to bylo složitější.
if (!preg_match("/^[a-z0-9\-]+$/i", $parametr)
{
header('HTTP/1.1 404 No hackers please');
exit();
}
<? require_once 'lib/page.php'; $pg = new Page(); $pg->data['text'] = "hello world"; $pg->render(); ?>A v lib/page.php bude veskery kod, ktery uplaca html kod stranky a treba i jednoduchy sablonovaci system. Ten u sveho posledniho webu delam tak, ze lib/page.php si includne template/neco.php, kde je kopec html doplneny o <? echo $d['neco'];?>. Je to jednoduche a prakticke. V sablonach pak muze byt i slozitejsi kod treba na vykresleni tabulky, ale je dobre udrzovat poradek a udrzovat oddelene vykreslovani a logiku aplikace.
<? $pg->data['text'] = "hello world"; ...... ?>index.php:
<?
require_once 'lib/page.php';
$pg = new Page();
require('hello_world.php'); // Zde by mohl byt ten switch, apod...
$pg->render();
?>
Mozna jsem te jen nepochopil, ale takhle mi to osobne vyhovuje mnohem vic a nemusim v kazdym skriptu typu "hello_world.php" psat to same dokola
.
.
PS: Je jasny, ze se o tom moc neda debatovat, jelikoz je to kazdymu podle vkusu
.
.
No jak pisu. Je to dost subjektivni pohled na vec.
No programuju v php uz vic jak 5 let a tak jak to myslis ty, tak jsem to delal driv... vim moc dobre, proc to ted delam jinak
. Ono je to taky hlavne dost o tom, co od te aplikace clovek ocekava.