ホームページ >バックエンド開発 >PHPチュートリアル >mysql - php上传含中文名的图片失败问题

mysql - php上传含中文名的图片失败问题

WBOY
WBOYオリジナル
2016-06-06 20:51:001343ブラウズ

代码:

$upfile='uploads/'.rand(0,10000).date('YmdHis').iconv("gb2312", "UTF-8", $_FILES['upload']['name']); //$upfile是上传图片的链接地址,存入数据库

在数据库显示的链接地址中原来的图片中文名不能显示出来,而且图片后缀格式显示不出来
比如数据库显示的链接是:uploads/34420121102122153android寮
而原来上传的图片是:android开发框架.jpg

回复内容:

代码:

$upfile='uploads/'.rand(0,10000).date('YmdHis').iconv("gb2312", "UTF-8", $_FILES['upload']['name']); //$upfile是上传图片的链接地址,存入数据库

在数据库显示的链接地址中原来的图片中文名不能显示出来,而且图片后缀格式显示不出来
比如数据库显示的链接是:uploads/34420121102122153android寮
而原来上传的图片是:android开发框架.jpg

首先,肯定是编码问题造成的。
你这里有三个地方涉及到编码问题,之间存在转换,很可能错乱,我建议你全部统一utf8的编码

  1. 上传的文件名 $_FILES['upload']['name']。看你的代码,把这个由gb2312转成utf8了,但是先要确定你的原文件名上传上来是否真的是gb2312,需要转换,如果不需要转换。
  2. 存入数据库的时候,你的数据库是什么格式的
  3. 数据库读出来的时候,展示的地方是什么格式的

建议你检查这三个地方,分别打印出来看下,统一编码,可以解决问题

linux下面的文件,尽量不要用中文命名

直接

$upfile='uploads/'.rand(0,10000).date('YmdHis');

你存文件名有啥用啊- -。

一般采取的方式是:上传后重新命名,在服务器采用存储对应表的方式,进行配对。各种操作系统存储文件的编码都不一样,而程序代码的编码也是各种各样,统一重命名存储是最好的方式。

你的上传form的html page的encoding难道不是utf-8么?问什么你还转码了一次?

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。