php.de

Zurück   php.de > Webentwicklung > PHP Einsteiger > PHP Tipps 2006

 
 
LinkBack Themen-Optionen Thema bewerten
Alt 11.10.2006, 10:26  
Moderator
 
Benutzerbild von cycap
 
Registriert seit: 13.02.2008
Beiträge: 6.816
PHP-Kenntnisse:
Fortgeschritten
cycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nett
Standard post2hidden

Hallo Leute,

da die meisten hier immer nur ihre Probleme schreiben dachte ich mir ich könnte mal was anderes machen. Ich hab mir eine, meiner Meinung nach, zwar kleine aber nützliche Funktion geschrieben die ich immer wieder nutze. Kann sein das es diese Funktion schon gibt oder etwas anderes sie überflüssig macht. Wenn ja, dann postet das doch bitte.

Die Funktion, denke ich, erklärt sich von selbst.

PHP-Code:
function post2hidden($input)
{
  
reset($input);
  while (list(
$key$val) = each($input))
  {
    echo 
"<input type=\"hidden\" name=\"$key\" value=\"$val\">";
  }

Gruß CyCap
cycap ist offline  
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 11.10.2006, 12:48  
Erfahrener Benutzer
 
Benutzerbild von Andreas
 
Registriert seit: 22.04.2005
Beiträge: 391
Andreas ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Und was machst du, wenn ein $_POST-Element ein array enthält?

Code:
<input type="text" name="arr[1]" value="1">
Andreas ist offline  
Alt 11.10.2006, 13:05  
Erfahrener Benutzer
 
Registriert seit: 13.11.2005
Beiträge: 2.583
xabbuh
Standard

Zusätzlich fehlen hier auch htmlspecialchars() bzw. htmlentities(), damit es dir nicht deinen HTML-Code zerhaut.
xabbuh ist offline  
Alt 11.10.2006, 13:22  
Moderator
 
Benutzerbild von cycap
 
Registriert seit: 13.02.2008
Beiträge: 6.816
PHP-Kenntnisse:
Fortgeschritten
cycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nett
Standard

Ok, es ist vllt noch nicht ausgereift, aber dafür ist ja auch das Forum gut

Gruß CyCap
cycap ist offline  
Alt 11.10.2006, 19:32  
moderatives Dielektrikum
 
Benutzerbild von nikosch
 
Registriert seit: 21.05.2008
Beiträge: 35.987
PHP-Kenntnisse:
Fortgeschritten
nikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunft
Standard

Zitat:
Zitat von xabbuh
Zusätzlich fehlen hier auch htmlspecialchars() bzw. htmlentities(), damit es dir nicht deinen HTML-Code zerhaut.
oder gar ein scheunentor für XSS öffnet. Mit POST hat die Funktion für sich ja auch nix zu tun...
Falls du das jetzt im großen Stil einsetzen möchtest, bedenke bitte, daß hidden Variablen wie auch normale Eingaben im Folgescript stets validiert werden müssen.
nikosch ist offline  
Alt 11.10.2006, 20:05  
da schreibt der ElePHPant
 
Benutzerbild von Flor1an
 
Registriert seit: 18.06.2008
Beiträge: 8.903
PHP-Kenntnisse:
Fortgeschritten
Flor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer Anblick
Standard

Wann braucht man überhaupt eine direkte $_POST Eingabe im folgenden Formular als hidden Field? Ich brauch das in meiner Anwendung kein einziges mal.
Flor1an ist offline  
Alt 12.10.2006, 13:26  
Moderator
 
Benutzerbild von cycap
 
Registriert seit: 13.02.2008
Beiträge: 6.816
PHP-Kenntnisse:
Fortgeschritten
cycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nett
Standard

wenn du zum beispiel etwas wie einen Assistenten machst wo man sich durchklicken kann und es erst am Ende gespeichert wird und es kann ja vorkommen das zwischendurch ein Wert per JS geändert werden soll.

Gruß CyCap
cycap ist offline  
Alt 12.10.2006, 13:52  
Erfahrener Benutzer
 
Registriert seit: 05.07.2004
Beiträge: 578
WarrenFaith
WarrenFaith eine Nachricht über ICQ schicken
Standard

Ein Assistent der durchklickt kann/sollte seinen Daten eher in Sessions als in hidden-inputs speichern.
Und was in deinem Argument JS zu suchen hat ist mir auch völlig unklar.
__________________
Developers-Guide.net
Senseless
WarrenFaith ist offline  
Alt 12.10.2006, 13:56  
Moderator
 
Benutzerbild von cycap
 
Registriert seit: 13.02.2008
Beiträge: 6.816
PHP-Kenntnisse:
Fortgeschritten
cycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nett
Standard

ganz einfach, der benutzer tut irgendwas (z.b. drag'n'drop) was die werte einer vorher gewählten option ändert. Dieses drag'n'drop muss aber nicht zwangsweise innerhalb des Formulares sein und kann daher nicht mit PHP erfasst werden. So muss der Wert der Variable also per JS geändert werden.
cycap ist offline  
Alt 12.10.2006, 14:51  
Erfahrener Benutzer
 
Registriert seit: 10.09.2004
Beiträge: 339
mkl0815
Standard

um sich sachen serverseitig zu merken gibt es doch sessions, das spart ausserdem traffic und ist deutlich sicherer. ausserdem braucht man die werte dann nur einmal zu validieren.

mario.
__________________
Problems with Windows : REBOOT
Problems with Linux : BE ROOT
mkl0815 ist offline  
 


Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an
Gehe zu

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
php post2hidden, post2hidden field

Alle Zeitangaben in WEZ +2. Es ist jetzt 14:17 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum

Creative Commons License
Dieser Inhalt ist unter einer Creative Commons-Lizenz lizenziert.