微信小程序:本地开发环境和线上环境配置

简介: 微信小程序:本地开发环境和线上环境配置

在开发微信小程序的时候,需要配置:

本地开发环境
体验预览环境
审核版环境
生产环境

为了简化环境配置,我只区分了两个环境

本地开发环境
生产环境/
  体验预览环境
  审核版环境
  生产环境

参考文档


环境区分原理: 使用wx.getSystemInfoSync() 的 host参数

host  Object  当前小程序运行的宿主环境  2.12.3

将配置文件放入一个目录中, 目录结构如下

config/
  ├── index.js  # 入口文件
  ├── env.js    # 环境获取
  ├── dev.js    # 开发环境配置
  └── pro.js    # 生产环境配置

env.js

/**
 * env
 */
export function getEnv() {
  let res = wx.getSystemInfoSync();
  // 客户端中host有值,本地开发的时候host为null
  if (res.host) {
    return 'pro';
  } else {
    return 'dev';
  }
}

dev.js

/**
 * dev
 */
export default {
  BASE_URL: 'http://127.0.0.1:8000/api',
};

pro.js

/**
 * pro
 */
export default {
  'BASE_URL': 'https://www.demo.com/api'
}

inde.js

/**
 * index
 */
import { getEnv } from './env.js';
import dev from './dev.js';
import pro from './pro.js';
const env = getEnv();
console.log('env', env);
let config = pro;
if (env == 'dev') {
  config = dev;
}
export default config;

其他方案

1、wx.getAccountInfoSync

参考文档:


实现代码

// 自动根据版本切换接口请求地址
  const { miniProgram: { envVersion } } = wx.getAccountInfoSync();
  let url = '';
  switch (envVersion) {
    case 'develop':
      url = `${defaultConfig.devUrl}${params.url}`;
      break;
    case 'trial':
      url = `${defaultConfig.devUrl}${params.url}`;
      break;
    case 'release':
      url = `${defaultConfig.prodUrl}${params.url}`;
      break;
    default:
      url = `${defaultConfig.baseUrl}${params.url}`;
      break;
  }

使用 wx.getAccountInfoSync 获取的环境,在开发、预览、生产都可以,不过在审核期间竟然没有生效,请求了’localhost’ 地址,审核人员看不到数据,导致审核不通过。

2、wx.getFileSystemManager

参考文档:


实现代码

let host = '';
let NODE_ENV = 'pro';
const fileManager = wx.getFileSystemManager();
try{
  fileManager.accessSync('/local.txt');
  NODE_ENV = 'dev';
}catch(e){}
if( NODE_ENV === 'pro' ){
  host = 'https://pro.qq.com';
}else{
  host = 'https://dev.qq.com';
}

这段代码遇到的问题是本地也获取不到local.txt 文件,所以暂时没有采用

相关文章
|
存储 API Python
FastAPI(24)- 详解 File,上传文件
FastAPI(24)- 详解 File,上传文件
1530 0
FastAPI(24)- 详解 File,上传文件
|
2月前
|
人工智能 安全 开发工具
VS2026下载 | Visual Studio 2026官网最新版安装使用教程(新手必看)
Visual Studio 2026是微软新一代智能IDE,深度融合AI辅助(精准补全、智能纠错、自动重构)、跨平台开发(Windows/macOS/Linux/移动)、云原生(Azure深度集成)及团队协作能力,支持C/C++、.NET、Python等多语言,大幅提升开发效率与质量。(239字)
|
网络安全 开发工具 git
git 出现错误:kex_exchange_identification: read: Connection reset by peer fatal
git 出现错误:kex_exchange_identification: read: Connection reset by peer fatal
git 出现错误:kex_exchange_identification: read: Connection reset by peer fatal
|
10月前
|
前端开发
文字显示在div 最下面,css怎么写
文字显示在div 最下面,css怎么写
652 0
|
SQL 程序员
sql中的distinct用法
`DISTINCT`在SQL中用于返回唯一不同的值,消除结果集中的重复行。基本用法包括:1) 选择单列唯一值,如`SELECT DISTINCT department FROM employees;`
1705 0
|
Web App开发 存储 人工智能
3D/XR线上展厅实时云渲染平台搭建方案
在数字化浪潮下,传统3D展厅面临高成本、维护难、兼容性差等问题。实时云渲染技术革新展览展示行业,通过云端渲染和超低延迟视频流推送,用户可使用XR设备沉浸式体验云展厅。结合VR/AR/AI技术,提供智能导览、展品推荐等功能,分析观众行为数据优化展览内容。该方案支持多平台访问,已在杭州亚运会等大型活动应用,极大降低参会门槛,提升传播和营销效果。平行云的实时云渲染技术支持低成本搭建在线展览平台,助力实现一机逛遍博物馆的美好愿景。
|
安全 关系型数据库 MySQL
分享一个 MySQL 简单快速进行自动备份和还原的脚本和方法
分享一个 MySQL 简单快速进行自动备份和还原的脚本和方法
763 0
|
算法 图形学
【推荐100个unity插件之4】OpenFracture插件实现unity3d物体破裂和切割
【推荐100个unity插件之4】OpenFracture插件实现unity3d物体破裂和切割
644 0
|
JSON 小程序 前端开发
【微信小程序 | 实战开发】配置开发环境、生产环境和API
【微信小程序 | 实战开发】配置开发环境、生产环境和API
2284 0
【微信小程序 | 实战开发】配置开发环境、生产环境和API