php - 无法将表情符号存储在数据库中

标签 php android ios mysql codeigniter

情况:

如果这个问题已经被问过,但解决方案对我不起作用,请提前道歉。

无论我尝试什么,我都无法将表情符号存储在我的数据库中。它们被保存为 ????
唯一正确保存的表情符号是只需要 3 个字节的表情符号,例如害羞的脸或太阳。

实际的 utf8mb4 不起作用。

Database screenshot

它已经在 Android 和 Ios 上进行了测试。结果相同。

版本:

Mysql:5.5.49
CodeIgniter:3.0.0

步骤:

  1. 我已修改数据库字符集和排序规则属性。

    ALTER DATABASE my_database CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci

  2. 我已经修改了表格字符集和排序规则属性。

    ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci

  3. 如果可能,我已将表格的每个字段设置为编码:UTF-8(ut8mb4) 和排序规则:utf8mb4_unicode_ci

  4. 我在 CodeIgniter 应用中修改了数据库连接。

  5. 我已运行以下命令:SET NAMES utf8mb4 COLLATE utf8mb4_unicode_ci

  6. 最后我也试过这个: 修复表表名; 优化表表名;

一切都应该正确设置,但它不起作用。

数据库设置:

这是运行以下命令的结果:

`SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collation%';`

Database settings

表格设置:

表格结构的截图:

Table settings

数据库连接:

这些是database.php中的数据库连接设置(注意这不是唯一的数据库,还有其他使用utf8连接的)

$db['my_database'] = array(
        'dsn'           => '',
        'hostname'      => PROJECT_DATABASE_HOSTNAME,
        'username'      => PROJECT_DATABASE_USERNAME,
        'password'      => PROJECT_DATABASE_PASSWORD,
        'database'      => PROJECT_DATABASE_NAME,
        'dbdriver'      => 'mysqli',
        'dbprefix'      => '',
        'pconnect'      => FALSE,
        'db_debug'      => TRUE,
        'cache_on'      => FALSE,
        'cachedir'      => '',
        'char_set'      => 'utf8mb4',
        'dbcollat'      => 'utf8mb4_unicode_ci',
        'swap_pre'      => '',
        'encrypt'       => FALSE,
        'compress'      => FALSE,
        'stricton'      => FALSE,
        'failover'      => array(),
        'save_queries'  => TRUE
    );

MY.CNF 设置:

这是my.cnf文件的全部内容:

[mysqld]
default-storage-engine=MyISAM
innodb_file_per_table=1
max_allowed_packet=268435456
open_files_limit=10000
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci

[client]
default-character-set = utf8mb4

[mysql]
default-character-set = utf8mb4

问题:

你知道为什么不工作吗?我错过了什么吗?

假设 1:

我不确定,但问题的原因可能是这样的:

正如您在 my.cnf 中看到的,character-set-server 明确设置为 utf8mb4:

但是在数据库中运行查询后:

SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collat​​ion%';

结果是 character-set-server = latin1

你知道这是为什么吗?为什么实际上没有更新?

假设 2:

应用程序使用几个不同的数据库。 这个设置为 utf8mb4,但所有其他设置为 utf8。即使它们是分开的数据库,也可能有问题?

谢谢!

编辑:

这是 SHOW CREATE TABLE app_messages;

的结果
CREATE TABLE `app_messages` (
  `message_id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
  `project_id` bigint(20) NOT NULL,
  `sender_id` bigint(20) NOT NULL,
  `receiver_id` bigint(20) NOT NULL,
  `message` text COLLATE utf8mb4_unicode_ci,
  `timestamp` bigint(20) DEFAULT NULL,
  `is_read` enum('x','') COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  PRIMARY KEY (`message_id`)
) ENGINE=InnoDB AUTO_INCREMENT=496 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci

编辑 2:

我已经运行了以下命令:

INSERT INTO app_messages (message_id, project_id, sender_id, receiver_id, message, timestamp, is_read)
VALUES ('496','322','77','188', '😜' ,'1473413606','x');

和其他两个与😂和👻相似

它们被毫无问题地插入到表中:

enter image description here

但在实际应用中,我真正看到的是:?(这次只有一个?而不是 4 个)

最佳答案

好吧,我终于成功了! 感谢所有试图帮助我的人,尤其是@Rick James 和@Gerard Roche。

建议:

如果您需要使用表情符号,首先在 localhost 上进行简单的测试。创建一个新数据库并制作一个新的应用程序用于测试目的。

如果您按照我在问题中写的步骤或按照本教程进行操作:https://mathiasbynens.be/notes/mysql-utf8mb4#utf8-to-utf8mb4它必须工作。

在本地开发新的基本应用程序,您将拥有更多控制权和更多空间来进行所需的所有测试。

解决方案:

就我而言,问题在于 CodeIgniter 中的数据库配置。它没有正确设置 char_set 和排序规则以进行愚蠢的忽略:我覆盖了保存消息的函数中的数据库设置,以确保它与移动数据库一起使用。

之前:

function message_save ( $data = FALSE )
{   
    $project_db_config                  = array();
    $project_db_config['hostname']      = 'MY_HOST';
    $project_db_config['username']      = 'MY_USERNAME';
    $project_db_config['password']      = 'MY_PASSWORD';
    $project_db_config['database']      = 'MY_DATABASE';

    $mobile_db                          = $this->load->database( $project_db_config, TRUE );

    // other code to save message       
}

之后:

function message_save ( $data = FALSE )
{
    $mobile_db_connection = $this->load->database('admin_mobile_mh', TRUE);

    // other code to save message
}

结论:

应用程序必须正确设置与数据库的连接。 如果您正确设置了数据库,但没有与您的应用建立正确的连接,它将无法正常工作。

因此,如果您遇到类似问题,请确保 api 正确设置 char_setutf8mb4db_collat​​utf8mb4_unicode_ci.

关于php - 无法将表情符号存储在数据库中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39326125/

相关文章:

iphone - 如何在Xcode中打开全屏摄像头

php - 通过 PHP 执行。我无法将输出(stderr)放入文件中

android - 奖励视频 AdMob 中介、Applovin 和 Chartboost - 加载失败

android - 证书固定 - 当恶意开发人员在 Android 中获取证书文件时会发生什么

Android SmsManger 发送报告

ios - geocodeaddressString 提供了错误的坐标

php - mysql查询中如何绑定(bind)参数?

php - 一次更新多个等级

javascript - PHP 代码 - 在一台 PC 上保存变量,而不仅仅是 cookie

当我尝试将 swift 框架与 objective-c 项目链接时,iOS 应用程序崩溃