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

网站教学做暖视频网站免费

网站教学,做暖视频网站免费,什么叫企业网站,网站模板下载网站需求 博客系统升级#xff0c;本来是用 express 写的#xff0c;最近发现 Egg 不错#xff0c;正好学习升级一下。边学边写。 Ps#xff1a;相同的功能#xff0c;迭代的写法#xff0c;由浅入深#xff0c;做个记录。 开发 初始化 安装 node版本需要 14.20.0…需求 博客系统升级本来是用 express 写的最近发现 Egg 不错正好学习升级一下。边学边写。 Ps相同的功能迭代的写法由浅入深做个记录。 开发 初始化 安装 node版本需要 14.20.0 LTS版本最低要求 8.xnpm版本 6.1.0 mkdir egg-blogs cd egg-blogs npm init egg --typesimple npm install npm run dev默认启动的是 7001 端口。 创建目录结构 egg-blogs ├── package.json ├── app | ├── router.js │ ├── controller │ | └── home.js │ ├── service │ | └── user.js │ ├── middleware │ └── extend │ ├── helper.js ├── config | ├── plugin.js | ├── config.default.js安装配置插件 npm i --save egg-mysql在 config/plugin.js 中配置 /** type Egg.EggPlugin */ module.exports {// had enabled by egg// static: {// enable: true,// }mysql: {enable: true,package: egg-mysql} };在 config/config.default.js 中配置数据库信息 /* eslint valid-jsdoc: off *//*** param {Egg.EggAppInfo} appInfo app info*/ module.exports appInfo {/*** built-in config* type {Egg.EggAppConfig}**/const config exports {};// use for cookie sign key, should change to your own and keep securityconfig.keys appInfo.name 123;// add your middleware config hereconfig.middleware [];// 关闭安全配置config.security {xframe: {enable: false,},csrf: {enable: false,}};// 添加mysql配置config.mysql {client: {host: 127.0.0.1,port: 3306,user: root,password: 12345678,database: blogs,charset: utf8},app: true,agent: false,};// add your user config hereconst userConfig {// myAppName: egg,};return {...config,...userConfig,}; };开发逻辑 Controller 创建 app/controller/tags.js const {Controller} require(egg);class TagsController extends Controller {/** 获取标签列表 */async getTagList() {await this.ctx.service.tags.getTagList(this.ctx.request.query);}/** 新建标签 */async createTag() {await this.ctx.service.tags.createTag(this.ctx.request.body);}/** 更新标签 */async updateTag() {await this.ctx.service.tags.updateTag(this.ctx.request.body);}/** 删除标签 */async deleteTag() {await this.ctx.service.tags.deleteTag(this.ctx.request.query);} }module.exports TagsController;Service 创建 app/service/tags.js const {Service} require(egg);class TagsService extends Service {async getTagList(params) {const {ctx, app} this;const tagName params?.tagName || ;const result await app.mysql.query(SELECT * FROM tag WHERE tagName LIKE % tagName % ORDER BY create_time DESC)// 判断是否成功const isSuccess result Array.isArray(result);if (isSuccess) {ctx.state 200;ctx.body {code: 200,success: true,data: result,msg: 获取标签数据成功,show: false}} else {ctx.state 200;ctx.body {code: 500,success: false,msg: 获取标签数据失败,show: true}}}async createTag(params) {const {ctx, app} this;const tagInfo {id: ctx.helper.snowflakeId(),tagName: params.tagName,tagColor: params.tagColor,remark: params.remark,create_time: app.mysql.literals.now,update_time: app.mysql.literals.now}const result await app.mysql.insert(tag, tagInfo);if (result.affectedRows 1) {ctx.status 200;ctx.body {code: 200,success: true,data: tagInfo,msg: 创建标签成功,show: true}} else {ctx.status 200;ctx.body {code: 500,success: false,msg: 创建标签失败,show: true}}}async updateTag(params) {const {ctx, app} this;const tagInfo {id: params.id,tagName: params.tagName,tagColor: params.tagColor,remark: params.remark,update_time: app.mysql.literals.now}const result await app.mysql.update(tag, tagInfo);const isSuccess result result.affectedRows 1;if (isSuccess) {ctx.status 200;ctx.body {code: 200,success: true,data: tagInfo,msg: 修改标签成功,show: true}} else {ctx.status 200;ctx.body {code: 500,success: false,msg: 修改标签失败,show: true}}}async deleteTag(params) {const {ctx, app} this;const ids params.ids.split(,);const result await app.mysql.beginDoomedTransactionScope(async (conn) {for (let i 0; i ids.length; i) {await app.mysql.delete(tag, {id: ids[i]});}return {success: true}}, ctx);if (result.success) {ctx.status 200;ctx.body {code: 200,success: true,msg: 删除标签成功,show: true}} else {ctx.status 200;ctx.body {code: 500,success: false,msg: 删除标签失败,show: true}}} }module.exports TagsService;暴露路由 在 app/router.js 中暴露路由接口 /*** param {Egg.Application} app - egg application*/ module.exports app {const {router, controller} app;router.get(/, controller.home.index);// 操作标签router.get(/tags/getTagList, controller.tags.getTagList);router.post(/tags/createTag, controller.tags.createTag);router.put(/tags/updateTag, controller.tags.updateTag);router.delete(/tags/deleteTag, controller.tags.deleteTag); };总结 基础增删改查完成但是当前状态最好不要部署在服务器上。 问题 安全防护并未打开SQL防注入语法不对直接操作数据库不规范、不标准各类安全措施没有增加各类数据校验没有增加
http://www.w-s-a.com/news/608060/

相关文章:

  • 望都网站建设抖音广告投放收费标准
  • 网站制作软件排行榜上海市网站建设公司58
  • 什么是网站风格中国工商网企业查询官网
  • 专业建设专题网站wordpress lnmp wamp
  • 环保网站 下载页网站
  • 开源小程序模板江门关键词优化排名
  • 网站开发 知乎房地产型网站建设
  • 买完域名网站怎么设计wordpress 纯代码
  • 公司网站怎么做百度竞价宁波网络公司哪家好
  • 河西网站建设制作微信分销系统多层
  • 网站制作完成后应进入什么阶段石家庄网站建设找哪家好
  • 南通外贸网站推广自在源码网官网
  • 个人网站模板html下载餐饮vi设计案例欣赏
  • 高端网站建设wanghess网站开发售后服务承诺
  • 江西网站建设费用企业网站推广的方法有( )
  • 中国十大网站开发公司企业网站建设的要素有哪些
  • 网站防站做网站吉林
  • 嘉定区网站建设公司企业信息公示查询系统官网
  • 一个具体网站的seo优化产品介绍网站模板下载地址
  • 怎么做网站在网上能搜到你哈尔滨网站建立公司
  • 做家旅游的视频网站上海百度公司总部
  • 微信小程序公司网站怎么制作区块链平台定制开发
  • 网站资质优化ip地址域名解析
  • 如何搭建个人网站ps做网站首页怎么运用起来
  • 中小企业商务网站建设wordpress 安全加固
  • asp网站开发设计文档php建设网站怎么用
  • 服装公司网站建设需求分析报告seo搜索引擎优化实战
  • wordpress 扒站最近最新新闻
  • 手机wap网站开发与设计wordpress域名无法访问
  • 百度收录网站收费吗做网站用vs还是dw