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í
×
    dnes 14:22 | IT novinky

    Společnost Proton AG stojící za Proton Mailem a dalšími službami přidala do svého portfolia AI asistenta Lumo.

    Ladislav Hagara | Komentářů: 4
    dnes 12:22 | IT novinky

    Amazon koupil společnost Bee zaměřenou na nositelnou osobní AI aktuálně nabízející náramek Pioneer (YouTube) s mikrofony zaznamenávající vše kolem [𝕏, LinkedIn].

    Ladislav Hagara | Komentářů: 5
    dnes 04:33 | IT novinky

    Společnost Teufel nedávno představila svůj první open source Bluetooth reproduktor MYND.

    Ladislav Hagara | Komentářů: 5
    včera 20:00 | Nová verze

    Byla vydána verze 4.2 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.

    Ladislav Hagara | Komentářů: 0
    včera 19:33 | IT novinky

    Anton Carniaux, právní zástupce Microsoft France, pod přísahou: Microsoft nemůže garantovat, že data z EU nepředá do USA bez EU souhlasu, musí dodržovat americké zákony.

    Ladislav Hagara | Komentářů: 25
    včera 15:33 | Nová verze

    Byl vydán Mozilla Firefox 141.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Lokální AI umí uspořádat podobné panely do skupin. Firefox na Linuxu využívá méně paměti. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 141 je již k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    21.7. 22:44 | Bezpečnostní upozornění

    NÚKIB upozorňuje na kritickou zranitelnost v SharePointu. Jedná se o kritickou zranitelnost typu RCE (remote code execution) – CVE-2025-53770, která umožňuje neautentizovaný vzdálený přístup a spuštění kódu, což může vést k úplnému převzetí kontroly nad serverem. Zranitelné verze jsou pouze on-premise verze a to konkrétně SharePoint Server 2016, 2019 a Subscription Edition. SharePoint Online (Microsoft 365) není touto zranitelností ohrožen.

    Ladislav Hagara | Komentářů: 4
    21.7. 21:00 | IT novinky

    Společnost Valve zpřísnila pravidla pro obsah, který je možné distribuovat ve službě Steam. Současně řadu her ze Steamu odstranila. V zásadách a pravidlech přibylo omezení 15: Obsah, který by mohl porušovat pravidla a normy stanovené zpracovateli plateb a souvisejícími sítěmi platebních karet a bankami nebo poskytovateli připojení k internetu. Sem spadají zejména určité druhy obsahu pouze pro dospělé.

    Ladislav Hagara | Komentářů: 0
    21.7. 13:33 | Komunita

    Dle analytics.usa.gov je za posledních 90 dnů 6,2 % přístupů k webových stránkám a aplikacím federální vlády Spojených států z Linuxu.

    Ladislav Hagara | Komentářů: 0
    20.7. 17:44 | Zajímavý článek

    Jak si zobrazit pomocí Chrome a na Chromiu založených webových prohlížečích stránky s neplatným certifikátem? Stačí napsat thisisunsafe.

    Ladislav Hagara | Komentářů: 3
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (27%)
     (24%)
     (3%)
     (7%)
     (4%)
     (2%)
     (3%)
     (29%)
    Celkem 90 hlasů
     Komentářů: 12, poslední dnes 16:25
    Rozcestník

    Dotaz: Zjištění chyby při neúspěchu fwrite()

    30.6.2018 15:22 andreaw.fean
    Zjištění chyby při neúspěchu fwrite()
    Přečteno: 2342×
    Ahoj.

    Načítám celkem velký objem dat (několik giga) po kouskách o velikosti typicky 2096 bajtů. A následně ho zapisuju do souboru v tempu:
    $tmpdir = sys_get_temp_dir();
    $tmpname = tempnam($tmpdir, 'app-');
    $handle = fopen($tmpname, 'a');
     
    // velikost $s je obvykle 2096 bajtů
    function write($s) 
    {
        $len = strlen($s);
        $wrote = fwrite($handle, $s);
        if ($len !== $wrote) {
            echo "\n\nERROR: Nesedí počet zapsaných bytů. C1 {$wrote} ~ {$len}\n\n"; // "419 ~ 2096"
            var_dump(error_get_last()); // nic
     
            $wrote2 = fwrite($handle, substr($s, $wrote));
            if ($wrote2 !== ($len - $wrote)) {
                echo "\n\n{$s}\n\n"; // zde vidím, že to není poslední záznam. Je to uřízlé uprostřed textu.
                throw new RuntimeException('Nesedí počet zapsaných bytů. C2 ' . "{$wrote2} ~ " . ($len - $wrote) ); // "0 ~ 1677"
            }
        }
    }
    
    Celé mi to chcípne na tom, že nesedí počet zapsaných bajtů. Je možné, že mi třeba došlo místo v tempu, nebo tak něco. Ale vadí mi, že mi to nevypíše žádnou chybu.

    Otázka tedy zní, jak zjistím, co se stalo?

    Děkuji za odpověď.

    Odpovědi

    30.6.2018 16:46 rastos | skóre: 63 | blog: rastos
    Rozbalit Rozbalit vše Re: Zjištění chyby při neúspěchu fwrite()
    Ak je to PHP, tak fwrite() returns the number of bytes written, or FALSE on error.

    A tipujem, že je to len wrapper pre fwrite(), kde sa píše detailnejšie: If an error occurs, or the end of the file is reached, the return value is a short item count (or zero).

    fread() does not distinguish between end-of-file and error, and callers must use feof(3) and ferror(3) to determine which occurred.
    30.6.2018 19:13 Fean
    Rozbalit Rozbalit vše Re: Zjištění chyby při neúspěchu fwrite()
    Ano, PHP

    Funkci ferror jsem nenašel. A ty http://php.net/manual/en/function.posix-errno.php vraceli úspěch, i když to úspěch nebyl.
    1.7.2018 09:48 Odin
    Rozbalit Rozbalit vše Re: Zjištění chyby při neúspěchu fwrite()
    Nemuze to byt tim, ze phpkovy strlen ukonci pocitani, kdyz narazi na bajt s hodnotou nula? Ale fwrite opravdu zapise vsechno, a tedy i to, co se nachazi za nulou? Tim padem by vam ty pocty nesedely. Zkuste si to nasimulovst. Ja se phpku vyhybam jako cert krizi.
    1.7.2018 11:57 Kit | skóre: 45 | Brno
    Rozbalit Rozbalit vše Re: Zjištění chyby při neúspěchu fwrite()
    Funkce fwrite() sice zapíše všechno, ale vyhýbám se jí, protože se chová divně při souběhu a zámky používat nechci. PHP je sice silně zatížené historií, ale při využívání jeho pokročilých vlastností je to efektivní nástroj.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    2.7.2018 00:44 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Zjištění chyby při neúspěchu fwrite()
    Jestli jsou to gigabyty, otázka je, proč to nenapsat rovnou v C. Na rozdíl od PHP má standardní (kni)hovna C nejen funkci feof(), ale také funkci ferror(). Pak najednou fwrite() začne dávat smysl.

    A ještě jednodušší může být nemořit se s podivnou abstrakcí ve standardní C (kni)hovně a místo toho použít rovnou POSIXový read() a write() se správnou velkostí bufferu a s naprosto přesně definovanými chybovými hlášeními v proměnné errno. Taky si pak člověk může nastavit různé vlastnosti souboru / deskriptoru a případně provádět operace asynchronně, tedy například mít bufferů několik, a použít klasický přístup typu producent/konzument s kruhovou frontou. Něco takového se s FILE* API dělá o poznání obtížněji.

    3.7.2018 15:53 Fean
    Rozbalit Rozbalit vše Re: Zjištění chyby při neúspěchu fwrite()
    Tak jsem se dozvěděl, že to podle všeho nejde nijak zjistit. Pokud fwrite() nemůže zapsat, protože typicky došlo místo, tak vrátí 0, a nikde nic nenastaví. Žádnou chybovku, nic. Funkce error_get_last() mlčí.
    3.7.2018 20:18  
    Rozbalit Rozbalit vše Re: Zjištění chyby při neúspěchu fwrite()
    Bodejť by ne, PHP znamená Prasomrdský hovnokód procesor a používají ho dementi typu MzK a jemu podobných.
    3.7.2018 22:11 Odin
    Rozbalit Rozbalit vše Re: Zjištění chyby při neúspěchu fwrite()
    Spise se obavam, ze poustet strlen na binarni data je z principu blbost. :-D

    Založit nové vláknoNahoru

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

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