因为一项目,有几个页面都需要访问服务器,从服务器上下载数据,在苹果和开发者工具上都运行完美,唯独一款安卓手机,访问不了,经测试,发现是汉字编码问题,苹果的编码是UTF-8,然后自动转换成%E5%C8%......,但安桌却是将E5转换成C3 A5,到服务器之后,服务器不能接受此种表示方法。只好将wx.request中的 url全部转换成 https://....../%E5%90....这种字符串格式,服务器这才表示认识。问题解决。下面是转换函数:
function hexToString(str) {
var val =
"";
var buf = Buffer.alloc(str.length *
3);
var j =
0;
for (
let i =
0; i < str.length; i++) {
if (str[i] <
0x80) buf[j++] = str[i];
//ascii字符无需转换
else {
val = str[i].toString(
16).toUpperCase(); // 大于0x80的字符转换成字符串如oxE5--->'E5'
buf[j++] =
0x25; // 增加%
buf[j++] = (parseInt(val[
0],
16) <
10) ? (parseInt(val[
0],
16) +
48) : (parseInt(val[
0],
16) +
55);//将数字与字符(A-F)分开
buf[j++] = (parseInt(val[
1],
16) <
10) ? (parseInt(val[
1],
16) +
48) : (parseInt(val[
1],
16) +
55);
}
}
return buf.toString().slice(
0, j); // 只取前面的字符串,后面的空字符删掉
}
第二个问题,也是安卓,也是其中一个页面访问不了服务器,调试到山穷水尽的时候,突然发现,会不会是因为请求的字符串中有空格的原因,去掉空格,将空格换成&之后,立马过关,但在苹果,开发者工具中,却不存在这个问题,安卓真是个奇怪的东西。下面是部分代码:
var flag =
1 ;
var buf = Buffer.from(company +
'?' + username +
'?' + devnum +
'?STA:' + hasTime+
':' + start +
'&' + shms +
'&to&' + end +
'&' + ehms +
'&now&' + hms +
'?');
var tbuf = hexToString(buf) ;
var surl = serurl +
'/2?' + tbuf ;
// console.log(surl)
timer = setInterval(
function () {
wx.request({
url: surl ,
success: res => {
// console.log(res.data)
var status = res.data.status ;
if(status ==
undefined) {
// console.log(status)
return ;
}