views:

32

answers:

2

Hi there ! I have a question! I want to print an unicode string in php (like 'سلام')! but when I use echo only some ??? apear!!!

what whould I do??? This happens hen I want to cho string that retrieved from database!

echo 'سلام';

result is:

????

I tried using header function but that didn't help me!

+1  A: 

You need to declare the used character encoding in the HTTP response. You can use the header function:

header('Content-Type: text/html;charset=utf-8');

With this the output is declared to be HTML with the character encoding UTF-8. Note that you can’t use header when you’ve already sent data to the client without buffering it. So either use the output control to buffer the output so that you can modify the header although there already was some output or use header before any output.

Gumbo
Thanks a lot but as I said It didn't work!!!
Aseman
+1  A: 

You need to do three things:

  1. Make sure you're receiving the data as UTF-8 data. For MySQL, query SET NAMES 'utf8' before selecting records.
  2. Make sure you're using UTF-8 compatible functions when dealing with UTF-8 strings.
  3. Make sure you're setting the output encoding as UTF-8. For HTML, this can be done by setting the Content-type HTTP header to (e.g.) text/html; charset=utf-8.

Of course, replace "UTF-8" with whatever encoding you want which supports the characters you need. There's no need to change the database tables (except for possible performance gains). You may need to change HTML templates, etc. if you decide on UTF-16 or something else which isn't (mostly) ASCII-compatible.

strager
If you plan on storing unicode data in mysql, you need to use a charset which supports it. Per default, Mysql uses latin1, but you can switch to utf-8.
troelskn
@troelskn, I'm assuming the data was already stored properly. I mentioned changing database tables because, say, if the site switches to UTF-16, the database's data's character set doesn't need to be changed, because the conversion is made for you.
strager