Heim >Backend-Entwicklung >PHP-Tutorial >mysql - php上传含中文名的图片失败问题

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

WBOY
WBOYOriginal
2016-06-06 20:51:001343Durchsuche

代码:

$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么?问什么你还转码了一次?

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn