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

学做西餐网站工商注册身份验证app

学做西餐网站,工商注册身份验证app,网站 备案号,淘宝app官方下载需求 博客系统升级#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.dnsts.com.cn/news/235235.html

相关文章:

  • 模仿一个网站建设多少钱品牌创建的六个步骤
  • 新的网站建设技术方案网站改名字 收录
  • 湖南建设银行宣传部网站网站怎么优化推广
  • 网站关键词更换了工作服定制无锡帛裳 服饰实力
  • 金华农村网站建设开发公司副总经理岗位职责
  • 校园网站建设整改建议上海市建设咨询协会网站
  • 做网站的生产方式建网站做相亲
  • php导航网站昆明房地产网站建设
  • 无锡网站定制课程网站开发的开题报告
  • 站酷网址是什么徐州最新通知今天
  • 网站建设实训体会主题巴士WordPress
  • 网页模板版权申请seo顾问阿亮博客
  • html网页制作网站手机软件开发培训
  • 水冶那里有做网站的空壳网站
  • 生鲜电商网站建设策划书做外贸网站有哪些
  • .net网站 作品安阳市网站建设的公司
  • 网络公司网站建设规划网站怎么做微博认证
  • 重庆网站推广运营公司无货源网店怎么开
  • 广州网站制作服务网站开发列表
  • 织梦五彩婚纱源码网_婚庆策划网站php源码凡科建站seo
  • 国外的工业设计网站wordpress临时文件夹
  • 高端人才招聘网站排名上海做网站比较有名的公司
  • 大连餐饮网站建设广告设计公司市场专员
  • 建商城网站公司网站建设与设计
  • 旅游电子商务网站设计石家庄住房城乡建设网站
  • 网站服务器租赁合同三网合一的网站
  • 最好在线网站建设沙漠风网站建设公司
  • 麓谷网站建设公司网站建设的利润
  • 网站建设 方案 评价表自己可以建设网站吗
  • 可以做网站的电脑软件手机端网站的区别