1

我使用 PHP 创建了一个简单的代码,用于将图片上传到文件夹。

在服务器端我有

    <?php

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

//check if file is actually an image etc.

//if is an image, send it to "upload" folder
     move_uploaded_file($_FILES["file"]["tmp_name"],"upload/" . $_FILES["file"]["name"]);

//save to the database a string like "upload/myImage.jpg", so I can render it on the site later
$stu = $dbh->prepare("UPDATE multi SET m_place=:name WHERE m_id = :id");
$stu->bindParam(':name', $n, PDO::PARAM_STR);
$n= "upload/".$_FILES["file"]["name"];                                          
$stu->execute();

问题?

如果文件夹中的图像名称是英文,我会看到“myImage01.jpg”,并且在数据库中还会看到“upload/myImage01.jpg”。但是,如果图像的名称在文件夹中是希腊语,我会看到“χωΟΞ―Ο, τίτλο.jpg”和数据库中的“上传/χωΟΞ- Ο, τίτλο.jpg"。这是错误的。Insted χωΟΞ―Ο, τίτλο 我应该得到“χωρις τιτλο”(顺便说一句,那是希腊语的“无标题”)。所以,我猜是字符集问题?

我该如何解决?

提前致谢

4

2 回答 2

2

听起来您的数据库没有正确的排序规则。确保表格/列utf8_general_ci用于其排序规则。

处理 UTF8 时也非常重要的是使用以下两行 MySQLGET请求...

SET time_zone = '+00:00'
SET CHARACTER SET 'utf8'

...当您有POST请求时,请使用以下两个...

SET time_zone = '+00:00'
SET NAMES 'utf8'

这些将有助于确保正确维护 UTF8 字符。

于 2013-09-22T17:47:50.913 回答
0

最后,我发现“PHP 文件系统函数只能处理系统代码页中的字符”。多亏了这个,我解决了我的问题。

我使用了这个iconv功能

所以我move_uploaded_file像这样改变了这条线

move_uploaded_file($_FILES["file"]["tmp_name"],"upload/" . iconv('UTF-8', 'Windows1253',$_FILES["file"]["name"]));
于 2013-09-26T18:25:29.730 回答