Mit ‘Programmieren mit PHP’ getaggte Artikel

Zählen von Substrings in einer Zeichenkette mit PHP und substr_count()

Dienstag, 08. November 2011

Viele PHP Programmieraufgaben lassen sich mit der Kombination verschiedenster Funktionen erledigen. Für manche bietet aber PHP bereits fertige Funktionen, die zum einen schneller sind, zum anderen einfacher einzusetzen sind. Einen solchen Beispiel werden wir heute veranschaulichen – wie können Substrings innerhalb einer Zeichen gezählt werden?

Problematik

Sie wollen gerne wissen, wie oft das Wort Buch in der Zeichenkette “Buch im Buchhandel” vorkommt, ohne immer wieder nach dem Wort Buch mit PHP zu suchen, den gefundenen String auszuschneiden und weiter zu suchen? Das lässt sich ganz einfach mit der Funktion substr_count erledigen, folgendermaßen:

Lösung 1

$nAnzahl = substr_count("Buch im Buchhandel", "Buch");

Anbei die Erläuterung – als erster PHP Parameter geben Sie die Zeichenkette ein, in der gesucht wird und als zweiter Parameter geben Sie das gesuchte Wort ein. $nAnzahl ist eine Zahl, die Sie von PHP als Ergebnis bekommen. Somit ist Ihre Programmierung schnell und kompakt. Folgendes sollten Sie aber beachten:

  • Die Funktion zählt nicht doppelt, wenn das zweite Vorkommen eines Strings innerhalb des ersten anfängt.
  • Die Funktion zählt unter Beachtung von Groß- und Kleinschreibung. Das bedeutet, das Wort buch kommt in unserer Beispelszeichenkette gar nicht vor.

Lösung 2 – Suche ohne Beachtung von Groß/Kleinschreibung

$nAnzahl = substr_count(strtolower("Buch im Buchhandel"), strtolower("Buch"));

Ganz einfach – wenn Sie suchen wollen, ohne großartig Groß- und Kleinschreibung zu berücksichtigen, so können Sie vor dem Aufruf der PHP Funktion substr_count eine andere PHP Hilfsfunktion aufrufen – strtolower(). Diese wandelt automatisch alle Buchstaben in Kleinbuchstaben um. Somit bekommen Sie einen Programmierergebnis für alle mögliche Treffer.

Einsatz und Fazit

Diese können können Sie immer verwenden, wenn Sie detaillierte Information über die Aufteilung von Wörten innerhalb eines Text mit PHP in Erfahrung bringen möchten. Diese nutzen wir für unsere Suchmaschinenoptimierung, von der Sie auch profitieren können.

Brauchen Sie schnelle und zuverlässige Programmier-Hilfe für Ihre Programmierungen oder MySQL Abfragen? Wir sind für Sie da – zögern Sie nicht mit uns per E-Mail oder telefonisch – 02161 / 177747 – Kontakt aufzunehmen. Schauen Sie sich unsere Leistungen an.

PHP Session geht im IFrame unter Internet Explorer verloren

Montag, 31. Januar 2011

Sicherlich haben Sie versucht über ein IFrame verschiedene Inhalte auf Ihrer Seite einzubinden. Diese Inhalte generieren so genannte PHP Sessions, um verschiedene Daten während des Aufenthaltes zu behalten, unter anderem Login Cookies. Jedoch funktioniert das tadeloss nur unter allen Browser außer Internet Explorer, egal ob Sie das Ziel über HTTP oder HTTPS einbinden. Insbesondere wenn die Domains des Ziels und die Hauptseite, die das IFrame enthält, unterschiedlich sind. Auch wenn Sie die Session über die session_id von der Oberseite zum IFrame übertragen, geht sie verloren.

Problematik

Die PHP Session wird, auch wenn ordnunngsgemäß erstellt, nach dem Aufruf verloren. Sie geht ja nicht einfach verloren, sondern der Explorer löscht diese oder richtiger gesagt, akzeptiert diese nicht aus Sicherheitsgründen. Unter Safari und Mozilla liegt das Problem nicht vor. Interessant ist, dass die Session-variable erstellt wird, sie bekommen keine Meldung, dass die Session nicht gestartet ist oder sonstiges, sondern der Wert ist einfach komplett leer. Wenn Sie den Inhalt außerhalb des IFrames aufrufen, so funktioniert die Session problemlos.

Hintergrund der Problematik

Aus Sicherheitsgründen lehnt Internet Explorer das Anlegen der Session Cookie ab, egal wie Sie die Session starten lassen (entweder mit session_start() oder die Session wird durch Konfiguration automatisch gestartet). Microsoft sagt, dass die obere Seite diese Session missbrauchen könnte und deswegen wird sie nicht erstellt.

Lösung

Um dieses Problem umzugehen, müssen Sie eine P3P PHP header-Anweisung implementieren, die in Worten sagt, dass die Tatsache, dass die Oberseite Zugriff bekommen hat, wird nicht missbraucht. Diese müssen Sie in die PHP Datei hineinprogrammieren, die im IFrame angezeigt wird:

<?php header('P3P: CP="CAO PSA OUR"'); ?>

Diese Zeile muss überall rein, wo Sie Ihre Session-Cookies erzeugen. Die P3P Headers sind eine Art Fine-Tuning der Datenschutzbestimmungen, die Sie lokal auf Ihrem Browser eingestellt haben und die informieren den Browser, wie er sich verhalten soll, wenn bestimmte Probleme wir das von beschriebene auftauchen.

Sie kommen selber nicht weiter?

Keine Sorge, wir sind für Sie da. Rufen Sie uns an oder schicken Sie uns eine Anfrage, wir helfen Ihnen weiter.

PHP Programmierung – Zahl formatieren mit PHP

Montag, 17. Mai 2010

Als Zusatz zu der von uns vorgestellten Javascript Funktion zur Formatierung von Zahlen, wollen wir heute die Programmierung einer Funktion zur Formatierung von Zahlen mit PHP näher erklären. Nach wie vor ist das Problem mit den auf das U.S. Zahlensystem formatierten Zahlen aktuell. PHP bietet eine sehr komfortable Funktion zur Formatierung von Zahlen mit tausender Gruppierung.  Vor allem können Sie Zahl auf die Deutsche Schreibweise umwandeln. Diese Funktion nennt sich number_format. Diese erwartet entweder zwei oder vier Paramater:

Die zu formatierende Zahl – so etwa wie 29.5
Anzahl von Nachkommastellen
Optional: Trennzeichen für die Nachkommastellen
Optional: Trennzeichen für die Tausenderstellen

Da man immer wieder die gleichen Parameter nimmt, wenn man die Zahlen auf die Deutsche Screibweise formatiert, so schreiben wir uns eine kleine und einfache Funktion, die number_format anwendet:

function ZahlFormatieren($dZahl, $nAnzahlNachkommastellen=2) {
     return number_format($dZahl, $nAnzahlNachkommastellen, ",", ".");
}

Die Funktion formatiert die Zahl 28,000.4 als 28.000,40 mit Zwei Kommastellen. Man kann gerne die Anzahl der Kommastellen über den Parameter von dem Standardwert von 2 auf eine andere Anzahl erweitern oder minimieren.

Einsatz

Wenn Sie beispielsweise ein Formular haben, das Zahlen in Textfelder automatisch ausfüllt, die auch korrekt dargestellt werden sollen, so können Sie die Funktion auf folgender Art und Weise in HTML einbetten:

<input type="text" name="MeineZahl" value="<?php echo ZahlFormatieren($dMeineZahl) ?>" />

PHP Programmierung – PHP Funktion zur Generierung von transparenten Spacer

Mittwoch, 05. Mai 2010

Wir hatten in unserem letzten Artikel darüber informiert, wie man mittels einer PHP Funktion die Generierung von <img /> Tags erleichtern kann. Diese Funktion spart Zeit, sichert eine einheitliche Schreibweise aller <img /> Tags und erlaubt Änderungen in der Schreibweise, sollte diese sich durch Richtlinien oder Suchmaschinenoptimierung ändern sollen. Heute werden wir präsentieren wir man mit Hilfe dieser Funktion die sehr oft benutzten Spacer (transparente 1×1 Pixel Bilder) generieren kann.

Die PHP Funktion zur Erstellung von Spacer wir ein Aufruf der Funktion CreateImage sein, dass bestimmte Parameter immer wieder nutzt. Anbei die Funktion:

function CreateSpacer($nWidth=1, $nHeight=1) {
    return CreateImage(IMAGES_PATH."trans.gif","","width: ".$nWidth."px; height: ".$nHeight."px; border: 0px","");
}

Was macht die Funktion?

Es wird die Funktion CreateImage aufgerufen, wobei der Pfad zu der 1×1 Pixel Grafik (trans.gif) vorgegeben ist und explizit keinen Rahmen angezeigt wird. Die Konstante IMAGES_PATH kann in einer Konfigurationsdatei als der Pfad zu dem Ordner definiert werden, wo sich Ihre Grafiken befinden. Die Funktion übernimmt die übergebenen Parameter Breite und Höhe, die die meistbenutzen Parameter bei der Erstellung von Spacer <img /> sind. Diese können auch nicht angegeben werden zwecks einer einfacheren Ausführung der Funktion, dann wird das Bild mit 1px Höhe und 1px Breite erstellt.

Beispiel der Nutzung

Normalerweise hätten Sie mit HTML eine solche Schreibweise zur Erstellung eines Spacers nutzen sollen:

<td><img src="<?php echo IMAGES_PATH;?>trans.gif" style="width: 200px; height: 20px; border: 0px;" alt="" title="" /></td>

Mit unserer Funktion geht das einfacher:

<td><img src="<?php echo CreateSpacer(200,20);?></td>

Somit vererbt die CreateSpacer Funktion die Funktion CreateImage auf eine einfache Art und Weise. Die Grundfunktion kümmert sich bei diesem Aufruf um den alternativen Text, korrekte Schreibweise des Tags usw.

PHP Programmierung – PHP Funktion zur Generierung von W3C-konformen img Tags

Montag, 03. Mai 2010

Die PHP Programmierung kann auf sehr vielen Art und Weisen in der Optimierung der HTML Programmierung eingesetzt werden. Das beinhaltet die Automatisierung von HTML Routinen, die sich immer wieder wiederholen und eine aufwändige Schreibweise mit sich bringen. Die Erstellung von korrekten und W3C-konformen <img> Tags erfordert das Ausfüllen von mehreren Attributen dieses Tags, was man auch gerne vergisst, da die Browser die Bilder nur mit dem source (src) Attribut auskommen und das Bild korrekt darstellen. Jedoch gibt es ein Paar Probleme, die man durch die Automatisierung der Erstellung von <img> Tags vermeiden kann:

1. Wenn ein Bild verlinkt wird, wird automatisch einen Rahmen erstellt – wenn das Bild ohne den Attribut style=”border: 0px”; erstellt wird, macht der Browser automatisch einen Rahmen um das Bild, um zu zeigen, dass man darauf klicken kann.

2. Wenn man keine genauen Maße angibt, wird das Bild beim Aufrufen der Seite erstmal auf der Breite des alternativen Textes gespannt – da der Browser beim Laden des Bildes nicht weiß, wie breit und hoch es ist, muss das Bild erstmal geladen werden und dann analysiert werden. Bis das erfolgt, wird der Platzhaltern vom Bild automatisch auf die Breite des angegebenen Alternativtextes gespannt, was mit vielen Bildern eine deutliche Unruhe beim Laden der Seite bereitet.

3. Der alternativ Text wird nur angezeigt, wenn das “title” Attribut benutzt wird.

Wir präsentieren an der Stelle eine PHP Funktion, die <img > Tags mit den entsprechenden Attributen je nach Aufruf in HTML generiert.

function CreateImage($sSrc="", $sAlt="", $sStyle="", $sId="") {
 
 if(is_file($sSrc)){
  $arImageInformation = getimagesize($sSrc);
  $nImageWidth = $arImageInformation[0];
  $nImageHeight = $arImageInformation[1];

  $PrintId="";
  if ($sAlt!="" &amp;&amp; $sId!="") $PrintId = ' id="'.$sId.'"';
  
  if(!strstr($sStyle, "width") &amp;&amp; !strstr($sStyle, "height") &amp;&amp; $sStyle!= ""){
   $sImageInfo = 'style="width: '.$arImageInformation[0].'px; height: '.$arImageInformation[1].'px;'.$sStyle.'"';
  }
  elseif(!strstr($sStyle, "width") &amp;&amp; !strstr($sStyle, "height") &amp;&amp; $sStyle== ""){
   $sImageInfo = 'style="width: '.$arImageInformation[0].'px; height: '.$arImageInformation[1].'px; border: 0px;"';
  }
  else {
   $sImageInfo = 'style="'.$sStyle.'"';
  }
  $sImage =  '<img src="'.$sSrc.'" '.$sImageInfo.' alt="'.$sAlt.'" title="'.$sAlt.'" '.$PrintId.'/>'; 
   return $sImage;
 }else{
  return "Pfad ".$sSrc. " not correct";
 }
}

Was macht die PHP Funktion und welche Parameter übernimmt sie?

1. Funktion – es wird zunächst geprüft, ob der angegebene Pfad zum Bild (übers src Attribut) existiert. Wenn nicht, wird einfach ein Text mit dem Falschen Pfad zurückgegeben. Wenn der Pfad existiert, werden die Maße des Bildes mittels der Funktion getimagesize ausgelesen. Dann wird das style Attribut, das alle nicht mehr als einzelne Attribute zu nutzende Attribute vereiningt, generiert. Das entspricht auch die W3C Richtlinien. In das style Attribut werden width, height, (die automatisiert ermittelt werden) border und weitere durch den User anzugebenden Eigenschaften reingeschrieben. Je nach dem, ob der User die Eigenschaften selber angibt, wird die border Eigenschaft automatisiert dazu geschrieben. Eventuellen id und alt werden ergänzt, wobei der title Tag wird automatisch wie der alt hinzugefügt. Das stellt sicher, dass der Besucher immer den alternativ Text wahrnehmen kann.

2. Parameter

 - $sSrc – der Pfad zum Bild
 - $sAlt – der alternativ Text des Bildes – hierüber kann man über PHP automatisiert Texte nutzen, die für die gesamte Seite relevant sind.
 - $sStyle – die durch den User definierten Style-eigenschaften wie width, height, border, margin etc.
 - $sId – die ID vom Bild, falls es durch Javascript Funktionen manipuliert werden wird.

Diese Funktion stellt eine konforme Art der Schreibweise von den <img /> Tags dar und erlaubt das Vermeiden der kleinen Fehler bei der täglichen Programmierung mit HTML. Sie lässt sich mit weiteren Parameter beliebig erweitern, es lässt sich beispielsweise die URL per Parameter übergeben, wohin das Bild verlinken soll.