Byla vydána nová verze 1.12.0 dynamického programovacího jazyka Julia (Wikipedie) určeného zejména pro vědecké výpočty. Přehled novinek v příspěvku na blogu a v poznámkách k vydání. Aktualizována byla také dokumentace.
V Redisu byla nalezena a v upstreamu již opravena kritická zranitelnost CVE-2025-49844 s CVSS 10.0 (RCE, vzdálené spouštění kódu).
Ministr a vicepremiér pro digitalizaci Marian Jurečka dnes oznámil, že přijme rezignaci ředitele Digitální a informační agentury Martina Mesršmída, a to k 23. říjnu 2025. Mesršmíd nabídl svou funkci během minulého víkendu, kdy se DIA potýkala s problémy eDokladů, které některým občanům znepříjemnily využití možnosti prokázat se digitální občankou u volebních komisí při volbách do Poslanecké sněmovny.
Společnost Meta představila OpenZL. Jedná se o open source framework pro kompresi dat s ohledem na jejich formát. Zdrojové kódy jsou k dispozici na GitHubu.
Google postupně zpřístupňuje českým uživatelům Režim AI (AI Mode), tj. nový režim vyhledávání založený na umělé inteligenci. Režim AI nabízí pokročilé uvažování, multimodalitu a možnost prozkoumat jakékoliv téma do hloubky pomocí dodatečných dotazů a užitečných odkazů na weby.
Programovací jazyk Python byl vydán v nové major verzi 3.14.0. Podrobný přehled novinek v aktualizované dokumentaci.
Bylo oznámeno, že Qualcomm kupuje Arduino. Současně byla představena nová deska Arduino UNO Q se dvěma čipy: MPU Qualcomm Dragonwing QRB2210, na kterém může běžet Linux, a MCU STM32U585 a vývojové prostředí Arduino App Lab.
Multiplatformní open source voxelový herní engine Luanti byl vydán ve verzi 5.14.0. Podrobný přehled novinek v changelogu. Původně se jedná o Minecraftem inspirovaný Minetest v říjnu loňského roku přejmenovaný na Luanti.
Byla vydána nová stabilní verze 6.10 (YouTube) multiplatformního frameworku a GUI toolkitu Qt. Podrobný přehled novinek v poznámkách k vydání.
Jsem zakladatelem tohoto portálu. Linux jsem používal spousty let, nějaký čas jsem se aktivně podílel na jeho propagaci v Česku (CZLUG, časopisy ComputerWorld, Network Magazine atd). Se současným Abíčkem už nemám nic společného.
(English summary at the end of the article) Uvažoval jsem, že upgradnu jetty, na kterém běží abíčko, z historické verze 4.1.20 na aktuální. Dlouho jsem se k tomu neměl, nejdříve kvůli chybě jsem měl opatchovanou verzi a nebyl jsem si jist, zda můj patch byl začleněn a pak u řady 5 chyběly startovací skripty. A vůbec, kdo by šťoural do něčeho, co funguje, že? Teď jsem se k tomu dostal, ale po odeslání formuláře jetty 6.0.2 byly znaky s diakritikou zničeny.
Chvíli jsem si s tím tedy hrál v debuggeru a skutečně metoda request.getParameter()
vracela deformovaná data, se kterými překódování pomocí new String(param.getBytes("ISO-8859-1"))
už nic nesvedlo. Zeptal jsem se v konferenci a dostal jsem pár tipů, například request.setEncoding("ISO-8859-2")
nebo System.setProperty("org.mortbay.util.URI.charset","ISO-8859-2")
. Nicméně tyto rady neměly žádný efekt.
Nakonec jsem si napsal testovací webovou aplikaci se servletem, který se dá konfigurovat, jaké kódování má requestu nastavit a dva jsp soubory s dvěma formuláři, které odesílají vstup (žížala) jednou přes POST podruhé přes GET. Jedno jsp bylo v ISO-8859-2 kódování, druhé v UTF-8. A jal jsem se testovat všechny možné kombinace, v jetty řady 4.1 i 6.0 a 6.1. Přitom jsem snifferem zjistil, že Firefox odesílá vstup jinak v závislosti na kódování HTML souboru (jak překvapivé, Watsone). Závěr je, že jetty 4 se chová jinak než jetty 6 a že pod jetty 6 spolehlivě fungují formuláře, pokud jsou ve stránce kódované pomocí UTF8, zato v ISO-8859-2 nefungují spolehlivě nikdy. Detaily najdete v příloze.
When I upgraded jetty from version 4.1.20 to 6.0.2 I found that it damages request parameters. The characters with caron from ISO-8859-2 encoding where replaced by ? character or disappeared at all. The trick with recoding new String(param.getBytes("ISO-8859-1"))
using did not work. I asked in jetty conference and tested few tips without luck: request.setEncoding("ISO-8859-2")
, System.setProperty("org.mortbay.util.URI.charset","ISO-8859-2")
. So I decided to test this topic thouroughly and wrote simple webapp consisting of two same jsp files and servlet dumping the request parameter. The jsp files contained two identical forms sending word 'žížala' either by GET or POST method to the servlet. One jsp file was encoded in UTF-8, the second in ISO-8859-2 encoding. I tested all combinations with both jetty versions and found difference between them. Jetty 6 can reliably accept accented characters if and only if the form was sent from HTML page encoded to UTF-8. When the page was encoded to ISO-8859-2 (latin2), then it is not possible to find setting suitable for both GET and POST methods. Test web application including complete results.
Tiskni
Sdílej:
QueryEncoding
(je to rozčíření Jetty), RequestCharacterEncoding
se u GETu vůbec nebere v úvahu. S následujícíém nastavením mi funguje testLatin2:
import org.mortbay.jetty.Request; ... protected void service(HttpServletRequest request, HttpServletResponse response) throws IOException { if (requestEncoding != null) request.setCharacterEncoding(requestEncoding); (Request)request).setQueryEncoding("iso-8859-2"); String tmp = request.getParameter("note"); String tmp1 = new String(tmp.getBytes("ISO-8859-1")); // this is correct for request locale cs String tmp2 = new String(tmp.getBytes("ISO-8859-2")); String tmp3 = new String(tmp.getBytes("UTF-8")); response.setContentType("text/html; charset=ISO-8859-2"); Writer w = response.getWriter(); ...
decodeQueryTo
třídy org.mortbay.jetty.HttpURI
, musí tam být
public void decodeQueryTo(MultiMap parameters, String encoding) throws UnsupportedEncodingException { if (_query==_fragment) return; if (encoding==null) encoding=URIUtil.__CHARSET; if (StringUtil.isUTF8(encoding)) UrlEncoded.decodeUtf8To(_raw,_query+1,_fragment-_query-1,parameters); else UrlEncoded.decodeTo(StringUtil.toString(_raw,_query+1,_fragment-_query-1,encoding),parameters,encoding); }