# 1. 小程序开发快速指引 - [1. 小程序开发快速指引](#1-小程序开发快速指引) - [1.1. 开发环境准备](#11-开发环境准备) - [1.1.1. 申请小程序账号](#111-申请小程序账号) - [1.1.2. 小程序管理后台](#112-小程序管理后台) - [1.1.3. 安装开发工具](#113-安装开发工具) - [1.2. 智能灯小程序Demo](#12-智能灯小程序demo) - [1.2.1. 概述](#121-概述) - [1.2.2. 前置工作](#122-前置工作) - [1.2.3. 普通开发方式(SDK)](#123-普通开发方式sdk) - [1.2.3.1. 导入工程](#1231-导入工程) - [1.2.3.2. 修改配置](#1232-修改配置) - [1.2.3.3. 功能扩展](#1233-功能扩展) - [1.2.4. 云开发方式(云函数)](#124-云开发方式云函数) - [1.2.4.1. 导入工程](#1241-导入工程) - [1.2.4.2. 开通云开发,创建环境](#1242-开通云开发创建环境) - [1.2.4.3. 部署云函数](#1243-部署云函数) - [1.2.4.4. 修改配置](#1244-修改配置) - [1.2.4.5. 功能扩展:结合API 3.0 Explorer工具快速实现云函数](#1245-功能扩展结合api-30-explorer工具快速实现云函数) - [1.2.5. 调试和发布](#125-调试和发布) - [1.2.6. 配置信息说明](#126-配置信息说明) - [1.3. FAQ](#13-faq) - [1.3.1. 网络请求报错: reqeust:fail url not in domain list](#131-网络请求报错-reqeustfail-url-not-in-domain-list) - [1.3.2. 云开发: 初始化错误 cloud init error](#132-云开发-初始化错误-cloud-init-error) - [1.3.3. 云开发:云环境不存在 env not exists](#133-云开发云环境不存在-env-not-exists) - [1.3.4. 云开发:云函数不存在 Function not found](#134-云开发云函数不存在-function-not-found) - [1.3.5. 可以接入第三方服务吗?](#135-可以接入第三方服务吗) ## 1.1. 开发环境准备 > 更详细小程序开发指南,请参见:[官方小程序开发指南](https://developers.weixin.qq.com/miniprogram/dev/framework/quickstart/getstart.html) ### 1.1.1. 申请小程序账号 进入 [小程序注册页](https://mp.weixin.qq.com/wxopen/waregister?action=step1&token=&lang=zh_CN) `https://mp.weixin.qq.com/` 根据指引填写信息和提交相应的资料,就可以拥有自己的小程序帐号 ### 1.1.2. 小程序管理后台 申请小程序成功后,登录[小程序管理后台](https://mp.weixin.qq.com/) 。在小程序管理平台,你可以管理你的小程序的权限,查看数据报表,发布小程序等操作。 AppID:在菜单 “设置”-“开发设置” 可以看到小程序的 AppID,小程序的 AppID 相当于小程序平台的一个身份证,在小程序项目的基本信息中需要配置AppID。 ![小程序后台](image/mini_program/mp_appid.png) ### 1.1.3. 安装开发工具 前往 [开发者工具下载页面](https://developers.weixin.qq.com/miniprogram/dev/devtools/download.html) ,根据自己的操作系统下载对应的安装包进行安装。安装成功后,打开小程序开发者工具,用微信扫码登录开发者工具 ## 1.2. 智能灯小程序Demo ### 1.2.1. 概述 ![小程序开发方式](image/mini_program/mp_diagram.png) 基于腾讯云开发物联网小程序应用,关键是如何在小程序上方便的调用腾讯云物联网平台的API(如图所示的红框部分)。 TencentOS tiny 提供了两种开发方式的小程序Demo案例,帮助开发者的小程序更快接入腾讯云: 1. 普通开发方式,使用SDK调用腾讯云API 2. 云开发方式,在云函数中调用腾讯云API ### 1.2.2. 前置工作 Demo案例以开发智能灯应用为例子,在小程序开发之前,应该先完成以下工作: + 在腾讯云物联网开发平台IotExplorer创建智能灯产品和设备 参考[腾讯云智能灯接入指引](https://cloud.tencent.com/document/product/1081/41155)。只需要关注控制台操作部分:创建项目和产品, 新建产品, 创建数据模板, 创建测试设备 + 基于TencentOS tiny完成设备和IotExplorer对接 参考智能灯数据模案例:TencentOS_tiny/examples/qcloud_iot_explorer_sdk_data_template ### 1.2.3. 普通开发方式(SDK) #### 1.2.3.1. 导入工程 在小程序开发工具中,导入项目: TencentOS_tiny\tools\Mini_Program\iotexplorer_mp_demo ![导入普通开发Demo项目](image/mini_program/mp_normaldev_import_project.png) > 注:AppID可在小程序管理后台获取,本地调试可以先使用测试号 #### 1.2.3.2. 修改配置 在miniprogram/app.js里更新配置信息,参考[配置信息说明](#配置信息说明) ![更新配置](image/mini_program/mp_normaldev_update_config.png) #### 1.2.3.3. 功能扩展 SDK支持的api参见iotclient.js,开发者可以基于案例进行功能扩展:TencentOS_tiny\tools\Mini_Program\iotexplorer_mp_demo\iotclient_for_miniprogram\iotclient.js > 注:腾讯云暂时没有提供小程序端的API SDK,本案例的小程序SDK(iotclient_for_miniprogram)是基于[腾讯云的NodeJS SDK](https://github.com/TencentCloud/tencentcloud-sdk-nodejs/tree/master/tencentcloud/services/iotexplorer)移植过来的 ### 1.2.4. 云开发方式(云函数) > 更详细的云开发指南,请参见[官方的云开发快速指引](https://developers.weixin.qq.com/miniprogram/dev/wxcloud/basis/quickstart.html) #### 1.2.4.1. 导入工程 在小程序开发工具中,导入云开发Demo项目: TencentOS_tiny\tools\Mini_Program\iotexplorer_mp_cloudfunctions_demo ![导入云开发Demo项目](image/mini_program/mp_clouddev_demo_import_project.png) > 注:AppID可在小程序管理后台获取;测试号不支持云开发,必须申请小程序账号 #### 1.2.4.2. 开通云开发,创建环境 在使用云开发能力之前需要先开通云开发。在开发者工具工具栏左侧,点击 “云开发” 按钮即可打开云控制台、根据提示开通云开发、创建云环境。 ![开通云开发](image/mini_program/mp_clouddev_demo_enable.png) ![创建云环境](image/mini_program/mp_clouddev_demo_create_env.png) > 例如:填入环境名称为tos-demo, 环境ID为tos-demo。 #### 1.2.4.3. 部署云函数 云函数需要部署到云环境中才能生效。在云函数目录上,点击右键,选择"创建并部署:云端安装依赖(不上传node_modules)" ![部署云函数](image/mini_program/mp_clouddev_demo_upload_function.png) 案例的cloudfunctions目录提供了两个云函数query和control,通过调用Iotexplorer的查询和控制接口,实现了对设备的查询和控制。 分别将control和query云函数部署到云环境中。部署成功后,可以在云开发控制台里看到对应的云函数。 ![云开发控制台的云函数](images/../image/mini_program/mp_clouddev_demo_cloudfunctions.png) #### 1.2.4.4. 修改配置 在miniprogram/app.js里更新配置信息,参考[配置信息说明](#配置信息说明) ![更新项目配置](image/mini_program/mp_clouddev_demo_update_config.png) #### 1.2.4.5. 功能扩展:结合API 3.0 Explorer工具快速实现云函数 腾讯云提供的[API 3.0 Explorer](https://cloud.tencent.com/document/api),可以非常方便的生成 API SDK代码。只需要稍微修改,就可以直接在云函数中使用。 + 自动生成API SDK代码 + 进入[API 3.0 Explorer工具](https://console.cloud.tencent.com/api/explorer) + 左侧选择对应服务,如:“物联网开发平台” + 继续选择对应接口,如:“数据查询相关接口”-“获取设备属性数据” + 填写个人密钥和输入参数。参见[配置信息说明](#配置信息说明) + 使用在线调用,测试接口是否调用成功 + 测试完成后,选择生成NodeJS代码。将代码拷贝,后续用于云函数中 ![api 3.0 explorer](image/mini_program/mp_api_explorer.png) + 创建并实现云函数 + 创建云函数query,将自动生成的NodeJS代码拷贝到云函数,并稍作修改即可使用。参考:[TencentOS-tiny/tree/develop/tools/Mini_Program/iotexplorer_mp_cloudfunctions_demo/cloudfunctions/query/index.js](https://github.com/OpenAtomFoundation/TencentOS-tiny/tree/develop/tools/Mini_Program/iotexplorer_mp_cloudfunctions_demo/cloudfunctions/query/index.js) + 记得上传部署修改后的云函数 + 调用云函数 + 调用云函数的代码也很简单。参考:[TencentOS-tiny/tree/develop/tools/Mini_Program/iotexplorer_mp_cloudfunctions_demo/miniprogram/pages/index/index.js#queryDeviceData()](https://github.com/OpenAtomFoundation/TencentOS-tiny/tree/develop/tools/Mini_Program/iotexplorer_mp_cloudfunctions_demo/miniprogram/pages/index/index.js) ```javascript // 调用云函数query wx.cloud.callFunction({ name: 'query', data: queryData, success: res => { try { let deviceData = JSON.parse(res.result.Data) this.setData({ deviceData: deviceData }) console.log("result:", deviceData) wx.showToast({ title: '调用成功', }) } catch (e) { wx.showToast({ icon: 'none', title: '调用失败', }) console.log(res.result.Data, e) } }, fail: err => { wx.showToast({ icon: 'none', title: '调用失败', }) console.error('[云函数] [iotexplorer] 调用失败:', err) } }) ``` ### 1.2.5. 调试和发布 上文的步骤完成后,就可以对基本功能进行调试,如:查询和控制设备。 + 本地调试。点击菜单栏的"编译"按钮进行编译,左侧模拟器中点击查询和发送按钮,下侧调试器中查看调试信息 ![本地调试](image/mini_program/mp_local_debug.png) + 真机调试。点击菜单栏"真机调试",手机微信扫描弹出的二维码,进入真机调试。可在手机小程序页面点击按钮进行调试。 ![真机调试](image/mini_program/mp_remote_debug.png) ![真机调试](image/mini_program/mp_remote_debug_mobile.jpg) 调试OK后,就可以发布小程序了 + 上传代码。点击菜单栏“上传”,填写版本信息,上传开发版本到小程序管理后台 ![上传开发版本](image/mini_program/mp_publish_upload.png) + 发布版本。登录小程序管理后台,进入“管理”-“版本管理”。将开发版本提交审核,等待审核通过后,点击发布版本。 ### 1.2.6. 配置信息说明 + productId, deviceName 产品ID和设备名称。用于IotExplorer API接口调用的参数。在腾讯云控制台-物联网开发平台-产品开发-设备调试中,获取产品ID和设备名称 ![获取产品和设备信息](image/mini_program/mp_get_device_info.png) + secretId, secretKey 腾讯云API密钥信息,用于IotExplorer API 接口调用的鉴权。在腾讯云控制台-访问管理-访问密钥-API密钥管理中,获取 secretId, secretKey ![获取API密钥](image/mini_program/mp_get_secret_key.png) + region Region字段,接口服务的地域,填写"ap-guangzhou"即可 + env 云开发的环境ID。填入云开发创建的环境ID ## 1.3. FAQ ### 1.3.1. 网络请求报错: reqeust:fail url not in domain list 报错信息: ```` https://iotexplorer.tencentcloudapi.com 不在以下 request 合法域名列表中,请参考文档:https://developers.weixin.qq.com/miniprogram/dev/framework/ability/network.html {errMsg: "request:fail url not in domain list"} ```` 解决方式: + 如果是本地调试,可以在本地设置中勾选`不校验合法域名` ![不校验合法域名](image/mini_program/mp_local_domain_noncheck.png) + 如果是真机调试或发布小程序,则需要在小程序管理后台进行服务器域名配置:进入微信公众平台小程序后台 - 开发 - 开发设置 - 服务器域名 - 输入域名。参见[微信小程序添加服务器端接口域名](https://jingyan.baidu.com/article/ce09321bb6e9c12bff858f92.html) + 如果使用物联网开发平台 IoT Explorer,输入域名: `iotexplorer.tencentcloudapi.com` + 如果使用物联网通信平台 IoT Hub,输入域名:`iotcloud.tencentcloudapi.com` ![服务器端域名配置](image/mini_program/mp_setting_domain.png) ### 1.3.2. 云开发: 初始化错误 cloud init error 报错信息 ```` cloud init error:{ errMsg: "invalid scope" } ```` 首次开通云环境后,需等待大约 10 分钟方可正常使用云 API,在此期间官方后台服务正在做准备服务,如尝试在小程序中调用云 API 则会报 cloud init error:{ errMsg: "invalid scope" } 的错误 ### 1.3.3. 云开发:云环境不存在 env not exists 报错信息: ```` Error: errCode: -404011 cloud function execution error | errMsg: cloud.callFunction:fail requestID , cloud function service error code -501000, error message [100004] env not exists; ```` + 确定是否开通云开发并创建环境 + 确定配置文件app.js中env字段是否和云开发中创建的云环境ID一致 ### 1.3.4. 云开发:云函数不存在 Function not found ```` Error: errCode: -404011 cloud function execution error | errMsg: cloud.callFunction:fail requestID , cloud function service error code -504002, error message Function not found [query]; at cloud.callFunction api ```` + 确认云函数是否部署到对应云环境 ### 1.3.5. 可以接入第三方服务吗? 可以。只要是符合要求的服务,小程序都能访问。简单来说,有以下几个要求:必须使用https/wss请求,请求域名需要做备案,并带有可信任的SSL证书。详细参见[小程序网络能力使用说明](https://developers.weixin.qq.com/miniprogram/dev/framework/ability/network.html)