sql >> Databasteknik >  >> RDS >> Mysql

Fel med tecken i en HTML-iframe

Om problemet inte finns i filerna som ska visas i ramen kan det vara problemet i data. Jag försöker alltid konfigurera PHP, Apache och MySQL med UTF8. För detta redigerar jag några konfigurationsfiler.

MySQL: /etc/my.cnf

[client]
default-character-set=utf8

[mysqld]
character-set-server=utf8
init-connect='SET NAMES utf8'
character-set-client=utf8
character_set_results=utf8

Sedan:

sudo service mysql restart

PHP: /etc/php.ini

default_charset = "UTF-8"

Apache: /etc/apache2/conf.d/charset

AddDefaultCharset UTF-8

Sedan:

sudo service apache2 restart

En annan sak att tänka på när du ansluter till databasen:

...
$link = mysql_connect(SERVER, USER, PASSWORD);
mysql_set_charset('utf8', $link);
...

Du kan se alla teckenrelaterade variabler med:

SHOW VARIABLES LIKE 'c%';

+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | utf8                       |
| character_set_filesystem | binary                     |
| character_set_results    | utf8                       |
| character_set_server     | utf8                       |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
| collation_connection     | utf8_general_ci            |
| collation_database       | utf8_general_ci            |
| collation_server         | utf8_general_ci            |
| completion_type          | NO_CHAIN                   |
| concurrent_insert        | AUTO                       |
| connect_timeout          | 10                         |
+--------------------------+----------------------------+

Du måste se till att sidan som visas i iframe-taggen också har:

<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>

Jag hoppas att det hjälper något.




  1. XOR-begränsning i Mysql

  2. En Mysql-tabell med flera TIMESTAMP-kolumner

  3. IS NOT NULL-testet för en post returnerar inte TRUE när variabeln är inställd

  4. STORT OSIGNERAD VÄRDE ÄR utanför intervallet Min SQL