mysql - php上传含中文名的图片失败问题
程序员文章站
2024-01-01 20:09:10
...
代码:
$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的编码
- 上传的文件名
$_FILES['upload']['name']
。看你的代码,把这个由gb2312转成utf8了,但是先要确定你的原文件名上传上来是否真的是gb2312,需要转换,如果不需要转换。 - 存入数据库的时候,你的数据库是什么格式的
- 数据库读出来的时候,展示的地方是什么格式的
建议你检查这三个地方,分别打印出来看下,统一编码,可以解决问题
linux下面的文件,尽量不要用中文命名
直接
$upfile='uploads/'.rand(0,10000).date('YmdHis');
你存文件名有啥用啊- -。
一般采取的方式是:上传后重新命名,在服务器采用存储对应表的方式,进行配对。各种操作系统存储文件的编码都不一样,而程序代码的编码也是各种各样,统一重命名存储是最好的方式。
你的上传form的html page的encoding难道不是utf-8么?问什么你还转码了一次?