Byla vydána (𝕏) nová verze 24.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 24.7 je Thriving Tiger. Přehled novinek v příspěvku na fóru.
Binarly REsearch upozorňuje na bezpečnostní problém PKFail (YouTube) v ekosystému UEFI. Stovky modelů zařízení používají pro Secure Boot testovací Platform Key vygenerovaný American Megatrends International (AMI) a jeho privátní část byla při úniku dat prozrazena. Do milionů zařízení (seznam v pdf) po celém světě tak útočníci mohou do Secure Bootu vložit podepsaný malware. Otestovat firmware si lze na stránce pk.fail. Ukázka PoC na Linuxu na Windows na YouTube.
Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.2 (Mastodon, 𝕏). Přehled novinek na GitLabu. Vypíchnuta je rodičovská kontrola.
Společnost OpenAI představila vyhledávač SearchGPT propojující OpenAI modely umělé inteligence a informace z webů v reálném čase. Zatím jako prototyp pro vybrané uživatele. Zapsat se lze do pořadníku čekatelů.
Distribuce Linux Mint 22 „Wilma“ byla vydána. Je založená na Ubuntu 24.04 LTS, ale s desktopovým prostředím Cinnamon (aktuálně verze 6.2), příp. MATE nebo Xfce, balíkem aplikací XApp, integrací balíčků Flatpak a dalšími změnami. Více v přehledu novinek a poznámkách k vydání.
Příspěvek na blogu Truffle Security: Kdokoli může přistupovat ke smazaným a privátním repozitářům na GitHubu.
Byla vydána nová verze 14 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v cgitu. Vypíchnout lze podporu rozšíření v Lua.
Byla vydána verze 1.80.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.
Apple oznámil, že v beta verzi spustil své Apple Maps na webu. Podporován je také webový prohlížeč Chrome. Ne však na Linuxu.
Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 65 tisíc vývojářů. Z Česka jich bylo 710. Ze Slovenska 246.
print_r($stmt->errorinfo());a i když se všechno uloží, přesto je na výstupu tohle
Array ( [0] => 00000 [1] => [2] => )Jedná se o chybu nebo jen o nějaký informační výsledek? Jak můžu udělat vypsání chyb pokud nějaká nastane? Děkuji
Řešení dotazu:
errorinfo()
se volá pouze v případě, kdy nějaká chyba vznikla. Viz manuál.
$stmt = $dbh->prepare('bogus sql'); if (!$stmt) { print_r($dbh->errorInfo()); }Ve svých aplikacích si to však zjednodušuji:
if(!($stmt = $dbh->prepare('bogus sql')) throw new Exception('Chybný dotaz SQL');
$stmt = $pdo->prepare("INSERT INTO `reg` (`a`, `b`, `c`, `d`, `e`) VALUES (?,; ?,; ?,; now(),; 1;)"); $stmt->execute(array($_POST['a'], $_POST['b'], $_POST['c'], $_POST['e'])); if (!$stmt) { print_r($pdo->errorInfo()); }
$stmt = $pdo->prepare("INSERT INTO `reg` (`a`, `b`, `c`, `d`, `e`) VALUES (?,; ?,; ?,; now(),; 1;)"); if (!$stmt) { print_r($pdo->errorInfo()); } $result=$stmt->execute(array($_POST['a'], $_POST['b'], $_POST['c'], $_POST['e'])); if (!$result) { print_r($stmt->errorInfo()); }
array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION)
. Nemusíš se pak piplat s if() a print_r(), prostě jen píšeš příkazy a nic netestuješ.
Máš špatně ten INSERT. Ty středníky mezi otazníky tam nepatří.Nepatří tam tedy ani jeden středník?
Veškeré starosti s chybami v PDO se dají elegantně vyřešit..Tak že celý konstruktor bude takto?
$pdo = new PDO ('mysql:host='.$host.';dbname='.$db.';charset=UTF-8', $user, $password, array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES UTF8"), array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION));A jak pak zjistím, že nastala chyba? když nebudu psát žádnou if()? Dík BTW: Můžu si dovolit jeden osobní dotaz?
try{ $pdo = new PDO('mysql:host='.$host.';dbname='.$db.';charset=UTF-8', $user, $password, array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES UTF8", PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION)); $stmt = $pdo->prepare("INSERT INTO `reg` (`a`, `b`, `c`, `d`, `e`) VALUES (?, ?, ?, now(), 1);"); $stmt->execute(array(1,2,3)); } catch(PDOException $e) { echo $e->getMessage(),"\n",$e->getTraceAsString(),"\n"; }Osobní dotaz? Jsme na veřejném fóru. Ptej se na co chceš a já odpovím, na co budu chtít.
Tiskni
Sdílej: