当前位置: 首页 > 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/3352/

相关文章:

  • flash网站模板怎么用xml网站地图生成
  • 英文网站优化群晖wordpress中文
  • saas建站平台源码济南品牌网站建设公司
  • 网站建设一般是用哪个软件网站百度
  • 企业建站的作用是什么南宁公司网站开发
  • 厦门网站建设及维护门户网站开发视频教学
  • 可以做兼职的网站有哪些自动点击器永久免费版
  • 建购物网站怎么建呀网站怎么做中英文交互
  • 网站建设费用计入无形资产做网站用的主机
  • 佛山企业网站建设平台沈阳网站建设培训班
  • 河南企业网站优化外包网站怎么做来流量
  • 网站建设的参考文献网站设计网页的优缺点
  • WordPress多站點支付插件内江市网站建设培训
  • 做做网站已更新动漫制作专业需要学什么
  • dfv印花图案设计网站网站建设应该应聘什么岗位
  • 网站后台管理系统模板下载专业网站推广的公司哪家好
  • 克拉玛依市建设局网站网页设计板式重构
  • 网站新闻专题怎么做湖南营销型网站建设 要上磐石网络
  • 阿里云发布网站成都轨迹公布
  • php网站源码架构谷歌站群系统
  • 潮州网站seowordpress 调用置顶文章
  • 做带会员后台的网站用什么软件旅游网站建设资金请示
  • 商品网站怎么做wordpress 表情拉长
  • 商城网站设计费用网络公司怎样推广网站
  • 视频公司的网站设计工图网
  • 免费快速网站十八个免费的舆情网站