ugrás a tartalomhoz

Archívum - 2014

május 8

Statikus tábla tárolása adatbázisban vagy talán jobb xml-ben?

janoo · 2014. Május. 8. (Cs), 08.26
Helló mindenki!

Egy elég fura kérdésem lenne hozzátok, és kíváncsian várom válaszotok:

Lehet nem túl jól fogalmaztam hogy statikus tábla, de lényegében egy olyan db tábláról lenne szó, ami sosem változik.
A LEGO szettek és a LEGO alkatrészek közötti kapcsolatot hivatott tárolni, azaz melyik szettben melyik LEGO alkatrész van, és abból hány darab.

Ennek megfelelően ennyi a tábla tartalma: set_id, part_id, quant

Na most a bajom a következő: átlagba minden szettben van minimum 60 féle alkatrész, tehát egy szettnél akkor ez 60! bejegyzést jelent. Úgy hogy a szettek töredéke sincs még lementve ebben a formában, már így is van ebben a táblában több mint 94000 bejegyzés!! Ez max. a szettek 10%!

A másik része a dolognak, ez sosem változik. Egyszer elmentem, és kész. Onnan már csak néha lekérem, ha a látogató meg akarja tekinteni az alkatrészlistát. Tehát tényleg egy tök statikus dolog.

Az jutott eszembe, mi lenne ha simán xml fájlokban tárolnám ezeket. Mégpedig úgy, hogy a szett száma a fájlnév, pl.: 8052.xml, és akkor két dolgot mentenék bele, part_id és quant. Ez így kb 6000 fájl, és csak annyit kell néznem, hogy $setId.".xml" van-e vagy nincs :)

Szerintetek ezzel kímélném a db-t?
Így is van benne jócskán adat (már most is több mint 10Mb :) )

Előre is köszi a véleményeteket
 

május 6

Bad request vagy access denied?

inf · 2014. Május. 6. (K), 03.11
Szerintetek olyan esetben, amikor az illetőnek nincs joga az adott művelethez és mellette még formailag hibás kérést is küld, akkor melyik hibaüzenetet adjam vissza neki?

Ha a business logic felett ellenőrzöm a jogosultságot, akkor a bad request a könnyebben megvalósítható, ha a representation felett ellenőrzöm a jogosultságot, akkor az unauthorized a könnyebben megvalósítható. Vajon biztonsági kockázat e, hogy először a formai hibákat ellenőrzöm, és csak utána a jogokat?
 

május 4

Joomla 2.5x -> 3x

JoMRas · 2014. Május. 4. (V), 16.47
Üdv mindenkinek.
A kérdésem az lenne hogy hogyan tudom biztonságosan a 2.5.9-es Joomlamat
3x -re migrálni ?
Tudtok e olyan ingyenes komponenst amellyel ez megvalósítható.
Válaszokat előre is köszönöm.
 

május 3

selected - lekérdezni, egy select list-ből melyik option-ban van a selected="selected" ?

Mikulasche · 2014. Május. 3. (Szo), 14.14
Rengeteg select list van egy lapon, mindegyik úgy jön be, hogy van bennük selected="selected".

Mindegyikben más-más option a selected.

Szeretném lekérdezni a legördítés pillanatában, hogy mi az eredeti default selected-je.

Próbáltam JS -el JQ-val - nem jöttem rá, és leírást se találtam sehol.


Valaki tud valami megoldást ?
 

május 2

JavaScript div height

bnc1995 · 2014. Május. 2. (P), 10.36
Sziasztok!

A segítségeteket szeretném kérni egy div magasságának beállításával kapcsolatban.

A problémám a következő:

Egy tartalomtól függően változó magasságú div-et hoztam létre, ami működik is csak mivel, a kerekített sarkokat képekkel oldottam meg, egy kicsit lejjebb kerül mint én szeretném, ezért a position tulajdonsággal néhány pixellel feljebb toltam, így a tartalom alatt maradt egy kis hely. Én ezt úgy próbáltam megoldani, hogy JavaScript-ben lekérdezem a magasságot, majd kivonom belőle a felesleges magasságot. A probléma viszont az, hogy bár $("div_ID").ready(function(){...}) segítségével megvárnám amíg a div betölt, sajnos nekem azonnal lefut az átméretező kód, nem várja meg míg teljes egészében betölt, így viszont nem a tényleges méretet használja a kód, erre végső megoldásként az a barbár megoldás jutott az eszembe, hogy a setTimeout() függvényt használnám. Először 1000ms-re állítottam, de ez sem volt elég,mert némely eszköznek nem elég az 1s, hogy betöltsön, most 2000ms-en van, de ez sem elég mindenhol(pl. telefonon). Már az 1s-et is soknak tartottam, de a 2s már pláne. Szerintem elég feltűnő, hogy az oldal betöltése után 2 másodperccel felugrik a weboldal jelentős része. Biztos van erre egy elegánsabb megoldás.

Ha valaki tudna segíteni azt nagyon megköszönném, illetve, ha tudtok a problémára másik megoldást azt is szívesen fogadom.

Bence
 

PHP deploy

inf · 2014. Május. 2. (P), 04.48
Mit ajánlatok deploy-hoz, egy olyan szerverre, aminél csak ftp és php elérhető? (a szolgáltató cserén kívül persze :d)

Egy darabig azon agyaltam, hogy megírom én magam a deploy-t, mert nem annyira bonyolult:
- git post commit, post merge hook-okkal a master változásainál automatikusan lehet deploy-olni
- liquibase diff-el lehet sql-be konvertálni elvileg a schema change-eket
- git-ftp feltölti a megváltozott php fájlokat automatikusan
- mivel event sourcing lesz, ezért le lehet gatterolni az összes adatot, futtatni a schema change-es sql-t, aztán replay-el újra végigmenni az összes domain event-en, és így újra feltölteni adatokkal az új schema-t.

Összességében nem tűnik bonyolultnak, de kíváncsi vagyok, hogy vannak e kiforrottabb eszközök is a célra...
 

május 1

Liquibase changeset alapján történő db schema módosítás

inf · 2014. Május. 1. (Cs), 15.54
Új release-nél szeretném a changeset alapján módosítani a db schema-t, viszont production szerveren csak php van, és nincs ssh. Tudtok olyan php-s tool-ról, ami a changeset-et átnézve megcsinálja a módosításokat?

Alternatívának egyelőre azt találtam ki, hogy dumpolom az aktuális schema-t, aztán utána újra felépítem éles szerveren nulláról. Event sourcing-el az adatok így nem vesznek el, és bármilyen fejlesztésnél szükség lehet a domain event-ek újrajátszására. Ami megint érdekes dolog, hogy vajon hogyan lehetne automatizálni annak a felismerését, hogy mikor van szükség ilyen event újrajátszásra, és mikor nincs? (ez történhet adatbázis változástól függetlenül is, hmm talán a projection osztályok fájljainak figyelésével megoldható ez is)
 

Specifikáció változásnál hogyan szoktátok utánigazítani a kódot?

inf · 2014. Május. 1. (Cs), 15.45
Specifikáció változásnál hogyan szoktátok utánigazítani a kódot?
 

április 30

log analizáló pythonban (valójában a TDD alapjaival ismerkednék)

H.Z. · 2014. Ápr. 29. (K), 22.29
Van-e köztetek valaki, aki tudna segíteni abban, hogy belekezdjek az OOP + TDD témák gyakorlati kipróbálásába?
Az elképzelésem, hogy python2.7-ben összerakok egy minimalista tűzfal logot analizáló scriptet, ami az openwrt/tomato routerek logjában megjelenő üzenetekből tud kiszedni bizonyos infókat.
És itt most a log analizálása csak ürügy, hogy kicsit életszerűbb példa legyen, mint a különböző tutorialokban látható, "autó ojjektum, ennek vannak tulajdonságai, alkatrészei etc...", mert ez utóbbi alapján kicsit nehezemre esik valós problémákat megoldani.


Ugyan valaha foglalkoztam programozással, de amit csináltam, azt manapság "code monkey" néven szokás emlegetni, programtervezést nem tanultam, nem csináltam soha. Szóval érdekes lesz, na... :)


Az alap elképzelés egy paraméterezhető program, ami kiválogatja a syslogból az iptables által generált sorokat és a paraméterek alapján gyárt kimenetet.
Paraméterezhető szűrőfeltételek:
- eldobott (DROP), elfogadott (ACCEPT) csomagok
- protokoll (tcp, udp, icmp, egyéb)
- protokollon belül, ha lehetséges, port
Kimenet:
- legtöbb találat IP alapján csoportosítva
- legtöbb találat portok alapján csoportosítva (melyik portokra jött a legtöbb találat)


Ez procedurális alapokon pár óra alatt összedobható volt, csak miután kipróbáltam, megkaptam az eredményeket, egy laza mozdulattal töröltem az egészet.

Sajnos már az elején elakadtam, mert fogalmam sincs, hogy lehetne ezeket a feladatokat objektumokra szétszedni.
Szóval ha akadna valaki lelkes segítő (nem a pythonos, hanem az elméleti részben), akkor folytatom.

Illetve még az is gondot okoz, hogy egyáltalán egy ilyen téma belefér-e még a fórum kereteibe?
 

kivonás

cica · 2014. Ápr. 29. (K), 15.27
Üdv!

Miért kapok ilyen eredményt?

var Mit; var Mit2; var mi;

Mit2=125.123;
Mit =236.456;	

mi = Mit2-Mit; 
document.writeln(mi);
  
Ennek az eredménye -111.33299999999998,
valójában :-111,333-nak kellene lenni.