最近在搞微信小程序开发,要远程连接PHP文件,在小程序端输入文字用微信小程序wx.request的方法请求和提交数据,然后返回给后端,后端用PHP连接MySQL数据库,然后把返回的数据以接送格式发送回小程序,而json格式对中文是有讲究的,这时候就出现了中文转换的乱码问题,在踩过无数次坑各种百度以后,得到下面几个结论:
1、从微信小程序发送过去的数据,在服务器端如果是GB2312格式编码的PHP文件是可以正确接收并写入数据库的,判断PHP文件是否是GB2312编码格式可以用nopad++打开服务器的PHP文件,通过右下角判断,如图。

2、从PHP文件(编码为GB2312)写入的中文要response回小程序中要进行格式转换,转换的方法是调用iconv函数,
iconv('GBK','UTF-8','中文');
也就是把源格式GBK(理论上GB2312也是可以的,不过GBK向下兼容GB2312,所以写成GBK)转化为UTF-8,然后返回给小程序,以防万一,在小程序端的header要设置:'content-type': 'application/x-www-form-urlencoded;charset=utf-8',
这样子就能保证数据写入和读出都不会乱码。
小程序端显示
数据库显示
在微信小程序开发中,遇到通过wx.request与PHP后台交互时的中文编码问题。解决方法包括:确保PHP文件为GB2312编码,使用iconv函数将GBK转为UTF-8以避免乱码,并在小程序端设置header以保证正确的字符集。
3069

被折叠的 条评论
为什么被折叠?



