跨平台应用开发进阶(三十六) :uniapp使用uni(1)

在以上前提下还出现这种问题,最有可能的原因:手机没有连网,或者看着连上了网但实际网络不可用,可以在手机浏览器中随便输入点文字搜一下测试看看,能不能搜到新内容。

仔细查看,这个{"errMsg":"request:fail abort statusCode:-1 未能找到使用指定主机名的服务器。(-1003)"} 返回值,其实并不是服务端返回来的,因为请求都完全没有到服务端。

2.2 https ssl证书解析(未得到验证)

通过对比前后版本差异,发现前期后台请求方式为http:IP形式,当前后台请求方式为https:域名形式。通过http:域名形式检测,未发现以上现象。排除法怀疑问题出在ssl证书验证阶段。

但是andriod不会出现以上问题,只有ios才会出现以上问题。难道androidios在校验证书方面存在差异?

通过抓包工具Stream分析发现,在出现网路连接问题时抓包信息如下:

在这里插入图片描述

抓包详情信息如下:

在这里插入图片描述

2.3 data序列化错误

从网上看到如下解释,经过实践,发现问题解决了。

官方文档上说uni.requestcontent-type:application/json时会尝试对data进行序列化。手动将原本是json的数据转成字符串传进去就可以了,希望官方可以对这一块进行优化吧。

2.4 TCP握手超时失败

通过WhireShark捕获网络层数据,发现TCP握手超时。

并在dmz区的服务器上捕获 netstat packets rejects in established connections because of timestamp 有这个错误。

通过系统参数优化可解决TCP握手超时问题。

在入口服务器打开编辑文件/etc/sysctl.conf,加入以下内容:

net.ipv4.tcp_tw_reuse=0
net.ipv4.tcp_tw_recycle=0
net.ipv4.tcp_fin_timeout=10
net.ipv4.ip_local_port_range=1024 65535
net.core.somaxconn=65535
vm.drop_caches=1
vm.swappiness=0
fs.file-max=10485760

然后执行 /sbin/sysctl -p 让参数生效。

三、解决办法

3.1 网络检测

针对手机没有连网的场景,在执行uni.request()向服务端请求前,使用uni.getNetworkType()uni.onNetworkStatusChange()对网络进行监听,如果监听到当前设备是处于无网络的状态时,就不执行uni.request()请求,而是弹出一个弹框或者消息提示,提醒用户:“当前设备断网了,请检查网络后重试”。

uni. onNetworkStatusChange
触发时机:在网络切换的时候执行,切换2G,3G,WiFi的时候会执行。
应用时机:一般都会放在 onShow里面,实时监听网络的切换。当应用关闭后台的时候在 onHide 生命周期函数中执行 uni.offNetworkStatusChange()关闭监听网络。

uni.getNetworkType
触发时机:在页面初始化的时候,或者是在方法执行的时候执行。
应用时机:可以再onShowonLoad这样的生命周期里面来执行,也可以在点击事件中添加执行,属于即用即取的。

3.2 请求封装

在使用uni.request进行网络请求时,对入参data进行JSON.stringfy()序列化操作。

return new Promise((resolve, reject) => {
	uni.request({
		url: curUrl,
		method: method || "POST",
		header: {
			'Content-Type': 'application/json',
			'Authorization': 'Basic'
		},
		// header: headerForm,
		data: JSON.stringfy(data) || {},
		success(res) {
			setToken(res.data)
			resolve(res.data)
			console.log('The request url(' + curUrl + ') success return info is: ', res.data)
		},
		fail(err) {
			reject(err)
			console.log('The request url(' + curUrl + ') fail return info is: ', err)
		},
		complete() {


## 最后

今天的文章可谓是积蓄了我这几年来的应聘和面试经历总结出来的经验,干货满满呀!如果你能够一直坚持看到这儿,那么首先我还是十分佩服你的毅力的。不过光是看完而不去付出行动,或者直接进入你的收藏夹里吃灰,那么我写这篇文章就没多大意义了。所以看完之后,还是多多行动起来吧!

可以非常负责地说,如果你能够坚持把我上面列举的内容都一个不拉地看完并且全部消化为自己的知识的话,那么你就至少已经达到了中级开发工程师以上的水平,进入大厂技术这块是基本没有什么问题的了。

**[开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】](https://bbs.csdn.net/topics/618166371)**
  • 8
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值