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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
včera 22:44 | Komunita

Joinup informuje, že Mnichov používá open source groupware Kolab. V srpnu byl dokončen dvouletý přechod na toto řešení. V provozu je asi 60 000 poštovních schránek. Nejenom Kolabu se věnoval Georg Greve ve své přednášce Open Source: the future for the European institutions (SlideShare) na konferenci DIGITEC 2016, jež proběhla v úterý 29. listopadu v Bruselu. Videozáznam přednášek z hlavního sálu je ke zhlédnutí na Livestreamu.

Ladislav Hagara | Komentářů: 4
včera 15:30 | Zajímavý projekt

Společnost Jolla oznámila v příspěvku Case study: Sailfish Watch na svém blogu, že naportovala Sailfish OS na chytré hodinky. Využila a inspirovala se otevřeným operačním systémem pro chytré hodinky AsteroidOS. Použita je knihovna libhybris. Ukázka ovládání hodinek na YouTube.

Ladislav Hagara | Komentářů: 6
včera 14:15 | Nová verze

Byla vydána verze 7.1.0 skriptovacího jazyka PHP používaného zejména k vývoji dynamických webových stránek. Jedná se o první stabilní verzi nejnovější větvě 7.1. Přehled novinek v dokumentaci. Podrobnosti v ChangeLogu. K dispozici je také příručka pro přechod z PHP 7.0.x na PHP 7.1.x.

Ladislav Hagara | Komentářů: 1
včera 12:55 | Nová verze

Google Chrome 55 byl prohlášen za stabilní. Nejnovější stabilní verze 55.0.2883.75 tohoto webového prohlížeče přináší řadu oprav a vylepšení (YouTube). Opraveno bylo také 36 bezpečnostních chyb. Mariusz Mlynski si například vydělal 22 500 dolarů za 3 nahlášené chyby (Universal XSS in Blink).

Ladislav Hagara | Komentářů: 4
včera 11:55 | Pozvánky

Máte rádi svobodný software a hardware nebo se o nich chcete něco dozvědět? Přijďte na 135. sraz spolku OpenAlt, který se bude konat ve čtvrtek 8. prosince od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Sraz bude tentokrát tématický. Bude retro! K vidění budou přístroje jako Psion 5mx nebo Palm Z22. Ze svobodného hardwaru pak Openmoko nebo čtečka WikiReader. Přijďte se i vy pochlubit svými legendami, nebo alespoň na pivo. Moderní hardware má vstup samozřejmě také povolen.

xkucf03 | Komentářů: 0
včera 00:10 | Nová verze

Byla vydána verze 3.2 svobodného systému pro detekci a prevenci průniků a monitorování bezpečnosti počítačových sítí Suricata. Z novinek lze zmínit například podporu protokolů DNP3 a CIP/ENIP, vylepšenou podporu TLS a samozřejmě také aktualizovanou dokumentaci.

Ladislav Hagara | Komentářů: 0
1.12. 21:00 | Nová verze

Byla vydána beta verze Linux Mintu 18.1 s kódovým jménem Serena. Na blogu Linux Mintu jsou hned dvě oznámení. První o vydání Linux Mintu s prostředím MATE a druhé o vydání Linux Mintu s prostředím Cinnamon. Stejným způsobem jsou rozděleny také poznámky k vydání (MATE, Cinnamon) a přehled novinek s náhledy (MATE, Cinnamon). Linux Mint 18.1 bude podporován až do roku 2021.

Ladislav Hagara | Komentářů: 0
1.12. 16:42 | Nová verze

Byl vydán Devuan Jessie 1.0 Beta 2. Jedná se o druhou beta verzi forku Debianu bez systemd představeného v listopadu 2014 (zprávička). První beta verze byla vydána v dubnu letošního roku (zprávička). Jedna z posledních přednášek věnovaných Devuanu proběhla v listopadu na konferenci FSCONS 2016 (YouTube, pdf).

Ladislav Hagara | Komentářů: 0
1.12. 15:16 | Komunita

Na GOG.com začal zimní výprodej. Řada zlevněných her běží oficiálně také na Linuxu. Hru Neverwinter Nights Diamond lze dva dny získat zdarma. Hra dle stránek GOG.com na Linuxu neběží. Pomocí návodu ji lze ale rozběhnout také na Linuxu [Gaming On Linux].

Ladislav Hagara | Komentářů: 1
1.12. 13:14 | Bezpečnostní upozornění

Byla vydána verze 2.7.1 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Řešeno je několik bezpečnostních problémů. Aktualizován byl především Tor Browser na verzi 6.0.7. Tor Browser je postaven na Firefoxu ESR (Extended Support Release) a právě ve Firefoxu byla nalezena a opravena vážná bezpečnostní chyba MFSA 2016-92 (CVE-2016-9079, Firefox SVG Animation

… více »
Ladislav Hagara | Komentářů: 0
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (7%)
 (5%)
 (3%)
Celkem 761 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

Dotaz: f-ce system v jazyce C

14.7.2012 17:08 Hanibal
f-ce system v jazyce C
Přečteno: 758×
Zdravíčko, programuji jednoduchý časovač v jazyce C, přičemž používám f-ci system() a v ní příkaz shutdown. Mám ale problém vložit číslo z proměnné minuty do f-ce system, protože "%d" nebo %d není argumentem příkazu shutdown. Dá se s tím něco dělat? Děkuji

Řešení dotazu:


Odpovědi

Řešení 1× (Filip Jirsák)
14.7.2012 17:31 Ash | skóre: 53
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
char cmd[256];
sprintf(cmd, "shutdown %d", time);
result = system(cmd);
Řešení 1× (Filip Jirsák)
14.7.2012 17:31 jerry
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
http://www.cplusplus.com/reference/clibrary/cstdio/sprintf

Použij sprintf na vytvoření řetězce a ten dej jako parametr do system()
14.7.2012 17:45 Hanibal
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
Děkuju :-)
Řešení 1× (Filip Jirsák)
15.7.2012 10:23 Michal Kubeček | skóre: 71 | Luštěnice
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
Funkce system() je poměrně nebezpečná hračka a její neuvážené použití snadno vytváří bezpečnostní chyby. Nemám moc dobrý pocit, když ji vidím používat někoho, kdo se potřebuje ptát na takhle elementární obraty.
15.7.2012 10:34 Václav Vanc | skóre: 14
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
Můžeš uvést nějaké odstrašující příklady, abych věděl, na co si mám dávat pozor?
David Watzke avatar 15.7.2012 10:59 David Watzke | skóre: 74 | blog: Blog... | Praha
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
No snadno tak někomu můžeš předat shell aniž bys chtěl. Někde ho necháš zadat řetězcovej argument pro nějakej příkaz, třeba "cmd %s" a on tam prdne něco jako "; /bin/bash", atd. Tohle je například problém u programů, které se spouštějí se sudo.
“Being honest may not get you a lot of friends but it’ll always get you the right ones” ―John Lennon
15.7.2012 11:04 Filip Jirsák | skóre: 66 | blog: Fa & Bi
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
A od bezmyšlenkovitého použití %d je k %s sakra blízko. Stačí, že si autor vzpomene, že chce použít plné možnosti zadání času pro shutdown.
martin-ux avatar 15.7.2012 11:24 martin-ux | skóre: 18 | Bratislava
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
I ked nie je presne zname co autor riesi, pripada mi vhodnejsie pouzitie skriptu na dany problem. Ked uz C, tak zavolat reboot nativne.

Ale ked uz zacala diskusia o security, tak by bolo vhodne spomenut aj fakt, ze miesto sprintf by mal autor pouzit snprintf.
..when you do things right, people won't be sure you've done anything at all..
martin-ux avatar 15.7.2012 11:26 martin-ux | skóre: 18 | Bratislava
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
xjo .. to mala byt reakcia na autora threadu, nie na teba michal.
..when you do things right, people won't be sure you've done anything at all..
15.7.2012 20:27 Ash | skóre: 53
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
Ale ked uz zacala diskusia o security, tak by bolo vhodne spomenut aj fakt, ze miesto sprintf by mal autor pouzit snprintf.

Jenže to by se pak muselo také říct proč, a to by bylo na dlouho, jinak by to při jeho úrovni znalostí vedlo k tomu, že by použil
char cmd[256];
snprintf(cmd, 256, "shutdown %d", time);
result = system(cmd);
což je nesmysl a spíš bych čekal že si pak kus toho čísla ustřihne a shutdown se provede v jiný čas, což by mohlo být větší bezpečnostní riziko :) strncpy není něco jako "bezpečná verze strcpy" v oblasti security, spíš brání nechtěným chybám v oblasti dočasné programátorovy stupidity která občas potká každého z nás. I když je nepochybně mnoho případů, kdy je vhodné ji použít, hlavně proto, aby se člověk musel zamyslet, jak dlouhý ten vstup vlastně může být. Pokud se ovšem zamyslí a řekne si, že nejlepší bude tam dát strlen(vstup) a má to teda bezpečné, protože to psali na abclinuxu, tak jsme tam, jde jsme byli :D
martin-ux avatar 16.7.2012 00:01 martin-ux | skóre: 18 | Bratislava
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
ani nie ze brani stupidite, skor ju limituje .. ale ma zmysel, kedze nuti sa zamysliet co vlastne kopirujem a hlavne kolko ..

neber to ale ako kritiku tvojho prispevku .. sam som hore napisal, ze nevieme co autor chce .. ale ked uz bol naznak o hovoreni bezpecnostnych chyb, tak stoji za zmienku aj to, co som napisal (aspon tak si myslim ja ;-) ).
..when you do things right, people won't be sure you've done anything at all..
17.7.2012 00:37 Ash | skóre: 53
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
Jasně, já to neberu jako kritiku, popravdě já spíš kritizuji :D Když jsem psal tu odpověď, tak jsem nejprve napsal ze zvyku strncpy, pak si říkám, tady jsme asi na jiném levlu, a napsal jsem to jednoduššeji. Protože kdybych řekl A (že strncpy), musel bych říct i B a C (proč, jak). Podle mne to také určitě stojí za zmínku, nejlépe takovou, která by rozebrala problém víc do hloubky, nebo alespoň dobrý odkaz... Bez toho mi to připadá že to nebude mít očekávaný efekt, přestože to je připomínka jistě fakticky správná a k věci.
Jardík avatar 17.7.2012 02:07 Jardík | skóre: 40 | blog: jarda_bloguje
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
Všechno s fixně velikým bufferem je kravina použít tam, kde se fixně veliký buffer nehodí, např. tady. Jednoho dne si to někdo bude chtít zkompilovat na plafromě, kde maximální hodnota intu jako řetězec bude mít 250 znaků a bum. Fce snprintf() nám přece vrátí potřebný počet znaků a pokud je jaksi >= než co jsme měli alokováno, můžeme přealokovat. Bohužel nějakek kokot si řekl, že bude vracet int, ale malloc() chce size_t (a funkce snprintf taky), takže bude následovat kýbl maker či podmínek, kde se porovnává jejich velikost k určení, zda bude typecast bezpečný. Taky vás pak omezují na řetězec s maximální délkou MIN(SIZE_MAX-1, INT_MAX-1), což je stupidní.

Závěr? snprintf nepoužívat, tato funcce je k ho*nu a podobně i další z její rodiny.
Věřím v jednoho Boha.
17.7.2012 22:17 Ash | skóre: 53
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
Tak pokud se pohybujete v takové teoretické rovině kde int má víc než 250 znaků, tak můžete rovnou použít nějakou GNU funkci printf která vám ten string naalokuje a nepotřbujete si předalokovávat nic, žejo.
Jardík avatar 18.7.2012 00:48 Jardík | skóre: 40 | blog: jarda_bloguje
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
GNU funkci
A v tom je háček, zrušíte tak přenositelnost programu a pak nemá teda ani cenu zabývat se velikým intem, budete na tom stejně.
Věřím v jednoho Boha.
AraxoN avatar 18.7.2012 15:24 AraxoN | skóre: 45 | blog: slon_v_porcelane | Košice
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
Ehm... int, ktorý môže mať v desiatkovom vyjadrení 250 a viac číslic, musí mať najmenej 831 bitov. Povedal by som, že takýto dátový typ nám v kategórii "primitívne dátové typy" tak skoro nehrozí. :)
A fine is a tax for doing wrong. A tax is a fine for doing well.
Jardík avatar 18.7.2012 16:52 Jardík | skóre: 40 | blog: jarda_bloguje
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
Jenže pak předpokládáte něco, co standard nevylučuje a jsme tam, kde jsme byli na začátku. Pak si ještě řekneme, že pravděpodobně na nic jiného, než 32bit int nenarazíme a že nám bude stačit 10 znaků pro <-2^31;2^31-1>, použijeme %d s 11 znakovým bufferem (pro ukončovací nulu) a pak zjistíme, že nám to chtělo dát "-2,125,256,111" protože nějaký locale.
Věřím v jednoho Boha.
18.7.2012 20:18 Ash | skóre: 53
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
No uvažovat 64bit nebo 830bit je trochu rozdíl :D Ale základní myšlenku chápu.
19.7.2012 07:55 Pindal
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
K prdu je dnes myslet na 250 znaků int.
30.7.2012 18:43 Nikola Pajkovský | skóre: 16
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
char cmd[sizeof("shutdown %d") + sizeof(unsinged) * 3];
sprintf(cmd, "shutdown %d", time);
...
...
Save the whales. Feed the hungry. Free the mallocs
30.7.2012 21:44 Michal Kubeček | skóre: 71 | Luštěnice
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
:-)
30.7.2012 22:23 Ash | skóre: 53
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
překladač snese všechno :-D
30.7.2012 22:31 Michal Kubeček | skóre: 71 | Luštěnice
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
Ten překlep asi ne. Ale jinak je to zajímavá myšlenka, jen pro velké hodnoty sizeof(unsigned) to bude zbytečné plýtvání. :-)
31.7.2012 09:21 Ash | skóre: 53
Rozbalit Rozbalit vše Re: f-ce system v jazyce C
Zvlášť pro ty 830bitové :)

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.