Stanislav Fort, vedoucí vědecký pracovník z Vlčkovy 'kyberbezpečnostní' firmy AISLE, zkoumal dopady Anthropic Mythos (nový AI model od Anthropicu zaměřený na hledání chyb, který před nedávnem vyplašil celý svět) a předvedl, že schopnosti umělé inteligence nejsou lineárně závislé na velikosti nebo ceně modelu a dokázal, že i některé otevřené modely zvládly v řadě testů odhalit ve zdrojových kódech stejné chyby jako Mythos (například FreeBSD CVE-2026-4747) a to s výrazně nižšími provozními náklady.
Federální návrh zákona H.R.8250 'Parents Decide Act', 13. dubna předložený demokratem Joshem Gottheimerem a podpořený republikánkou Elise Stefanik coby spolupředkladatelkou (cosponsor), by v případě svého schválení nařizoval všem výrobcům operačních systémů při nastavování zařízení ověřovat věk uživatelů a při používání poskytovat tento věkový údaj aplikacím třetích stran. Hlavní rozdíl oproti kalifornskému zákonu AB 1043 a kolorádskému SB26-051 je ten, že federální návrh by platil rovnou pro celé USA.
Qwen (čínská firma Alibaba Cloud) představila novou verzi svého modelu, Qwen3.6‑35B‑A3B. Jedná se o multimodální MoE model s 35 miliardami parametrů (3B aktivních), nativní kontextovou délkou až 262 144 tokenů, 'silným multimodálním vnímáním a schopností uvažování' a 'výjimečnou schopností agentického kódování, která se může měřit s mnohem rozsáhlejšími modely'. Model a dokumentace jsou volně dostupné na Hugging Face, případně na čínském Modelscope. Návod na spuštění je už i na Unsloth.
Sniffnet, tj. multiplatformní (Windows, macOS a Linux) open source grafická aplikace pro sledování internetového provozu, byl vydán ve verzi 1.5. V přehledu novinek je vypíchnuta identifikace aplikací komunikujících po síti.
V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 15.0 (Mastodon). Forgejo je fork Gitei.
Současně se SUSECON 2026 proběhne příští čtvrtek v Praze také komunitní Open Developer Summit (ODS) zaměřený na open source a openSUSE. Akce se koná ve čtvrtek 23. 4. (poslední den SUSECONu) v Hilton Prague (místnost Berlin 3) a je zcela zdarma, bez nutnosti registrace na SUSECON. Na programu jsou témata jako automatizace (AutoYaST), DevOps, AI v terminálu, bezpečnost, RISC-V nebo image-based systémy. Všichni jste srdečně zváni.
Český úřad zeměměřický a katastrální zavedl u anonymního nahlížení do katastru nemovitostí novou CAPTCHA ve formě mapové puzzle: nepřihlášení uživatelé musí nově správně otočit devět dlaždic v 3x3 poli tak, aby dohromady daly souvislý obrázek výseče reálné mapy, přičemž na to mají pouze jeden časově omezený pokus. Test je podle uživatelů i odborníků příliš obtížný a na sociálních sítích pochopitelně schytává zaslouženou kritiku a
… více »Byla vydána verze 1.95.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Mozilla prostřednictvím své dceřiné společnosti MZLA Technologies Corporation představila open-source AI klienta Thunderbolt. Primárně je určený pro firemní nasazení.
Firma Cal.com oznámila, že přesouvá svůj produkční kód z otevřeného do uzavřeného repozitáře z důvodu bezpečnostního rizika umělé inteligence, která prý dokáže vyhledávat a zneužívat zranitelnosti rychleji, než by je jejich vývojářský tým stíhal opravovat. Zároveň zveřejnila samostatnou, open-source verzi Cal.diy pod licencí MIT, ovšem bez řady původních funkcí. O tom, zda je toto opatření rozumné, existují pochyby. … více »
Zdravim, doteraz pouzivam na dynamicke nastavovanie meta tagov output buffering, co nie je najlepsia volba, vzhladom na spotrebu pamate. Preto hladam nejaky menej narocny sposob na to, aby som mohol vypisovat tieto udaje. Udaje mam uloztene v MySQL databazi a problem je ten, ze celu sekciu HEAD mam nastavenu v header.php a tym padom uz neviem vypisat title, ktory je nastaveny v stranke.
<?php
include "header.php";
include "stranka.php";
include "footer.php";
?>
Ako by som toto mohol riesit? Dakujem.
Možná jen špatně chápu, o co vám jde, ale co si prostě ještě před prvním include nadpis uložit do proměnné (např.) $title?
<?php
include "common.php";
header('Titulek stránky');
echo "tělo stránky";
footer();
?>
Není to úplně ideální a brzy narazíš na omezení i tohoto přístupu, ale do doby než prozkoumáš šablonovací nástroje či rovnou nějaké hotové CMS, ti to asi bude stačit. Pokud to chceš udělat pořádně, podívej se na nějaký pěkný framework.
header() pojmenoval jinak kvůli kolizi.
Jinak tuto techniku jsem dost používal, než jsem přešel na objekty. Mělo to výhodu, že i když někdo uhodl název includovaného souboru a vložil jeho adresu do prohlížeče, nic se neprovedlo.
<?php include "headers.php"; $set_title='Titulek stránky';//případně vyměnit za array include "head.php"; //body include "foot.php";a v
head.php
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN" "http://www.w3.org/TR/1998/REC-html40-19980424/strict.dtd" >
<html lang="cs">
<head>
<title><?php echo $set_title;?> </title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
...
OT: pojmenováni fce header není nejvhodnější
<?php
function tpl_header($data) {
extract($data); // podle klíčů v $data jsou nadefinovány lokální proměnné
echo 'Hello ', $user, '!';
?>
Nějaký větší kus HTML, kde je málo
kusů PHP, protože to je znatelně pomalejší.
<?php
}
Použití takové šablony je pak jednoduché. Na začátku souboru, kde je použita se udělá jednou require a pak se jen volá funkce, kolikrát je libo:
require 'tpl/header.php';
// ... hromada užitečného kódu
// a nakonec:
tpl_header(array(
'user' => $user_name,
));
Výhodou tohoto je i možnost spojit všechny šablony do jednoho souboru... stačí odstranit první řádek (php tag není uzavřen) a prohnat to catem. A navíc není třeba šablony nijak chránit, protože v nich není nic, co by něco dělalo samo od sebe.
) můžeme debatovat, ono to řešení pře funkce bez class-ů je, dle mého, takové na půl cesty.headers.php do head.php by bylo dost divné, oba by měli jen vstřebávat.$set_title, bo pak je to jedinečné konfigurační pole např.
$glb_setting=Array(headers=>Array('Content-Type: text/html; charset=utf-8'),/*http headers*/
title='Můj title', /*page title*/
robots='index,follow',/*meta robot*/);
které je definováno jako první. Což je taky takové nic moc, bo to není nějaký class.<?php /*inicializace PHP, načtení potřebné konfigurace třeba do array*/ require_once "init.php"; /*věci jako nové proměnné do session, případně změna hlavičky obsahu, mění title, klíčová slova apod*/ require_once "preswicth.php"; /*http hlavičky*/ require_once "headers.php"; /*začátek dokumentu*/ require_once "head.php"; /*obsah, který pravděpodobně include-uje dále*/ require_once "mainswicth.php"; /*ukončení dokumentu*/ require_once "foot.php";nevidím nic špatného a může být někdy i přehlednější než (včetně „funkcionálního“ ekvivalentu):
<?php
require_once "base.php";
require_once "session.php";
require_once "doc.php";
require_once "form.php";
require_once "acontent.php";
$init_array=Array();
require_once "init.php";
Base::Init($init_array);
unset($init_array);
Form::ParseGetPost(/*$_GET,$_POST,$_SESSION*/);
Session::SetSession();
Doc::PrintHeaders();
Doc::PrintBeginDoc();
try{
if($cntnt = Form::GetContentObj())
$cntnt->sendStdBody();
else Doc::PrintTextError('Fatal error');
}catch(Exception $e){
Doc::PrintExceptionError($e);
}
Doc::PrintEndDoc();
PS: obě struktury jsem si teď vymyslel
$stranka=new ViewHTML();
$stranka->setObsah($_REQUEST['strana']);
$stranka->setMenu('filtr');
$stranka->setTitle('Titulek webu');
$stranka->addCSS('style.css');
echo $stranka;
Hlavička i patička se generuje až na posledním řádku, kdy jsou k dispozici všechny datové komponenty a vím, že se nějaká stránka generovat bude.
Tiskni
Sdílej: