网络管理开发常见问题
http网络请求中extraData支持的数据格式有哪些
适用于:OpenHarmony 3.2 Beta API 9
解决措施
extraData代表发送请求的额外数据,支持如下数据:
- 当HTTP请求为POST、PUT方法时,此字段为HTTP请求的content。
- 当HTTP请求为GET、OPTIONS、DELETE、TRACE、CONNECT方法时,此字段为HTTP请求的参数补充,参数内容会拼接到URL中进行发送。
- 开发者传入string对象,开发者需要自行编码,将编码后的string传入。
http请求的错误码28是什么意思
适用于:OpenHarmony 3.2 Beta API 9
问题现象
发起http请求后报错,错误码28。
解决措施
错误码28代表CURLE_OPERATION_TIMEDOUT,操作超时。网络请求底层使用libcurl库,更多错误码可以查看相应文档。
参考链接
http请求中response错误码返回6是什么意思
适用于:OpenHarmony 3.2 Beta API 9
问题现象
发起http请求后,返回信息中response错误码为6。
解决措施
错误码6表示地址无法解析主机,可以尝试ping一下request中的URL,确认是否可以ping通。
参考链接
更多错误码参考Response常用错误码或者Curl错误码
@ohos/axios三方件post请求queryParams参数场景下如何传参
适用于:OpenHarmony 3.2 Beta API 9
问题现象
三方件@ohos/axios中发起post请求,以queryParams形式传递参数(将参数拼接在URL后)。
解决措施
-
方式一:使用axios.post接口只接收一个参数,Url.URLSearchParams需要转成字符串拼接在url后面。
let params:Url.URLSearchParams = new Url.URLSearchParams() params.append('ctl', 'sug') params.append('query', 'wangjunkai') params.append('cfrom', '1099a') axios.post('http://10.100.195.234:3000/save?' + params.toString()).then(res => { this.message = "request result: " + JSON.stringify(res.data); }).catch(err => { this.message = "request error: " + err.message; })
-
方式二:使用axios接口只接收一个config对象,请求参数写在config对象的params中。
axios({ url: 'http://10.100.195.234:3000/save', method: 'post', params: { ctl: 'sug', query: 'wangjunkai', cfrom: '1099a' } }).then(res => { this.message = "request result: " + JSON.stringify(res.data); }).catch(err => { this.message = "request error: " + err.message; })
connection.getNetCapabilities(mNetHandle)无法正常返回结果
适用于:OpenHarmony 3.2 beta2 API 9
问题现象
在网络连接管理中,调用connection.getNetCapabilities()函数时无法取到数据。
原因分析
this指向存在问题,用(err,data)=>{}可以进入回调函数并且拿到返回结果数据,不能使用function(err,data),因为function声明的函数内存在自己的this,无法指向全局的this。
解决措施
getNetCapabilities的第二个参数把function(err,data)改成(err,data)。
http请求如何以json形式进行传输
适用于:OpenHarmony 3.2 Beta API 9
解决措施
在HTTP协议消息头中,使用Content-Type来表示媒体类型信息。它被用来告诉服务端如何处理请求的数据,以及告诉客户端(一般是浏览器)如何解析响应的数据,比如显示图片,解析html或仅仅展示一个文本等。
设置该参数值为application/json,请求中的数据就会以json形式进行传输。
this.options = {
method: http.RequestMethod.GET,
extraData: this.extraData,
header: { 'Content-Type': 'application/json' },
readTimeout: 50000,
connectTimeout: 50000
}
调用camera拍摄的照片如何上传到服务器
适用于:OpenHarmony 3.2 Beta5 API 9
问题现象
应用调用摄像头拍照后如何将图片上传到服务器?
解决措施
启动应用,获取权限后系统会访问远程服务器,将拍摄照片保存在本地,通过上传接口将文件从个人设备传送至远程服务器。
参考链接
设备网络正常,调用connection.hasDefaultNet()接口失败
适用于:OpenHarmony 3.2 Beta API 9
问题现象
设备可以上网,浏览器可以正常打开网页,但是hasDefaultNet这个方法调用失败,回调函数走到了失败的回调。
解决措施
connection.hasDefaultNet 接口需要注明需要权限ohos.permission.GET_NETWORK_INFO
权限申请链接:访问控制授权申请
如何理解connection.getDefaultNet返回对象netHandle中的netId
适用于:OpenHarmony 3.2 Beta API 9
问题现象
netId的值如0、100分别代表什么含义?
解决措施
正常情况下,netHandle里的netId为0时表示没联网,大于等于100时为有网状态。
如何使用http请求从网络上获取数据
适用于:OpenHarmony 3.2 Beta API 9
解决措施
使用@ohos.net.http模块来发起http网络请求。
- 导入http模块,创建http请求对象。
- 设置请求地址URLl和参数,发起http请求。
- 获取请求结果response,并解析数据。
参考链接
详细信息请参考:http数据请求
如何使用JS封装网络请求
适用于:OpenHarmony 3.2 Beta API 9
解决措施
OpenHarmony网络请求支持JS语言开发方式,可直接使用。具体使用参考如下文档:网络连接
基于JS开发智能手表应用,如何编写网络请求
适用于:OpenHarmony 3.2 Beta API 9
解决措施
OpenHarmony网络请求支持JS语言开发方式,可直接使用。具体使用参考如下文档:网络连接
应用增加权限"ohos.permission.NOTIFICATION_CONTROLLER",编译后无法启动
适用于:OpenHarmony 3.2 Beta API 9
问题现象
启动报错:error: install failed due to grant request permissions failed.
解决措施
权限"ohos.permission.NOTIFICATION_CONTROLLER为系统级“system core”权限,第三方应用无法获取该权限。
WiFi模块中使用wifi.getIpInfo().ipAddress报错
适用于:OpenHarmony 3.2Beta API 9
问题现象
WiFi模块中使用wifi.getIpInfo().ipAddress,报错Error: assertion (wifiDevicePtr != nullptr) failed: Wifi device instance is null
解决措施
权限不足。请先检查是否申请了相关的操作权限,权限相关信息可参考权限管理。