问题描述
在跟公司后台配合的上传zip压缩文件,上传成功,但是用mac登录内管平台登录,下载zip文件,zip解压缩之后不会出现文件乱码,但是使用windows电脑登录内管平台,下载zip文件,zip文件解压之后出现乱码
问题分析
认为iphone是基于Unix的,和windows的有区别,然后就联想到是不是服务器在接受文件的时候修改了编码格式
第三方库的原因导致编码格式不正确
解决问题
通过自己和服务器的调试发现,服务器的编码格式是默认UTF8但是windows电脑默认的编码格式是GBK的编码格式,因为编码格式不一致从而导致了文件解压之后乱码
mac支持UTF8编码,所以解压缩文件出来不会导致文件乱码
最后查看了一下第三方库的编码格式,默认的UTF8编码,在压缩文件时将编码格式修改为GBK编码格式
代码如下
- 在生成压缩文件的时候把字符串的编码转成C语言的char类型时转成GBK的编码格式,代码如下
//先创建编码格式
NSStringEncoding gbkEncoding = CFStringConvertEncodingToNSStringEncoding(kCFStringEncodingGB_18030_2000);
//将要转换的字符串转换成GBK编码格式的NSData流
NSData *data =[fileName dataUsingEncoding:gbkEncoding];
//定义文件名称
const char *cfileName;
//给文件名称赋值
cfileName = data.bytes;
- 然后再进行后续的压缩操作,上传操作即可
问题补充
后来在实际测试的过程中发现会导致文件名的后缀出现乱码,导致电脑无法识别文件的具体类型
后来分析了一下应该是char的fileName在赋值操作时没有很好的识别字符串的结束,即data的长度和char的长度不一致,在赋值的时候有可能多读了,多所以将上述代码更改为一下代码就不会有问题了
//先创建编码格式
NSStringEncoding gbkEncoding = CFStringConvertEncodingToNSStringEncoding(kCFStringEncodingGB_18030_2000);
//将要转换的字符串转换成GBK编码格式的NSData流
NSData *data =[fileName dataUsingEncoding:gbkEncoding];
//定义文件名称
const char *cfileName = NULL;
//给文件名称赋值
cfileName = data.bytes;
cfileName[data.length] = '\';