zoukankan      html  css  js  c++  java
  • 首次搭建微信小程序记录各种细节

    获取微信手机号

    查看链接:https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/getPhoneNumber.html

    解密算法:https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/signature.html#%E5%8A%A0%E5%AF%86%E6%95%B0%E6%8D%AE%E8%A7%A3%E5%AF%86%E7%AE%97%E6%B3%95

    获取用户信息、openId

    https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/login.html

    获取openid的具体流程是

    1. 调用 wx.login() 获取 临时登录凭证code 。

    2. 根据code, 调用 auth.code2Session 接口,换取 用户唯一标识 OpenID 、微信开放平台帐号下的UnionID 、会话密钥 session_key

    参考:https://developers.weixin.qq.com/miniprogram/dev/api-backend/open-api/login/auth.code2Session.html

    例子:https://api.weixin.qq.com/sns/jscode2session?appid=小程序appId&secret=小程序appSecret(小程序管理后台,管理员才有权限看到)&js_code=JSCODE&grant_type=authorization_code(授权类型,此处写死authorization_code即可)

    备注:前端也能直接调用https://api.weixin.qq.com/sns/jscode2session获取openId,不过一般都是通过请求后端服务获取,原因appSecret暴露给前端不安全

    相关代码

    import { jsCode2Session } from './services/index'
    
    App({
      onLaunch() {
        // 异步请求获取数据,添加全局Promise,其他页面方便获取用户信息和opneId
        this.userInfoReadyCallback = new Promise(resovle => {
          let openid; 
          let userInfo; 
    
          // 获取用户信息
          wx.getSetting().then(res => {
            if (!res.authSetting['scope.userInfo']) return (userInfo = {})
            // 已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框
            wx.getUserInfo().then(res => {
              userInfo = res.userInfo
              this.globalData.userInfo = userInfo
              if (!openid || openid === undefined) return
              resovle({ openid, userInfo })
            })
          })
    
          // 获取用户的openid
          wx.login().then(res => {
            // 调用后端接口获取openId、unionid(如果有)
            jsCode2Session({ jsCode: res.code }).then(rs => {
              openid = rs.data.openid
              this.globalData.openId = openid
              if (!userInfo) return
              resovle({ openid, userInfo })
            }).catch(e => {
              console.log('获取openid失败!')
              openid = ''
              if (!userInfo) return
              resovle({ openid, userInfo })
            })
          })
        })
      }
    })
    // 未授权,弹窗授权按钮,引导用户授权
    <view wx:if="{{!userInfo.nickName}}">
      <view class="mask-dialog">
        <text>获取头像昵称</text>
        <button open-type="getUserInfo" bindgetuserinfo="getUserInfo">确定</button>
      </view>
    </view>
    
    // 授权后的回调
    getUserInfo(e) {
      const userInfo = e.detail.userInfo
      app.globalData.userInfo = userInfo
      this.setData({ userInfo })
    }

     

    微信接收服务消息

    指南: https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/subscribe-message.html

    在微信上,如果需要接收小程序推送的服务消息,具体流程如下:

    1. 首先在小程序管理平台上创建模板(创建过程就不细说了,基本)

        

     一些细节需要注意:

    2. 代码层面 

       // 这个接口,只在点击事件或是支付完成后调用才有效。其它事件使用无效
      wx.requestSubscribeMessage({
          tmplIds: ['BHX-xcOHtwViZfaL9v2Tkmf6Xlv94tPCtL8qVpfcaLA'],
          success(msg) {
            console.log(msg)
          },
          fail(msg, errCode) {
            console.log('msg', msg, msg.errCode)
          }
        })

    3. 点击按钮,会弹窗授权(后端就可以写代码根据业务逻辑推送,微信就可以接收服务消息)

     

    使用npm

    https://developers.weixin.qq.com/miniprogram/dev/devtools/npm.html

    例子:使用 tabs

    1. 安装:cnpm install @miniprogram-component-plus/tabs -S

    2. page.json: 

    {
      "usingComponents": { "mp-tabs": "@miniprogram-component-plus/tabs" }
    }

    3. 构件npm:

     

    请求接口的url配置

    Object wx.getAccountInfoSync()可以获取当前账号的信息,里面有字段区分当前环境

    https://developers.weixin.qq.com/miniprogram/dev/api/open-api/account-info/wx.getAccountInfoSync.html

    代码可以这样写:

    const urlConfig = {
      // 开发版地址配置
      develop: {
        apiBaseUrl: 'https://ybstest.qxfoodom.com/',
        connectUrl: 'wxs://ybstest.qxfoodom.com:443/ws/mqtt'
      },
      // 体验版地址配置
      trial: {
        apiBaseUrl: 'https://ybstest.qxfoodom.com/',
        connectUrl: 'wxs://ybstest.qxfoodom.com:443/ws/mqtt'
      },
      // 正式版地址配置
      release: {
        apiBaseUrl: 'https://ybs.qxfoodom.com/',
        connectUrl: 'wxs://ybstest.qxfoodom.com:443/ws/mqtt'
      },
      // 兜底处理
      other: {
        apiBaseUrl: 'https://ybs.qxfoodom.com/',
        connectUrl: 'wxs://ybstest.qxfoodom.com:443/ws/mqtt'
      }
    }
    
    const getUrlConfig = () => {
      const accountInfo = wx.getAccountInfoSync()
      console.log(accountInfo)
      const envVersion = accountInfo.miniProgram.envVersion
      return urlConfig[envVersion] || urlConfig.other
    }
    
    const config = getUrlConfig()
    
    export {
      config
    }

     备注:据说审核版本的值不确定,很可能导致审核不通过

     

    使用mqtt

    https://github.com/mqttjs/MQTT.js

    地址必须是 wxs(对应https) 或 wx(http) 开头,否侧报错:

    import mqtt from './my_mqtt.js';
    
    // 连接选项
    const options = {
      clean: true, // 保留回话
      connectTimeout: 15000, // 超时时间
      keepalive: 20,
      username: 'admin',
      password: 'public',
    }
    
    let mqttClient
    const getMqttClient = () => {
      if (mqttClient) return mqttClient
      mqttClient = mqtt.connect('wxs://ybstest.com:443/ws/mqtt', options);
    
      mqttClient.on('connect', () => {
        console.log('connect:', mqttClient.options.href);
      });
      
      mqttClient.on('close', () => {
        console.log('close..........')
      });
      
      mqttClient.on('reconnect', () => { 
        console.log('reconnect..........')
      });
      
      mqttClient.on('disconnect', () => {
        console.log('disconnect..........')
      });
      
      mqttClient.on('error', () => {
        console.log('error..........')
      });
    
      return mqttClient
    };
    
    export default getMqttClient;
    
    // // 订阅消息
    // mqttClient.subscribe(`/device/upload/${deviceSn}`, { qos: 0 }, err => {
    //   if (err) console.log(err);
    // });
    
    // 订阅消息后,才能接收消息
    // mqttClient.on('message', (topic, message) => {
    //   try {
    //     const obj = JSON.parse(message.toString());
    //     console.log('收到信息:', obj);
    //   } catch (error) {
    //     console.error(error);
    //   }
    // });
    
    // 无需订阅消息,链接成功即可发送消息
    // mqttClient.publish('/device/push/${deviceSn}', JSON.stringify({
    //   deviceSn: '设备SN',
    //   mqttActionEnum: 'BASE_DIRECTION_CONTROL',
    //   DIRECTION: 'LEFT', // RIGHT UP DOWN
    //   timestamp: +new Date()
    // }));

     

    其他使用技巧

    • 页面的Page构造,改为 Component构造器;可以使用behaviors等高级属性,可以使用Component构造器, 如果这样做,生命周期方法需要写在methods中

    • 使用svg图片:<image mode="widthFix" class="svg-gongdan" src="../../icon/icon_gongdan.svg" />

    • 使用 iconfont 字体图标:/**app.wxss**/  @import './iconfont.wxss'; (iconfont.wxss就是下载下来的字体图标样式)

     

    微信小程序下载视频保存到本地

    文件下载接口: https://developers.weixin.qq.com/miniprogram/dev/api/network/download/wx.downloadFile.html

    保存视频到系统相册:https://developers.weixin.qq.com/miniprogram/dev/api/media/video/wx.saveVideoToPhotosAlbum.html

    用户授权:https://developers.weixin.qq.com/miniprogram/dev/api/open-api/authorize/wx.authorize.html

    获取用户已经授权的接口: https://developers.weixin.qq.com/miniprogram/dev/api/open-api/setting/wx.openSetting.html

    handleDownload(e) {
      let fileName = new Date().valueOf();
       // 单次下载允许的最大文件为 200MB
      wx.downloadFile({
        url: '下载地址:xxxx',
        filePath: wx.env.USER_DATA_PATH + '/' + fileName + '.mp4', // 指定文件下载后存储的路径 (本地路径)
        success: res => {
          let filePath = res.filePath; // 传入 filePath 时会返回,跟传入的 filePath 一致
          
          // 保存视频到系统相册
          wx.saveVideoToPhotosAlbum({ 
            filePath,
            success: file => {
              wx.showToast({
                title: '下载成功',
                icon: 'success',
                duration: 2000
              })
            },
            fail: err => {
              if (err.errMsg === 'saveVideoToPhotosAlbum:fail auth deny') {
              wx.authorize({
                  scope: 'scope.writePhotosAlbum', // 保存到相册 授权
                  success () {
                    // 再次保存
                  }
                })
              }
            }
          })
        }
      })
    }

    遇到问题

    1. 小程序iOS Promise不支持finally语法 TypeError: undefined is not a function .finally is not a function;Promise.finally()在实际使用中ios真机上不生效,安卓及模拟器正常
    2. 小程序的textarea组件,不能再scroll-view组件上使用,会出textarea输入的字体悬浮在页面上的问题

    开发工具使用

    下载地址: https://developers.weixin.qq.com/miniprogram/dev/devtools/download.html

    代码提交

    提交之前,先配置好“网络和认证”

     

    开发避开域名校验

    请求接口,需要在小程序管理后台配置服务器域名,否侧会报错,如果需要开发时避开这个限制,可以如下设置:

    编译某一个页面配置

    点击保存文件后,开发者工具会自动编译,会默认跳转到首页,如果想跳转到某一个页面可以如下配置:

              

    备注: 可以设置进入的场景值,具体的场景值说明地址: https://developers.weixin.qq.com/miniprogram/dev/framework/app-service/scene.html

    清除缓存

    有些时候,需要测试微信授权,可以清除缓存,,具体如下

    其他

    真机调试: 点击后,可以在手机上真机调试,开发工具会弹出调试面板

     预览: 点击后会生成二维码,扫码后自动显示当前页面

  • 相关阅读:
    如何透过上层div点击下层的元素解决方法
    学习javscript函数笔记(二)
    js栈内存和堆内存的区别
    学习javscript对象笔记(一)
    小程序 给最外层view设置百分之百高度不起作用
    小程序 开发阶段请求网络报 不在以下 request 合法域名列表中
    git安装以及webstorm配置git
    failed to push some refs to 'git@github.com:xxx/xxx.git' 解决方法
    Jquery EasyUI Treegrid按需加载子集
    js时间戳与日期格式的相互转换
  • 原文地址:https://www.cnblogs.com/vs1435/p/14524896.html
Copyright © 2011-2022 走看看