当前位置: 首页 > wzjs >正文

做模具做什么网站抖音广告推广怎么收费

做模具做什么网站,抖音广告推广怎么收费,网站建设方案报价,电商代运营收费标准在 Web 开发中,请求参数处理与数据校验是保障系统稳定性的第一道防线。本文将深入探讨 Egg.js 框架中参数处理的完整解决方案,涵盖常规参数获取、高效校验方案、文件流处理等核心功能,并分享企业级项目中的最佳实践。 一、多场景参数获取策略…

在 Web 开发中,请求参数处理与数据校验是保障系统稳定性的第一道防线。本文将深入探讨 Egg.js 框架中参数处理的完整解决方案,涵盖常规参数获取、高效校验方案、文件流处理等核心功能,并分享企业级项目中的最佳实践。

在这里插入图片描述


一、多场景参数获取策略

1. Query 参数处理

适用于 URL 中的查询参数,通过 ctx.query 直接获取:

// GET /api/users?type=admin&page=2
async list() {const { ctx } = this;const { type = 'user', page = 1 } = ctx.query;ctx.body = await ctx.service.user.list({type: type.trim(),page: Number(page)});
}

注意点

  • 自动完成 URL decoding
  • 参数值始终为字符串类型
  • 使用解构设置默认值

2. Params 路由参数

通过路由占位符获取参数:

// router.js
router.get('/api/users/:id', controller.user.show);// controller
async show() {const { ctx } = this;const user = await ctx.service.user.find(ctx.params.id);if (!user) {ctx.throw(404, '用户不存在');}ctx.body = user;
}

3. Body 请求体处理

处理 POST/PUT 请求的请求体数据:

// config/config.default.js
exports.bodyParser = {jsonLimit: '10mb',formLimit: '10mb'
};// controller
async create() {const { ctx } = this;const { name, email } = ctx.request.body;const user = await ctx.service.user.create({name: ctx.helper.escape(name),email: email.toLowerCase()});ctx.body = user;
}

安全建议

  • 始终对用户输入进行转义处理
  • 使用 ctx.validate() 验证请求类型
  • 敏感字段需二次验证

二、数据校验强化方案

1. 安装与配置校验插件

$ npm install egg-validate --save
// config/plugin.js
exports.validate = {enable: true,package: 'egg-validate'
};

2. 基础校验实践

async create() {const { ctx } = this;ctx.validate({username: { type: 'string', required: true },password: { type: 'password', compare: 're_password' },email: { type: 'email', allowEmpty: true },age: { type: 'number', min: 18, max: 60 }});// 业务逻辑
}

3. 校验规则扩展

支持以下校验类型:

  • 基础类型:string, number, int, float
  • 格式验证:email, url, ip
  • 特殊规则:date, datetime, enum
  • 复杂校验:object, array

4. 扩展校验规则

// app.js
app.validator.addRule('mobile', (rule, value) => {const regex = /^1[3-9]\d{9}$/;if (!regex.test(value)) {return '手机号格式错误';}
});// 使用自定义规则
ctx.validate({phone: { type: 'mobile', required: true }
});

5. 统一错误处理

// app/middleware/error_handler.js
module.exports = () => async (ctx, next) => {try {await next();} catch (err) {ctx.status = err.status || 500;ctx.body = {code: ctx.status,message: err.message,details: err.errors || []};}
};// config/config.default.js
config.middleware = ['errorHandler'];

三、文件上传进阶技巧

1. 基础文件上传

// config/config.default.js
exports.multipart = {mode: 'file',fileSize: '50mb',whitelist: ['.png', '.jpg', '.gif']// whitelist也可以配置为如下方式fileExtensions: [".png", ".jpg", ".gif"]
};// app/controller
async upload() {const { ctx } = this;const stream = await ctx.getFileStream();ctx.body = await ctx.service.upload.save(stream);
}// app/service
const sendToWormhole = require('stream-wormhole');async save(stream, obj) {const { ctx } = this;try {// 创建上传目录const uploadDir = this.createUploadDir();// 生成唯一文件名const filename = `${crypto.randomUUID()}${path.extname(stream.filename)}`;const target = path.join(uploadDir, filename);// 写入文件const writeStream = fs.createWriteStream(target);stream.pipe(writeStream);// 等待写入完成await new Promise((resolve, reject) => {writeStream.on('finish', resolve);writeStream.on('error', reject);});// 返回结果return {code: 200,data: {originalName: stream.filename,fileName: filename,size: stream.bytesRead,url: `/files/${filename}`,formData: stream.fields // 其他表单字段}};} catch (err) {// 销毁未消费的流await sendToWormhole(stream);ctx.throw(500, `文件上传失败: ${err.message}`);}
}// 创建上传目录(按日期分类)
createUploadDir() {const dir = path.join(this.app.config.baseDir,'app/public/uploads',dayjs().format('YYYY-MM-DD'));if (!fs.existsSync(dir)) {fs.mkdirSync(dir, { recursive: true });}return dir;
}

2. 大文件流式处理

const sendToWormhole = require('stream-wormhole');async upload() {const stream = await ctx.getFileStream();try {// 上传到云存储const result = await cloudStorage.upload(stream);return { url: result.url };} catch (err) {// 销毁未消费的流await sendToWormhole(stream);ctx.throw(500, '上传失败');}
}

3. 文件错误处理中间件

app/middleware/error_handler.jsmodule.exports = () => async (ctx, next) => {try {await next();} catch (err) {if (err.code === 'LIMIT_FILE_SIZE') {ctx.status = 413;ctx.body = { error: '文件大小超过限制' };} else if (err.code === 'INVALID_FILE_TYPE') {ctx.status = 415;ctx.body = { error: '不支持的文件类型' };} else {ctx.status = err.status || 500;ctx.body = { error: err.message };}}
};

性能优化建议

  • 使用管道(pipe)处理流数据
  • 限制并发上传数量
  • 实现断点续传功能

最佳实践总结

  1. 始终优先校验后处理原则
  2. 防御性编码应对异常输入
  3. 敏感操作使用二次验证
  4. 日志记录关键参数处理过程
  5. 定期审计参数处理代码

下篇预告:服务层抽象与复用逻辑

在下一篇中,我们将深入探讨:

  • Service层的职责与依赖注入
  • 业务逻辑封装与复用模式
  • 事务处理与数据库操作封装
  • 服务单元测试策略

核心价值:通过合理的抽象设计,提升代码复用率 300%,降低维护成本 50%!


通过本文的实践方案,可有效提升接口健壮性,降低安全风险 80% 以上。建议结合项目需求选择合适的校验策略,并建立统一的参数处理规范。欢迎在评论区留下你遇见的「参数传递与校验」设计经验与挑战,共同探讨最佳实践!

http://www.dtcms.com/wzjs/499753.html

相关文章:

  • 网站备案信息注销原因怎么搜索关键词
  • 音乐网站可做哪些内容创建网站
  • 内容展示型网站特点小程序怎么引流推广
  • 外贸免费建设网站苏州网站建设书生商友
  • 企业网站建设哪家seo刷关键词排名优化
  • 辽阳企业网站建设费江门网站定制多少钱
  • 哈尔滨网站搜索优化公司seo推广绩效考核指标是什么
  • 设计logo网站免费奇米网络营销的推广方式都有哪些
  • wap视频网站建设难吗?中国进入全国紧急状态
  • 商场网站建设百度推广app下载
  • 福州短视频seo排行seo入门教学
  • 陕icp网站建设什么是sem
  • 网站设计师培训排位及资讯
  • 漳浦网站制作抖音推广网站
  • 建设银行甘肃分行网站怎么创作自己的网站
  • 北京模板网站建设费用优化公司流程制度
  • 网站制作公司哪家专业外贸平台app
  • 平台网站模板素材图片下载深圳最新通告今天
  • 公司网页是什么网站建设seo优化培训
  • 电脑管理软件排行榜seo系统教程
  • 枞阳网站制作站长之家源码
  • 达州网站建设的公司seo研究中心道一老师
  • 微信网站开发怎么做陕西新闻今日头条
  • en blog wordpress宁波seo推广方式排名
  • 做网站一般注意些什么腾讯企点官网下载
  • 广告设计创意作品漯河搜狗关键词优化排名软件
  • 网站字体颜色大小小程序模板
  • 个人做游戏下载网站侵权吗推广策略包括哪些内容
  • 网站空间多大合适成人职业技能培训班
  • 游戏开科技的软件厦门关键词seo排名网站