微信小程序访问云数据库

简介: 微信小程序访问云数据库

1.Copy官网测试代码另保存Test.html ,修改APPID和ENVID

    公众号使用云开发 / 极简示例 / HTML | 微信开放文档 (qq.com)

<html>
  <head>
    <title>云开发 Web 能力极简示例</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1, maximum-scale=1">
    <script>
      window.onerror = e => {
        alert('window error ' + e)
      }
    </script>
    <!-- 调试用的移动端 console -->
    <script src="https://cdn.jsdelivr.net/npm/eruda"></script>
    <script>eruda.init();</script>
    <!-- 公众号 JSSDK -->
    <script src="https://res.wx.qq.com/open/js/jweixin-1.6.0.js"></script>
    <!-- 云开发 Web SDK -->
    <script src="https://res.wx.qq.com/open/js/cloudbase/1.1.0/cloud.js"></script>
    <script>
      // 公众号基本信息:请修改下列字段使用本示例
      const WX_RESOURCE_APPID = 'wx****86c6e5aa1573' /*         资源方 AppID */
      const WX_RESOURCE_ENVID = 'test-****4qd6b2c3182' /*                     资源方云开发环境 ID */
      const WX_OFFICIAL_ACCOUNT_APPID = 'wxaaaaaaaaaaaaaaaa'/*  公众号 AppID */
      const WX_AUTH_TYPE = 'snsapi_base' /*                     选择需要的授权方式,snsapi_base 或 snsapi_userinfo */
      const WX_REDIRECT_URI = 'https://example.com/' /*         回调 URL */
 
      // 示例配置
      const isPersistLoginInfo = false // 是否需要保留登录态信息到 window 中,只有 snsapi_userinfo 方式需要
      
      if (window.wx) {
        window.cloud = wx.cloud
      }
 
      var urlSearch = new URLSearchParams(location.search)
      var accessToken = urlSearch.get('access_token')
      var refreshToken = urlSearch.get('refresh_token')
 
      /**
       * 检查/发起登录
       * 1. 函数会检查当前是否已登录(checkLogin)
       * 2. 如果未登录,会 10s 后自动发起登录(startLogin)
       * 3. 如果已登录,会初始化实例,使用指定的小程序云开发资源
       */
      window.doLogin = async () => {
        try {
          const checkLoginOptions = {
            provider: 'OfficialAccount',
            appid: WX_OFFICIAL_ACCOUNT_APPID,
          }
 
          if (urlSearch.get('oauthredirect') === '1') {
            checkLoginOptions.accessToken = accessToken
            checkLoginOptions.refreshToken = refreshToken
          }
 
          console.log(`checkLogin options: `, checkLoginOptions)
          const result = await cloud.checkLogin(checkLoginOptions)
          console.log(`checkLogin result: `, result)
          if (isPersistLoginInfo) {
            window.checkLoginRes = result
          }
          if (result.errCode === 0 && result.loggedIn) {
            console.log(`checkLogin success`)
 
            const instance = window.instance = new cloud.Cloud({
              appid: WX_OFFICIAL_ACCOUNT_APPID,
              resourceAppid: WX_RESOURCE_APPID,
              resourceEnv: WX_RESOURCE_ENVID,
            })
            const initResult = await instance.init()
            
            console.log(`instance inited`, initResult)
            console.log(`can use cloud instance to access resource now !`)
 
            const els = [...document.getElementsByClassName('display-none')]
            els.forEach(el => el.classList.remove('display-none'))
          } else {
            console.log(`checkLogin with sdk errCode ${result.errCode} errMsg ${result.errMsg}, will start oauth in 10s`)
 
            setTimeout(() => {
              try {
                cloud.startLogin({
                  provider: 'OfficialAccount',
                  appid: WX_OFFICIAL_ACCOUNT_APPID,
                  scope: WX_AUTH_TYPE,
                  redirectUri: WX_REDIRECT_URI,
                })
              } catch (e) {
                console.error(`startLogin fail: ${e}`)
                console.warn(`will start OfficialAccount OAuth login in 10s.`)
              }
            }, 10000)
          }
        } catch (e) {
          console.error(e)
        }
      }
 
      /**
       * 获取用户信息的示例
       * 1. 需在登录后调用
       * 2. 网页授权的方式需为 snsapi_userinfo
       * 3. 从 checkLogin 结果中获取用户信息 cloudID(已在 doLogin 函数中先暂存到全局变量 checkLoginRes)
       * 4. 调用云函数换取 cloudID 信息
       */
      window.getUserInfo = async () => {
        if (!checkLoginRes) throw new Error('获取登录信息失败,请确认授权方式以及是否保存了登录信息')
        try {
          if (checkLoginRes.cloudID) {
            const res = await instance.callFunction({
              name: 'echo',
              data: {
                userInfoData: new instance.CloudID(checkLoginRes.cloudID),
              },
            })
 
            const cloudData = res.result.userInfoData
            if (cloudData.data) {
              const userInfoImg = document.querySelector('#userinfo .avatar')
              userInfoImg.src = cloudData.data.avatarUrl
 
              const userInfoName = document.querySelector('#userinfo .name')
              userInfoName.innerText = cloudData.data.nickName
 
              const userInfoOpenID = document.querySelector('#userinfo .openid')
              userInfoOpenID.innerText = cloudData.data.openId
 
              const userInfoDiv = document.getElementById('userinfo')
              userInfoDiv.style.cssText = ''
            } else {
              console.warn(`cloudID data error: `, cloudData)
              alert(`cloudID 信息获取错误,请查看调试器报错信息`)
            }
          } else {
            alert(`找不到 cloudID,请确认网页授权方式为 snsnapi_userinfo`)
          }
        } catch (e) {
          console.error(`error: ${e} ${e.stack}`)
        }
      }
 
      /**
       * 使用 JSSDK 的示例
       * 1. 需在登录后调用
       * 2. 首先会使用云开发 web sdk 提供的 getJSSDKSignature 方法获取网页所需的 wx.config 的签名
       * 3. 调用 wx.config
       * 4. wx.config 成功之后尝试调用选择图片和获取地理位置作为示例
       */
      window.useJSSDK = async () => {
        try {
          const instance = window.instance
 
          console.log(`url: ${location.href}`)
          const res = await instance.getJSSDKSignature({
            url: location.href,
          })
          console.log(`jssdk sign res: ${JSON.stringify(res)}`)
 
          const configOpt = {
            debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
            appId: WX_OFFICIAL_ACCOUNT_APPID, // 必填,公众号的唯一标识
            timestamp: res.timestamp + '', // 必填,生成签名的时间戳
            nonceStr: res.nonceStr, // 必填,生成签名的随机串
            signature: res.signature,// 必填,签名
            jsApiList: ['chooseImage', 'getLocation'] // 必填,需要使用的JS接口列表
          }
 
          console.log(`wx.config opt ${JSON.stringify(configOpt)}`)
          wx.config(configOpt)
          console.log(`wx.config executed`)
 
          wx.ready(() => {
            console.log(`wx.ready triggered`)
 
            setTimeout(() => {
              wx.chooseImage({
                count: 5, 
                sizeType: ['original', 'compressed'], 
                sourceType: ['album', 'camera'],
                success : function(res) {
                  alert('已选择 ' + res.localIds.length + ' 张图片');
                },
                fail: function(err) {
                  console.error(`chooseImage fail ${JSON.stringify(err)}`)
                },
              })
 
              wx.getLocation({
                type: 'wgs84', // 默认为wgs84的gps坐标,如果要返回直接给openLocation用的火星坐标,可传入'gcj02'
                success: function (res) {
                  var latitude = res.latitude; // 纬度,浮点数,范围为90 ~ -90
                  var longitude = res.longitude; // 经度,浮点数,范围为180 ~ -180。
                  var speed = res.speed; // 速度,以米/每秒计
                  var accuracy = res.accuracy; // 位置精度
                  console.log(`getLocation ${JSON.stringify(res)}`)
                },
                fail: err => {
                  console.log(`getLocation fail ${JSON.stringify(err)}`)
                }
              });
            }, 2000)
          })
 
          wx.error(err => {
            console.error(`wx.error ${JSON.stringify(err)}`)
          })
 
        } catch (e) {
          console.error(`error: ${e} ${e.stack}`)
        } 
      }
 
      /**
       * 带登录态访问资源方的云开发资源,调用方式见文档,与小程序一致
       */
      window.accessResource = async () => {
        try {
          const c = window.instance
          await runWithLogs(() => c.database().collection('reposkipuser').where({done:true}).limit(10).skip(1).get())
        } catch (e) {
          console.error('logs', `error: ${e}`)
        }
      }
 
      /**
       * 未登录模式下访问小程序云开发的资源示例
       */
      window.accessResourceWithoutAuth = async () => {
            var c = new cloud.Cloud({
                identityless: true, // 表示是未登录模式
                resourceAppid: 'wx5f****6e5aa1573',
                resourceEnv: 'test-0g****qd6b2c3182',
            })
 
            await c.init()
 
            await runWithLogs(() => c.database().collection('reposkipuser').where({}).get(), `start db`, `db res`)
        }
 
 
      window.runWithLogs = async (fn, before, after) => {
        try {
          console.log(before)
          const res = await fn()
          console.log(`${after}: ${JSON.stringify(res)}`)
        } catch (e) {
          console.error(`error: ${e}`)
        }
      }
    </script>
    <style>
      .display-none {
        display: none;
      }
 
      .userinfo {
        display: flex;
        flex-direction: column;
        align-items: center;
      }
 
      .userinfo .avatar {
        width: max-content;
        box-shadow: inset 0 -3em 3em rgba(0,0,0,0.1), 0 0 0 2px rgb(255,255,255), 0.3em 0.3em 1em rgba(0,0,0,0.3);
      }
 
      .userinfo .name {
        border-bottom: 2px solid gray;
        padding: 0 5px 5px 5px;
      }
    </style>
  </head>
  <body>
    <h2>云开发 Web 能力极简示例</h2>
    <p>请注意按照文档说明配置好,主要包括:</p>
    <p>1. 配置好公众号的授权回调域名及 JS 安全域名</p>
    <p>2. 配置好云开发授权关系(小程序授权云开发资源给公众号)</p>
    <p>3. 将代码中相应需要填入小程序/公众号 AppID 的地方进行相应改动</p>
    <p>4. 编写部署好小程序云开发对应云环境的 cloudbase_auth 云函数和 echo 云函数</p>
    <p>5. 准备好后,页面加载后先点击登录,登录后再执行访问资源等其他操作,日志可在调试器查看</p>
    <div id="userinfo" class="userinfo" style="display: none">
      <img class="avatar" />
      <p class="name"></p>
      <p class="openid"></p>
    </div>
   <!--  <p><a href="javascript:;" onclick="doLogin()">登录(云开发公众号网页授权)</a></p>
    <p><a href="javascript:;" class="display-none" onclick="getUserInfo()">获取用户信息</a></p>
    <p><a href="javascript:;" class="display-none" onclick="useJSSDK()">使用 JSSDK</a></p> -->
    <p><a href="javascript:;"  onclick="accessResource()">访问云资源</a></p>
    <p><a href="javascript:;"  onclick="accessResourceWithoutAuth()">未登录模式下访问云资源</a></p>
  </body>
</html>

2.F12调试 控制台调试

使用未登录模式下访问云资源会报错,

解决:需要在浏览器属性新增--test-type --disable-web-security

未登录情况下回遇到两个问题 ,点击查询 错误码 | 微信开放文档 (qq.com)

 

3.最终访问效果

相关文章
|
4月前
|
消息中间件 缓存 监控
优化微服务架构中的数据库访问:策略与最佳实践
在微服务架构中,数据库访问的效率直接影响到系统的性能和可扩展性。本文探讨了优化微服务架构中数据库访问的策略与最佳实践,包括数据分片、缓存策略、异步处理和服务间通信优化。通过具体的技术方案和实例分析,提供了一系列实用的建议,以帮助开发团队提升微服务系统的响应速度和稳定性。
|
1月前
|
SQL Oracle 数据库
使用访问指导(SQL Access Advisor)优化数据库业务负载
本文介绍了Oracle的SQL访问指导(SQL Access Advisor)的应用场景及其使用方法。访问指导通过分析给定的工作负载,提供索引、物化视图和分区等方面的优化建议,帮助DBA提升数据库性能。具体步骤包括创建访问指导任务、创建工作负载、连接工作负载至访问指导、设置任务参数、运行访问指导、查看和应用优化建议。访问指导不仅针对单条SQL语句,还能综合考虑多条SQL语句的优化效果,为DBA提供全面的决策支持。
68 11
|
2月前
|
SQL Java 数据库连接
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率。本文介绍了连接池的工作原理、优势及实现方法,并提供了HikariCP的示例代码。
69 3
|
2月前
|
SQL Java 数据库连接
打破瓶颈:利用Java连接池技术提升数据库访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,避免了频繁的连接建立和断开,显著提升了数据库访问效率。常见的连接池库包括HikariCP、C3P0和DBCP,它们提供了丰富的配置选项和强大的功能,帮助优化应用性能。
103 2
|
4月前
|
消息中间件 缓存 监控
优化微服务架构中的数据库访问:策略与实践
随着微服务架构的普及,如何高效管理和优化数据库访问成为了关键挑战。本文探讨了在微服务环境中优化数据库访问的策略,包括数据库分片、缓存机制、异步处理等技术手段。通过深入分析实际案例和最佳实践,本文旨在为开发者提供实际可行的解决方案,以提升系统性能和可扩展性。
|
4月前
|
SQL NoSQL Java
彻底革新你的数据库操作体验!Micronaut数据访问技巧让你瞬间爱上代码编写!
【9月更文挑战第10天】Java开发者们一直在寻找简化应用程序与数据库交互的方法。Micronaut作为一个现代框架,提供了多种工具和特性来提升数据访问效率。本文介绍如何使用Micronaut简化数据库操作,并提供具体示例代码。Micronaut支持JPA/Hibernate、SQL及NoSQL(如MongoDB),简化配置并无缝集成。通过定义带有`@Repository`注解的接口,可以实现Spring Data风格的命名查询。
92 6
|
4月前
|
SQL 存储 关系型数据库
C#一分钟浅谈:使用 ADO.NET 进行数据库访问
【9月更文挑战第3天】在.NET开发中,与数据库交互至关重要。ADO.NET是Microsoft提供的用于访问关系型数据库的类库,包含连接数据库、执行SQL命令等功能。本文从基础入手,介绍如何使用ADO.NET进行数据库访问,并提供示例代码,同时讨论常见问题及其解决方案,如连接字符串错误、SQL注入风险和资源泄露等,帮助开发者更好地利用ADO.NET提升应用的安全性和稳定性。
405 6
|
4月前
|
SQL 关系型数据库 分布式数据库
PolarDB Proxy配置与优化:提升数据库访问效率
【9月更文挑战第6天】PolarDB是阿里云推出的高性能分布式关系型数据库,PolarDB Proxy作为其关键组件,位于客户端与PolarDB集群间,负责SQL请求的解析与转发,并支持连接池管理、SQL过滤及路由规则等功能。本文详细介绍了PolarDB Proxy的配置方法,包括连接池、负载均衡和SQL过滤设置,并探讨了监控调优、缓存及网络优化策略,以帮助提升数据库访问效率。
82 1
|
4月前
|
SQL 安全 Java
探索研究Servlet 数据库访问
【9月更文挑战第28天】
43 0
|
5月前
|
开发者 UED Java
Play Framework惊天秘密:如何让异常处理优雅得像芭蕾舞?
【8月更文挑战第31天】在Web应用开发中,异常处理至关重要,直接影响应用稳定性和用户体验。Play Framework作为轻量级Java Web框架,提供了基于Scala偏函数的灵活异常处理机制。通过实现`HttpErrorHandler`接口可定义全局异常逻辑,而在控制器中使用try-catch块则能捕获特定异常。定义自定义异常类也有助于表示特定错误情况。最佳实践包括保持处理一致性、提供有用错误信息、记录日志及分类处理异常。掌握这些技巧,能使Play应用更健壮可靠。
74 1