Archive

Archive for the ‘php’ Category

JSON++ compiled with VS 6.0

September 17th, 2008

Χρειαζόμουν έναν τρόπο να συνδέσω ένα c++ script με ένα php script, ώστε να ανταλλάσουνε δεδομένα. Στην αρχή σκέφτηκα με xml από το stdin/stdout, άλλα δεν ήθελα και τόσο δομημένη πληροφορία, όποτε αποφάσισα να χρησιμοποιήσω json.

Για php δεν υπήρχε συζήτηση ότι θα χρησιμοποιούσα μία κλάση που έχω βρει, και την έχω δουλέψει αρκετά σε πολλά projects, την Services_JSON. Για C++ όμως δεν είχα χρησιμοποιήσει ποτέ, όποτε έπρεπε να ψάξω και να βρω κάτι που να με βολεύει.
Googlesearch, json.org, πολλά project, στα πρώτα αποτελέσματα, άλλα όχι κάτι απλό έτσι που το ήθελα εγώ. Κάπου στη 3η σελίδα βρήκα ένα ενδιαφέρον project το JSON++. Αμέσως το κατέβασα, και έφτιαξα ένα test project στο Visual Studio 6.0 να το δοκιμάσω. Το JSON++ όμως ήταν για Visual Studio .NET. Δεν πτοήθηκα, διότι στο παρελθών έχω κάνει και compile το php5 με VC++ 6.0, οπότε ξεκίνησα τις αλλαγές ώστε να γίνει το compile.
Στο αρχείο value.cpp στην γραμμή 428 και 432, διόρθωσα την εντολή swprintf από
swprintf(strnum,31,L”%.1lld”,(*(__int64 *)val));
σε
swprintf(strnum,L”%.1lld”,(*(__int64 *)val));

και
swprintf(strnum,31,L”%lG”,(*(double *)val));

σε
swprintf(strnum,L”%lG”,(*(double *)val));

Στο αρχείο parser.h έβγαλα την μεταβλητή errstrings, από την γραμμή 28 extern const wchar_t *errstrings[8];
Στο αρχείο parser.cpp πρόσθεσα τα παρακάτω includes στην αρχή

#include <stdio.h>

#include <stdlib.h>

Μετέφερα την μεταβλητή errstrings από το αρχείο errstrings.cpp εδώ μέσα namespace json {const wchar_t *errstrings[9]={
/*0*/ L”Invalid Unicode escape sequence”,
L”Tried to read past End of File”,
L”Error reading Array, ] expected”,
L”Unquoted object names not allowed”,
L”Error reading Object, : expected after name”,
/*5*/ L”Error reading Object, } expected”,
L”Could not find a valid Object value”,
L”Invalid unquoted string, or misspelled literal”,
L”Duplicate value name in Object”
};

και στην γραμμή 253 του παλιού αρχείο άλλαξα την συνάρτηση _wtof σε _wtol.Από
val->setnumber(_wtof(number.c_str()));
σε
val->setnumber(_wtol(number.c_str()));

Αυτό βέβαια δεν είναι σωστό, γιατί μία μεταβλητή float θα χαλάει, το σωστό θα ήταν να ασχολούμουν λίγο παραπάνω και να έβρισκα το σωστό συνδυασμό από functions προκείμενο να μετατραπεί σωστά το string σε float. Στην προκειμένη περίπτωση δεν θα είχα float όποτε και δεν ασχολήθηκα παραπάνω. Αν κάποιος το βρει θα ήθελα να το γράψει στα σχόλια για είναι ποιο ολοκληρωμένη η μετατροπή του project από .net σε 6.0.Τέλος έβγαλα το αρχείο errstrings.cpp από το compile γιατί ήταν άχρηστο πλέων, και το compile έγινε κανονικά.

Το JSON++ ήταν ακριβώς αυτό που χρειαζόμουν, διότι είναι πού εύκολο στην χρήση του σε αντίθεση με τα υπόλοιπα open source projects.

c++, JSON, php , ,

String UTF-8

May 27th, 2008

Ένας γρήγορος τρόπος ελέγχου αν ένα string είναι utf-8. Πρώτα μετατρέπουμε το string σε utf-8 (utf encode). Στην συνέχεια το ξαναμετατρέπουμε στο αρχικό format (utf decode). Αν το crc του αρχικού είναι ίδιο με το crc του τελικού τότε είναι utf-8.

function is_utf8($str) {
	$str_u8=iconv('Windows-1253','UTF-8',$str);
	return (crc32($str)==crc32(iconv('UTF-8','Windows-1253',$str_u8))) ? true : false;
}

php

Php Acronym Replace

May 25th, 2008

Χρειαζόμουν ένα acronym replace utility για να το ενσωματώσω σε ένα site. Όπως κάθε έξυπνος προγραμματιστής, ψάχνει πρώτα στο google. Τι γίνεται όμως όταν αυτό που βρίσκει δεν τον ικανοποιεί. Προσπαθεί να το φτιάξει μόνος του.

Έτσι λοιπόν ξεκίνησα να σκέφτομαι τι θα μπορούσα να χρησιμοποιήσω ώστε να πετύχω το καλύτερο δυνατό αποτέλεσμα. Στην αρχή σκέφτηκα να κάνω parse το html, να βρίσκω τα κείμενα ανάμεσα στα tags, και να κάνω replace τα acronyms. Άκυρη η προσπάθεια, πολλά προβλήματα, ήθελε πολλούς ελέγχους. Αποφάσισα ότι πρέπει να κινηθώ προς αυτήν την κατεύθυνση, άλλα με άλλο τρόπο parsing.

Έτσι μου ήρθε η ιδέα να χρησιμοποιήσω τον xml parser του php module expat. Το αποτέλεσμα καταπληκτικό, απλά έπαιρνε υπόψη του, μόνο το πρώτο block από tags. Έπρεπε να βρω γιατί σταματούσε, και δεν συνέχιζε και στα επόμενα. Μετά από ώρες ψαξίματος, κατάλαβα ότι του έλειπε ένα dtd, για να καταλάβει ο parser με τι τύπο xml (doctype) έχει να κάνει.

Έτσι του πρόσθεσα ότι είναι xhtml. Bingo επιτέλους πάρσαρε όλα τα blocks που είχε το content. Βέβαια τα προβλήματα δεν σταμάτησαν εδώ, ενώ έδειχναν ότι όλα είναι ok, ξαφνικά διαπίστωσα ότι χαρακτήρες όπως &,.! κτλ, εξαφανίστηκαν. Άντε πάλι googling… Η λύση ήρθε από το W3C, λείπανε τα entities, από το dtd. Πρόσθεσα και τα entities που με ενδιαφέρανε και το αποτέλεσμα, super! Τέλος για γίνει καλύτερο, πρόσθεσα στα replace όλες τις περιπτώσεις με τα σημεία στίξης. Με ένα σύστημα cache, για μεγαλύτερη ταχύτητα, το replace για τα acronyms έπαιξε καταπληκτικά, καλύπτοντας όλες τις περιπτώσεις που είχα στο site.

Με αυτό το utility κατάφερα εκτός των άλλων, να κατασκευάσω και ένα μικρό xhtml validator, γιατί αν υπάρχει έστω και ένα πρόβλημα στο html, βρίσκει το error ο parser, και σταματάει η εκτέλεση του. Αυτό το utility, το χρησιμοποιήσαμε στην Netwerk και προσθέσαμε στο cms μας την δυνατότητα για inner linking.

Καθώς έγγραφα το post σκεφτικά, δεν βάζω το utility στo phpclasses ? http://www.phpclasses.org/browse/package/4599.html

php

Site verification over mod_rewrite or error 404 redirect

May 6th, 2008

Ένας τρόπος για να ελέγχεις αν ανήκει ένα domain σε κάποιον, είναι να του ζητήσεις να βάλει ένα αρχείο (zero byte) στον docroot του site του, όπως γίνεται στο google html verification. Αυτό είναι εύκολο να το ελέγξεις με php χρησιμοποιώντας την fopen ή την fsockopen. Τι γίνεται όμως αν υπάρχει rewrite module για να έχει friendly urls (seo) ή error 404 με redirect σε κάποια άλλη σελίδα (παλιά τεχνική – σήμερα αποφεύγεται για διάφορους λόγους). Σε αυτές τις δύο περιπτώσεις, χωρίς να υπάρχει το αρχείο, ο έλεγχος θα βρίσκει ότι υπάρχει. Η λύση είναι πολύ απλή, ανοίγουμε το connection και διαβάζουμε τα raw data. Αν δεν υπάρχει η σελίδα το connection θα αποτύχει. Αν όμως πετύχει το connection τότε θα πρέπει να μην υπάρχουν καθόλου raw data.

function url_valid($url) {
	$found=true;
	$fp=@fopen($url,"r");
	if ($fp) {
		if (fgetc($fp)) $found=false;
		fclose($fp);
	} else
		$found=false;
	return $found;
}

mod_rewrite, php ,

How to create thumbs with mod_rewrite, php and gd2

May 2nd, 2008

Σε συνεργασία με τον Παρασκευά Σμυρλάκη, υπεύθυνο του τμήματος Seo Development της εταιρείας Netwerk, σκεφτήκαμε ένα έξυπνο τρόπο για να φτιάχνεις thumbs on the fly σε μία gallery από φωτογραφίες. Εκμεταλλευτήκαμε τις δυνατότητες του mod rewrite, για να ελέγχουμε αν υπάρχει το thumb αρχείο στον δίσκο, και αν δεν υπάρχει να το κατευθύνουμε σε ένα php script που με την σειρά του το δημιουργεί.

Ποιο συγκεκριμένα έχουμε μία σελίδα που θέλουμε να δημιουργήσουμε ένα thumb στο html δίνουμε απλά την διαδρομή του thumb <img src=”/photos/thumb/demo.jpg” />.

Αυτό που χρειάζεται είναι ένα .htaccess στο folder thumb με το παρακάτω.

RewriteEngine on
RewriteBase /
RewriteCond %{REQUEST_FILENAME} !-f

RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*) /thumb.php?ph=$1&w=100&h=100&q=70 [L,QSA]

Για όσους δεν το καταλάβανε, ελέγχουμε αν είναι file ή folder με τα RewriteCond και αν δεν είναι το κατευθύνουμε με RewriteRule στο thumb.php με παραμέτρους το $ph το όνομα του αρχείου και $w & $h το μέγεθος του thumb και $q την ποιότητα του jpeg.

Το php script thumb.php κατασκευάζει το thumb μεγέθους ($w x $h), χρησιμοποιώντας το php extension για gd2. Διαβάζει από το /photos/normal/ την μεγάλη φωτογραφία δημιουργεί το thumb και το αποθηκεύει στον φάκελο /photos/thumb/ με το όνομα που έχει περάσει στην μεταβλητή $ph. Επειδή αυτό το script τρέχει μέσα από το img tag, επιστρέφει με header για jpeg και τα raw data του thumb.

<?php
header("Content-type: image/jpeg");
$imNormal=ImageCreateFromString(file_get_contents("photos/normal/".$_GET['ph']));
$imThumb=ImageCreateTrueColor($_GET['w'],$_GET['h']);
ImageCopyResampled($imThumb,$imNormal,0,0,0,0,$_GET['w'],$_GET['h'],ImageSX($imNormal),ImageSY($imNormal));
ImageJpeg($imThumb,"photos/thumbs/".$_GET['ph'],$_GET['q']);
ImageJpeg($imThumb,"",$_GET['q']);
ImageDestroy($imNormal);
ImageDestroy($imThumb);
?>

Εμείς πάντως κάναμε ένα ακόμα βήμα παραπέρα, και με δύο .htaccess καταφέραμε κάτι ακόμα ποιο advanced. Το αφήνω στην φαντασία σας.

mod_rewrite, php