Hirdetés
- Samsung Galaxy Z Fold7 - ezt vártuk, de…
- Huawei Watch GT 6 és GT 6 Pro duplateszt
- Vivo X200 Pro - a kétszázát!
- Milyen okostelefont vegyek?
- MIUI / HyperOS topik
- Dupla kamerával menekülne az iPhone Air a kaszától
- Apple iPhone 17 Pro Max – fennsík
- Xiaomi 15T - reakció nélkül nincs egyensúly
- iPhone topik
- Android alkalmazások - szoftver kibeszélő topik
Új hozzászólás Aktív témák
-
Frigo
őstag
válasz
akopacsi
#4695
üzenetére
Session-ök alaphelyzetben a szerver vinyóján tárolódnak (az ini-ben megadott temp helyen) illetve ha elérhető akkor a cookie-ban is utóbbit le tudod tiltani a php.ini-ben.
Biztonság terén érdemes jelszavakat pl alapból titkosítva kezelni (pl md5() ),
időként kiléptetni a usereket a session timeout-tal ,szintén nem árt figyelni a user agent és az ip cím egyezést.Ha nagyon fontos a biztonság érdemes akkor a session-ket teljesen adatbázisban tárolni.Ha fontos a sebesség akkor érdemes elgondolkodni a memcahced technika alkalmazásán és a session-k a memóriába való mentésén . -
DeltaPower
addikt
válasz
akopacsi
#3867
üzenetére
legjobb megoldás szerintem 2 php oldal.
első:
adat form, magának postolja vissza. ellenőrzés, helyes adatok esetén sessionba menti és redirectel a második oldalra. helytelen adatok esetén visszahelyettesíti a formba és kiírja a hibát.
második:
képfeltöltő form, ez is magának postol.megoldható 1 fájllal is, így viszont áttekinthetőbb szerintem.
mindenképp sessiont ajánlok mentéshez, post adatokat tovább postolni nem egy elegáns megoldás. egyrészt ilyenkor ellenőrizni kell a továbbpostolt adatokat is (forrásban átírhatók a hidden form elemek), másrészt pl több lépcsős regisztrációnál jelszót forrásban tovább postolni mondhatni tilos.
-
Sk8erPeter
nagyúr
válasz
akopacsi
#3695
üzenetére
mysql_num_error ??

Miért nem a mysql_num_rows() függvényt használod? -
DeltaPower
addikt
válasz
akopacsi
#3667
üzenetére
standard megoldás? azt nem tudom, de leírom hogy én hogy szoktam.
1. kapott-e adatot? ha nem (tehát első futás), form kiíratás üresen
2. ha kapott: mezők ellenőrzése egyenként, szép nagy if-elseif sorozat vagy lehet ciklussal is.
2.a. ha minden adat helyes: adatbázisba írás, form nem jelenik meg
2.b. ha volt legalább egy hibás adat: hibaüzenet kiírása, form kiírása a kapott adatokkal (a jelszót/megerősítést, valamint capcha kódot nem szokás visszatölteni a formba).2.b-ben levő hibaüzenet lehet egyszerű ("hibás kitöltés"), vagy ennél informatívabb, ha az egyes mezők érték vizsgálatainál egy karaktertömböt csinálsz a hibákból ($error[]='túl rövid jelszó'; $error[]='ez a felhasználónév foglalt'; ), majd ennek elemeit íratod ki egymás után.
-
Sk8erPeter
nagyúr
válasz
akopacsi
#3635
üzenetére
1.) Először mindenképp a PHP-s ellenőrzést csináld meg, hogy az működjön, hiszen a JavaScript a böngészőben kikapcsolható, a PHP nem. Aztán utána jöhet a JavaScript-es ellenőrzés elkészítése, hiszen annak a működése kliens oldali, így értelemszerűen gyorsabb.
A legegyszerűbb, ha a $_POST adatok (vagyis az űrlap által elküldött mezők tartalmának) meglétét ellenőrzöd, az isset() és/vagy empty() függvénnyel.
Pl. if( !isset($_POST['az_egyik_urlapmezo']) ) { /* hibaüzenetek tárolása, vagy akármi hasonló... */ }
Ezután a következő lépés attól függ, a felhasználó számára szeretnéd-e felsorolni az összes hibát, vagyis az összes mezőt, ami még kitöltetlen, vagy sem (pl. csak kijelzed, hogy valahol hiba van, és kész). Erre is van többféle megoldás is, egyik egyszerűbb az, hogy mondjuk egy $hiba=""; változót inicializálsz az elején, és mindig hozzáfűzöd az aktuális hibasztringet, ha valahol hibát észleltél ($hiba .= 'Nem adta meg a nevét! <br />'; és ehhez hasonlók), és aztán mielőtt elküldenéd pl. adatbázisba az adatokat, ellenőrzöd, hogy a $hiba sztringed üres vagy sem. No meg attól is függ a dolog, hogy azonos oldalon dolgozod-e fel a kapott adatokat, vagy kiküldöd valami másik fájlnak, ami csak a feldolgozásért felel. Ha másik fájlba küldöd a feldolgozást, akkor egyik lehetséges megoldás a $_SESSION változók használata - pl. a hibasztringnek is beállíthatsz akár egy külön $_SESSION['hiba'] változót, aztán ezt kiíratod a form előtt; vagy azt is csinálhatod, hogy minden mezőnek külön $_SESSION változója van, és akkor akár rögtön a hiányos mező mellett is kiírathatod az üzenetet.
Utóbbi esetben (ha más fájlnak küldted ki a feldolgozást, és $_SESSION változókat használsz) csinálhatod azt is, hogy a júzernek ne kelljen még egyszer begépelni az adatokat, hogy
<input name="az_egyik_urlapmezo" type="text" id="az_egyik_urlapmezo"<?php if(isset($_SESSION['az_egyik_urlapmezo'])) echo ' value="'.$_SESSION['az_egyik_urlapmezo'].'" ';?> />A Javascriptes ellenőrzés: tételezzük fel, hogy van egy label mező is az input előtt (persze egyébként XHTML szabvány szerint a labelnek valami külön elemben kéne lennie, pl. div vagy táblázatmező vagy ilyesmi):
<label for="from_name" id="az_egyik_urlapmezo">Az egyik űrlapmező</label>
<input name="az_egyik_urlapmezo" type="text" id="az_egyik_urlapmezo"<?php if(isset($_SESSION['az_egyik_urlapmezo'])) echo ' value="'.$_SESSION['az_egyik_urlapmezo'].'" ';?> />Akkor ilyesmi lesz a Javascript erre vonatkozó egyik ellenőrző sora:
function formcheck(){
var hiba = '';
/***** Az egyik űrlapmező ellenőrzése******/
var urlapm = document.getElementById('az_egyik_urlapmezo');
var urlapm_label = document.getElementById('az_egyik_urlapmezo_label');
if ( ( urlapm.value.length==0 ) || (urlapm.value==null) ) {
hiba+='Nem adta meg a nevét!\n';
urlapm_label.style.color="#FF0000"; //red
}
else{
urlapm_label.style.color="#000000"; //black
}if(hiba!=''){
alert(hiba);
return false;
}
else {
return confirm('Kész?');
}
}Ez azt csinálja, hogy piros lesz a label mezőben található szöveg, így egyértelműen látszik, hol a hiba.
Persze a submit gombodhoz tedd be ezt:
<input onclick="return formcheck();" type="submit" name="send" id="send" value="Elküldés" />Az, hogy hányadikra küldték el a formot, mindegy kell, hogy legyen.
2.) Ha kisebbet kellene készítened a képből, nézz körül az imagecopyresampled() függvénynél, ott a felhasználói hozzászólások között biztos, hogy van egy-két kész megoldás, amit akár elég, ha kimásolsz.

Remélem nem fogalmaztam túl nehézkesen, vannak a leírtaknál szebb megoldások is, de most szerintem ez a legegyszerűbb.
-
DArchAngel
tag
-
tob!as
tag
válasz
akopacsi
#3087
üzenetére
<?php
$query = mysql_query('SELECT id, nev FROM kategoria', $connection);
?>
<form action="termek_hozzaadasa.php" method="post">
<p>Termék név:<br>
<input type=text name="termek_nev" size="75"><br>
Kategória:<br>
<select name="termek_kategoria">
<?php
while ($row=mysql_fetch_row($query)){
print '<option value='.$row[0].'>'.$row[1].'</option>';
}
?>
</select>
<input type=submit name="submit" value="Hozzáadás">
</p>
</form></body>
</html>
Új hozzászólás Aktív témák
- Arc Raiders
- ASUS notebook topic
- Samsung Galaxy Z Fold7 - ezt vártuk, de…
- Mibe tegyem a megtakarításaimat?
- Ezzel tényleg tizenkilencre húzott lapot a Gigabyte
- Milyen asztali (teljes vagy fél-) gépet vegyek?
- Autós topik
- AMD Navi Radeon™ RX 9xxx sorozat
- Okos Otthon / Smart Home
- Linux Mint
- További aktív témák...
- BESZÁMÍTÁS! MSI B550M R7 5800X 32GB DDR4 512GB SSD RTX 3070 8GB FSP CMT510 Cooler Master 750W
- Ricoh GRIIIx HDF
- Acer Predator Helios Neo16" QHD+ IPS i9-14900HX RTX 4070 32GB 1TB NVMe gar
- T14 Gen2i 14 FHD IPS i7-1185G7 16GB 512GB NVMe magyar vbill ujjolv gar
- Eladó Lenovo LOQ laptop I5, Rtx2050, 16gb ram, 512 m2 ssd. Garancia.
- MSI NVIDIA GeForce RTX 3090 3X OC GPU Kitűnő állapotban
- Telefon felvásárlás!! Honor 200 Lite, Honor 200, Honor 200 Pro, Honor 200 Smart
- Gitárerősítő Boss Katana 50
- LG 65QNED86T3A / QNED / 65" - 164 cm / 4K UHD / 120Hz / HDR Dolby Vision / FreeSync Premium / VRR
- Gamer PC-Számítógép! Csere-Beszámítás! I7 12700E / RTX 3060Ti / 32GB DDR4 / 512GB Nvme SSD
Állásajánlatok
Cég: Laptopműhely Bt.
Város: Budapest
Cég: NetGo.hu Kft.
Város: Gödöllő
...dobj egy privátot és akkor nem felejtem el... 





