【带并发限制的异步调度器Ⅲ】点餐排队系统

在前两篇文章
【带并发限制的异步调度器Ⅰ】原始Demo
【带并发限制的异步调度器Ⅱ】点餐排队系统Demo
的基础上,这次加入了图形化界面,这样就升级成一个完整的项目。我把这三篇文章总结为以下三种递进的阶段:
①单通道的任务调度器
②多通道的任务调度器,无页面的应用场景演示Demo,并增加了通道数及任务运行数的初始化配置
③多通道的任务调度器,有页面的应用场景操作,可配置初始化信息并持久化保存,可查看某一任务的运行情况,可实时添加及移除任务

第三阶段的技术总结如下:

  1. React组件图形化界面,形成最原始的可视化页面
  2. Egg.js企业级Node.js框架,提供接口请求以及安全防护
  3. Mongoose数据库存储,持久化配置信息
  4. React-redux提供组件间交互的状态管理,store机制给所有组件(隔层组件以及不同页面组件)提供全局数据
  5. Ant Design模态框提供便于交互的组件服务

第三阶段的功能点总结如下:

  1. 在“初始化”界面添加配置桌子信息,可移除添加的信息,可编辑添加的信息(添加相同人数的桌子信息即可覆盖原信息),可点击“完成配置”持久化配置数据,以供下次启动试用,可立即切换到“点餐排队”使用配置信息
初始化页面
添加配置数据
完成添加
  1. 进入系统时,系统会自动请求配置数据接口初始化操作页面需要用到的全局数据store(“点餐排队”和“初始化”使用的是store里的同一个数据源)
初始界面
数据加载后界面
  1. 点击初始化后,会出现后续操作按钮,点击“查看桌子使用信息”,会出现桌子的使用信息情况


    操作按钮
桌子使用情况
  1. 点击“用餐入座”,相应的顾客就会在N人桌里占一个位子,如果有空闲桌,可以直接用餐(若按原始Demo的说法,就是执行任务队列有空缺,任务直接进入执行任务队列运行,若已满,则会进入待执行任务队列),若没有,则会拿到一个排队编号等待入座


    添加用餐信息
取号情况
  1. 当拿到编号时,可点击“查看某桌排队情况”,输入相应编号来查看此编号目前所处的情况,具体情况如下:
  • 无此桌点餐信息
  • 正在用餐
  • 排队情况
无此桌点餐信息
正在用餐
  • 排队情况
  1. 当某桌用餐结束时,可点击“结束用餐”,输入桌子编号,把执行任务从正在用餐队列里移除
移除用餐前
移除用餐
移除用餐后

以上就是此系统的全部功能,完整项目放在github上,如有需要请自取。

总结下开发此系统遇到的问题:

  1. 服务端无法接受 post 请求,并且请求接口报错 403 :message: 'invalid csrf token'
    原因:Egg框架内置中间件安全防护,默认开启防止 XSS 攻击 和 CSRF 攻击,所以前端请求post接口时需要在header请求头里添加csrfToken,让Egg帮忙验证,具体配置如下:
    server端:
//config.default.js
  //csrf配置
  exports.security= {
    csrf : {
      headerName: 'x-csrf-token', // 自定义请求头
    }
 }

client端:

'use strict'
import api from './api';
// 封装获取 cookie 的方法
function getCookie(name){
  var arr,reg=new RegExp("(^| )"+name+"=([^;]*)(;|$)");
  if(arr=document.cookie.match(reg))
  return unescape(arr[2]);
  else
  return null;
}

function saveSetting(deskData, successCB, failCB) {
  return $.ajax({
    url: api.COMPANY + '/setting',
    method: 'POST',
    contentType: 'application/json',
    headers:{
      // 前后端不分离的情况加每次打开客户端,egg会直接在客户端的 Cookie 中写入密钥 ,
      //密钥的 Key 就是 'scrfToken' 这个字段,所以直接获取就好了
      'x-csrf-token': getCookie("csrfToken"), 
    },
    data: JSON.stringify({ data:deskData })
  }).then(successCB, failCB);
}
  1. 开发前端的操作页面时,对React-redux的store使用不当,导致不同页面组件获取store中的全局数据出现问题。
    具体情况:当把页面组件从UI组件变为容器组件(使用connect处理)时,未能成功获取到store数据,但实际是错误理解了React-redux和redux获取全局数据store的方式。
    解决:React-redux子组件获取store的方式是在mapStateToProps方法中处理的,而redux是通过this.context.store来获取,以下是React-redux获取store的项目代码:
/app/view/container/DinnerPane.js

import { connect } from 'react-redux';
import dinnerPane from '../component/dinnerPane/dinnerPane';

function mapStateToProps(state) {
  return {
    deskData: state.deskData||{}
  };
}

function mapDispatchToProps(dispatch) {
  return {};
}

export default connect(mapStateToProps, mapDispatchToProps)(dinnerPane);

初始化store是在dinnerPane的上层容器Content里处理的,先请求配置数据get接口,然后dispatchinitDeskDataAction到store里更新数据:

/app/view/container/content/Content.js

import { connect } from 'react-redux';
import Content from '../../component/Content/Content';
import { getSetting } from '../../utils/WebAPIUtils';
import { initDeskDataAction } from '../../action/initDataActionCreator'

function mapStateToProps(state) {
  return {
    deskData: state.deskData
  };
}

function mapDispatchToProps(dispatch) {
  return {
    initDeskDataRequest: function (companyId, callback) {
      return getSetting(companyId, function (result) {
        callback(null, result);
      }, function (err){
        callback(err);
      });
    },
    initDeskData: function(deskData){
      dispatch(initDeskDataAction(deskData));
    }
  }
}

export default connect(mapStateToProps, mapDispatchToProps)(Content);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,923评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,154评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,775评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,960评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,976评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,972评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,893评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,709评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,159评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,400评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,552评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,265评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,876评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,528评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,701评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,552评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,451评论 2 352

推荐阅读更多精彩内容