vue 本地/PC端访问微信云数据库

news/2024/7/4 1:46:11 标签: vue.js, 微信, 数据库

1. 解决跨域访问问题

新建文件 vue.config.js

// 后端服务器地址
let url = "http://localhost:8888";
module.exports = {
  publicPath: "./", // 【必要】静态文件使用相对路径
  outputDir: "./dist", //打包后的文件夹名字及路径
  devServer: {
    // 开发环境跨域情况的代理配置
    proxy: {
      // 【必要】访问自己搭建的后端服务器
      "/api": {
        target: url,
        changOrigin: true,
        ws: true,
        secure: false,
        pathRewrite: {
          "^/api": "/",
        },
      },
      // 【范例】访问百度地图的API
      // vue文件中使用方法  this.$http.get("/baiduMapAPI/place/v2/search"
      // 最终实际访问的接口为  http://api.map.baidu.com/place/v2/search
      // 遇到以/baiduMapAPI开头的接口便使用此代理
      "/wxAPI": {
        // 实际访问的服务器地址
        target: "https://api.weixin.qq.com",
        //开启代理:在本地会创建一个虚拟服务端,然后发送请求的数据,并同时接收请求的数据,这样客户端和服务端进行数据的交互就不会有跨域问题
        changOrigin: true,
        ws: true, // 是否启用websockets
        secure: false, // 使用的是http协议则设置为false,https协议则设置为true
        // 将接口中的/baiduMapAPI去掉(必要)
        pathRewrite: {
          "^/wxAPI": "",
        },
      },
    },
  },
};

若部署上线,需配置nginx反向代理,可参考下方链接
https://blog.csdn.net/weixin_41192489/article/details/118568253

2. 获取 access_token

    // 获取 access_token
    async get_access_token() {
      let res = await this.$http.get(
        "/wxAPI/cgi-bin/token?grant_type=client_credential&appid=你的appid&secret=你的app密钥"
      );
      let access_token = res.data.access_token;
      if (access_token) {
        sessionStorage.setItem("access_token", access_token);
        return access_token;
      } else {
        return false;
      }
    },

此处要将接口中的参数,更换为你的appid和密钥,需登录你的微信小程序后台,参照下图获取:在这里插入图片描述

3. 访问微信数据库

    async login() {
      let access_token = sessionStorage.getItem("access_token");
      if (!access_token) {
        access_token = await this.get_access_token();
      }

      this.$http({
        method: "post",
        url: `/wxAPI/tcb/databasequery?access_token=${access_token}`,
        data: {
          env: "dos-6g02iqcz92dc63ff",
          query: 'db.collection("user").where({No:1}).limit(10).get()',
        },
      }).then((res) => {
        let errcode = res.data.errcode;
        // 7200s后access_token会过期,需重新执行
        if (errcode === 42001) {
          this.login();
        }

        if (errcode === 0) {
          // 获取到微信数据库中的数据
          console.log(res.data.data);
        }
      });
  }
  • 需使用 post 方法
  • headers 中不能有 "Content-Type":"application/x-www-form-urlencoded";
    需注释掉 src\axios.js 中的
// axios.defaults.headers.post["Content-Type"] =
//   "application/x-www-form-urlencoded";
  • 参数为
          env: "你的微信云环境id",
          query: 'db.collection("user").where({No:1}).limit(10).get()',

微信云环境 id 在微信开发者工具中的云开发控制台中参照下图一键复制
在这里插入图片描述
query 的内容为微信数据库的查询语句(语法参考云数据库的开发文档)

  • access_token 默认 7200s 后会过期,过期后需重新获取。

http://www.niftyadmin.cn/n/342164.html

相关文章

实操Linux 部署单机版nacos

目录 Nacos部署环境要求JDK安装下载和构建Nocas控制面板,新建配置Nacos数据库配置 总结 Nacos部署环境要求 64bit OS: Linux/Unix/Mac/Windows 支持, Linux/Unix/Mac 推荐 64bit JDK 1.8 Maven 3.2.x JDK安装 1、准备好jdk1.8 链接:https://pan.baidu.…

New:dbForge Edge 2023 4in1 Enterprise Edition Crack

dbForge Edge 2023 4in1 Enterprise Edition 赋予自己开发和管理 SQL Server、MySQL、Oracle 和 PostgreSQL 数据库的广泛能力 dbForge Edge:您的终极多数据库解决方案 让我们来看看。您需要处理多个数据库管理系统。同时,您希望能够灵活有效地处理范围广…

这是一篇使用ChatGPT生成的关于隐私计算的文章

标题:隐私计算:直白介绍和算法实现 简介: 随着数字化时代的发展,隐私保护成为了一个日益重要的话题。隐私计算作为一种保护个人隐私的方法,具有广泛的应用前景。本篇博客将为您提供一个直白的介绍,解释隐私…

BurpSuite—-Spider模块(蜘蛛爬行)

本文主要介绍BurpSuite—-Spider模块(蜘蛛爬行)的相关内容 关于BurpSuite的安装可以看一下之前这篇文章: http://t.csdn.cn/0Qw2n 一、简介 Burp Spider 是一个映射 web 应用程序的工具。它使用多种智能技术对一个应用程序的内容和功能进行全面的清查。 Burp Spi…

求爷爷告奶奶,阿里大佬才甩出这份Spark+Hadoop+中台实战pdf

Spark大数据分析实战 1、Spark简介 初识Spark Sp ark生态系统BDAS Sp ark架构与运行逻辑 弹性分布式数据集 2、Spark开发与环境配置 Spark应用开发环境2置 使用Intelli i开发Spark 远程调试Spark程序 Spark编译 配置Spark源码阅读环境 3、BDAS简介 SQL on Spark S…

SELECT...FOR UPDATE

SELECT...FOR UPDATE 一、悲观锁、乐观锁1.1 乐观锁1.2 悲观锁 二、SELECT...FOR UPDATE 一、悲观锁、乐观锁 在了解 SELECT...FRO UPDATE 时,先了解其几个概念,悲观锁、乐观锁。 1.1 乐观锁 乐观锁(Optimistic Locking) 假设并发冲突的概率较低&…

【题解】P1971 [NOI2011] 兔兔与蛋蛋游戏

link 第一个黑题,写篇题解纪念一下。 题目大意 两人博弈,有 n m ( 1 ≤ n , m ≤ 40 ) n\times m(1\le n,m\le 40) nm(1≤n,m≤40) 的棋盘,每个格子中可能为空、黑棋或白棋,整个棋盘只有 1 1 1 个空格。对于兔兔&#xff0c…

Vs+Qt+C++电梯调度控制系统

程序示例精选 VsQtC电梯调度控制系统 如需安装运行环境或远程调试&#xff0c;见文章底部个人QQ名片&#xff0c;由专业技术人员远程协助&#xff01; 前言 这篇博客针对<<VsQtC电梯调度控制系统>>编写代码&#xff0c;代码整洁&#xff0c;规则&#xff0c;易读。…