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í
×
včera 16:11 | Bezpečnostní upozornění

V Linuxu byla nalezena bezpečnostní chyba CVE-2019-8912. Jedná se o vážnou (CVSS v3.0: 9.8) bezpečnostní chybu typu CWE-416: Use After Free v crypto/af_alg.c. Chyba byla nalezena pomocí detektoru chyb při práci s pamětí KASAN (Kernel Address Sanitizer).

Ladislav Hagara | Komentářů: 5
včera 11:11 | Komunita

Mozilla.cz informuje, že další vydání SeaMonkey se zdrží. Infrastruktura projektu SeaMonkey prochází mnoha změnami. Důvodem je požadavek na nezávislost na infrastruktuře Firefoxu do konce roku, protože jeho vývoj nebude SeaMonkey následovat ve stejném tempu a rozdíly jsou moc veliké. Bohužel se při těchto přesunech nepodařilo udržet vše ve funkčním stavu a tak není možné sestavovat a vydávat nové verze SeaMonkey.

Ladislav Hagara | Komentářů: 0
20.2. 16:55 | Bezpečnostní upozornění

V Drupalu byla nalezena vysoce kritická zranitelnost PSA-2019-02-19. Podrobnosti a opravy 8.5.x a 8.6.x budou zveřejněny dnes mezi 19:00 a 23:00.

Ladislav Hagara | Komentářů: 1
20.2. 16:33 | Zajímavý projekt

Mozilla.cz informuje o stavu češtiny v projektu Common Voice. Projekt Common Voice sbírá hlasová data, na základě kterých bude možné trénovat modely a software pro rozpoznávání řeči. Aktuálně je nutné rozšířit počet vět v datové sadě a alespoň 5 tisíc vět musí být ručně ověřených několika lidmi.

Ladislav Hagara | Komentářů: 0
20.2. 16:22 | Nová verze

Byla vydána nová vývojová verze datového formátu a souvisejících nástrojů Relational pipes. Hlavní novinkou verze v0.10 je nástroj relpipe-tr-guile, který díky GNU Guile umožňuje filtrovat a transformovat relační data pomocí výrazů jazyka Scheme.

xkucf03 | Komentářů: 0
20.2. 00:33 | Bezpečnostní upozornění

CSIRT.CZ upozorňuje na kritickou zranitelnost ve WordPressu umožňující vzdálené spuštění libovolného kódu. Prakticky se jedná o kombinací dvou různých zranitelností (Directory Traversal a Local File Inclusion), pro jejichž úspěšné zneužití musí útočník získat v rámci instance WordPressu alespoň oprávnění autora.

Ladislav Hagara | Komentářů: 2
19.2. 17:33 | Nová verze

Po dvou a půl letech od vydání verze 5.0.0 byla oficiálně vydána nová major verze 6.0.0 správce digitálních fotografií a nově i videí digiKam (digiKam Software Collection). Přehled novinek i s náhledy v oficiálním oznámení. Ke stažení je také balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo ke spuštění a spustit.

Ladislav Hagara | Komentářů: 1
19.2. 00:44 | Komunita

Do 2. dubna se lze přihlásit do dalšího kola programu Outreachy (Wikipedie), jehož cílem je přitáhnout do světa svobodného a otevřeného softwaru lidi ze skupin, jež jsou ve světě svobodného a otevřeného softwaru málo zastoupeny. Za 3 měsíce práce, od 20. května do 20. srpna 2019, v participujících organizacích lze vydělat 5 500 USD.

Ladislav Hagara | Komentářů: 1
19.2. 00:11 | Bezpečnostní upozornění

Byly zveřejněny informace o o bezpečnostní chybě CVE-2019-6454 ve správci systému a služeb systemd (PID 1). Běžný uživatel jej může shodit připravenou D-Bus zprávou. V upstreamu je chyba již opravena [reddit].

Ladislav Hagara | Komentářů: 3
18.2. 22:44 | Nová verze

Byla vydána nová verze 2019.1 průběžně aktualizované linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek v changelogu. Vývojáři zdůrazňují Linux 4.19.13 a díky němu opětovnou podporu Banana Pi a Banana Pro, aktualizaci nástrojů jako theHarvester nebo DBeaver a Metasploit Framework ve verzi 5.0. Aktualizovat Kali Linux lze pomocí příkazů "apt update && apt -y full-upgrade".

Ladislav Hagara | Komentářů: 0
Máte v desktopovém prostředí zapnutou zvukovou znělku po přihlášení se do systému?
 (8%)
 (1%)
 (90%)
 (1%)
Celkem 382 hlasů
 Komentářů: 11, poslední 14.2. 07:59
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: 2299×
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: 61 | 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: 42 | 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: 46 | blog: Republic of Mordor | Zürich
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.