0

在我的一个数据库表中,我发现了一些损坏的单词,例如:

Noël, japón, Świata

我后来发现应该是:

Noël, japón, świata

任何人都知道如何使用PHP将它们恢复正常

4

2 回答 2

1

不幸的是,它不能通过使用 php 转换来恢复。我刚刚制作了一个 PHP 脚本,它尝试了所有组合,不止一次(最多 5 次)并且没有一个产生“japón”。所以这是不可能的。

脚本:

<?php
$encodings=mb_list_encodings();
foreach($encodings as $enc_to) {
    foreach($encodings as $enc_from) {
        $str="Noël, japón, Świata";
        for ($i=0;$i<5;$i++) {
            $str=mb_convert_encoding($str,$enc_to,$enc_from);
            echo "$enc_from -> $enc_to ($i): ".$str."\n";
            echo "$enc_from -> $enc_to ($i) + html_entity_decode: ".html_entity_decode($str)."\n";
            echo "$enc_from -> $enc_to ($i) + htmlspecialchars_decode: ".htmlspecialchars_decode($str)."\n";
            echo "$enc_from -> $enc_to ($i) + urldecode: ".urldecode($str)."\n";
            echo "$enc_from -> $enc_to ($i) + htmlentities: ".htmlentities($str)."\n";
            echo "$enc_from -> $enc_to ($i) + htmlspecialchars: ".htmlspecialchars($str)."\n";
            echo "$enc_from -> $enc_to ($i) + urlencode: ".urlencode($str)."\n";
        }
    }
}

... grepping 输出没有捕获“japón”

于 2014-02-08T14:07:33.833 回答
1

或者,您可以检查问题是否与使用的字符编码有关iconv-检查 php 手册

于 2014-02-08T14:08:38.900 回答