简单mock server模拟用户请求给小程序提供数据

2024-02-22 10:20

本文主要是介绍简单mock server模拟用户请求给小程序提供数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

整理小程序代码时发现一此小程序离开了mock-server基本上没有办法显示了,因此用node,express来满足给小程序提供演示数据的功能 

const express = require('express');  
const { createCanvas, Image } = require('canvas');  
const fs = require('fs');  
const path = require('path');  
const app = express();  
const port = 3000;  
const querystring = require('querystring');  function createImageFromPath(req, res) {const imagePath = req.path;  const match = imagePath.match(/\/(\d+)x(\d+)\.jpg/);  if (match) {  const [, widthStr, heightStr] = match;  const width = parseInt(widthStr, 10);  const height = parseInt(heightStr, 10);  if (isNaN(width) || isNaN(height)) {  return res.status(400).send('Invalid image dimensions');  }  const canvas = createCanvas(width, height);  const ctx = canvas.getContext('2d');  // 生成随机背景颜色  const randomColor = '#' + Math.floor(Math.random() * 16777215).toString(16);  ctx.fillStyle = randomColor;  ctx.fillRect(0, 0, width, height);  // 获取对比色  const contrastColor = getContrastColor(randomColor);  const queryParams = req.query.q;  console.log(queryParams);// 在图像上显示尺寸字样  const fontSize = 30; // 字体大小  let text = `${width}x${height}`; // 尺寸字样            if (queryParams) {  text = queryParams; // 如果查询参数不为空,使用查询参数的值  }  ctx.font = `${fontSize}px simsun`;  const metrics = ctx.measureText(text); // 测量文本尺寸  const x = (width - metrics.width) / 2; // 计算文本水平居中位置  const y = height / 2 + fontSize / 2; // 计算文本垂直居中位置  // 画描边  // ctx.strokeStyle = contrastColor;  // ctx.lineWidth = 10;  // ctx.strokeText(text, x, y);  // 画填充文本  ctx.fillStyle = contrastColor;  ctx.fillText(text, x, y);  // 画图像边框  ctx.strokeStyle = contrastColor;  ctx.lineWidth = 10; // 边框宽度  ctx.strokeRect(0, 0, width, height); // 画矩形边框  // 将canvas转换为Buffer对象  const buffer = canvas.toBuffer('image/jpeg');  // 设置响应头信息  res.setHeader('Content-Type', 'image/jpeg');  res.setHeader('Content-Disposition', 'inline; filename=generated.jpg');  res.setHeader('Cache-Control', 'no-store, no-cache, must-revalidate, proxy-revalidate');  res.setHeader('Pragma', 'no-cache');  res.setHeader('Expires', '0');  // 发送图片Buffer到响应中  res.send(buffer);  } else {  // 如果没有匹配到尺寸,则发送404错误  res.status(404).send('Not Found');  }  
}  // 辅助函数:获取对比色  
function getContrastColor(color) {  // 将颜色字符串转换为RGB数组  const rgb = color.slice(1).match(/.{2}/g).map(byte => parseInt(byte, 16));  // 计算亮度  const luminance = (0.299 * rgb[0] + 0.587 * rgb[1] + 0.114 * rgb[2]) / 255;  // 根据亮度返回对比色  return luminance > 0.5 ? '#000000' : '#FFFFFF';  
}// 使用中间件处理所有以.jpg结尾的请求  
app.use(express.static(path.join(__dirname, 'public'))); // 假设你的静态文件在public文件夹中  
app.get(/\/(\d+)x(\d+)\.jpg/, createImageFromPath);  
app.get(/\*.jpg$/, (req, res) => {  res.status(404).send('Not Found');  
});  app.get('/:filename', (req, res) => {  const fileName = req.params.filename;  const filePath = path.join(__dirname, `${fileName}.json`);  fs.readFile(filePath, 'utf8', (err, data) => {  if (err) {  if (err.code === 'ENOENT') {  // 文件不存在的错误  res.status(404).send('File not found');  } else {  // 其他类型的错误  res.status(500).send('Internal Server Error');  }  return;  }  res.setHeader('Content-Type', 'application/json');  res.send(data);  });  
});  
app.listen(port, () => {  console.log(`Server is running on port ${port}`);  
});

整理一个o2o行业  洗衣小程序时添加了一些演示数据,这个洗衣程序, 有充值页面, 在地图搜索洗衣机, 拖动地图时, 可以实时加载洗衣机, 可以绑定洗衣, 没有后台, 只有简单的mock server, 看了一下这是一个未完成的项目, 感兴趣的话, 可以动手完善一下, 

下面是一些程序的截图

这篇关于简单mock server模拟用户请求给小程序提供数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/734947

相关文章

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

SpringBoot请求参数传递与接收示例详解

《SpringBoot请求参数传递与接收示例详解》本文给大家介绍SpringBoot请求参数传递与接收示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录I. 基础参数传递i.查询参数(Query Parameters)ii.路径参数(Path Va

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

使用Python的requests库来发送HTTP请求的操作指南

《使用Python的requests库来发送HTTP请求的操作指南》使用Python的requests库发送HTTP请求是非常简单和直观的,requests库提供了丰富的API,可以发送各种类型的HT... 目录前言1. 安装 requests 库2. 发送 GET 请求3. 发送 POST 请求4. 发送

SQL Server 查询数据库及数据文件大小的方法

《SQLServer查询数据库及数据文件大小的方法》文章介绍了查询数据库大小的SQL方法及存储过程实现,涵盖当前数据库、所有数据库的总大小及文件明细,本文结合实例代码给大家介绍的非常详细,感兴趣的... 目录1. 直接使用SQL1.1 查询当前数据库大小1.2 查询所有数据库的大小1.3 查询每个数据库的详

Spring Boot 整合 SSE(Server-Sent Events)实战案例(全网最全)

《SpringBoot整合SSE(Server-SentEvents)实战案例(全网最全)》本文通过实战案例讲解SpringBoot整合SSE技术,涵盖实现原理、代码配置、异常处理及前端交互,... 目录Spring Boot 整合 SSE(Server-Sent Events)1、简述SSE与其他技术的对

基于Python编写自动化邮件发送程序(进阶版)

《基于Python编写自动化邮件发送程序(进阶版)》在数字化时代,自动化邮件发送功能已成为企业和个人提升工作效率的重要工具,本文将使用Python编写一个简单的自动化邮件发送程序,希望对大家有所帮助... 目录理解SMTP协议基础配置开发环境构建邮件发送函数核心逻辑实现完整发送流程添加附件支持功能实现htm

C#控制台程序同步调用WebApi实现方式

《C#控制台程序同步调用WebApi实现方式》控制台程序作为Job时,需同步调用WebApi以确保获取返回结果后执行后续操作,否则会引发TaskCanceledException异常,同步处理可避免异... 目录同步调用WebApi方法Cls001类里面的写法总结控制台程序一般当作Job使用,有时候需要控制

python连接sqlite3简单用法完整例子

《python连接sqlite3简单用法完整例子》SQLite3是一个内置的Python模块,可以通过Python的标准库轻松地使用,无需进行额外安装和配置,:本文主要介绍python连接sqli... 目录1. 连接到数据库2. 创建游标对象3. 创建表4. 插入数据5. 查询数据6. 更新数据7. 删除