首页 > 后端开发 > php教程 > mysql - php上传含中文名的图片失败问题

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

WBOY
发布: 2016-06-06 20:51:00
原创
1342 人浏览过

代码:

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

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板