十一终于完了,进入到新的项目.终于有时间来总结一下做的一个游泳场的项目了.从项目开始到现在,已经三个月了.中间有很多次想要将这个东西写下来,始终没机会.现在有时间,好好想一下,也算是对自己的一个总结.
先说一下这个项目,是一个游泳场的收费系统,类似于公交车的卡系统.操作人员可以通过终端进行售票,然后用户凭票在游泳池门口验票进入;同时,也可以通过操作人员出售可以多次使用的IC卡,在游泳池门口通过刷卡器刷卡进入.这个系统的使用者分销售员和验卡票员,且游泳场分布在不同的地方.故需要作成一个联网的模式,以便进行数据同步.
因此这个项目从一开始就分为两个部分,卡和票.
票通过销售终端销售出去(用票打印机打印出来),在消费端由验票员验票进入.由于硬件条件限制,票打印机就是一般的打印机,没有任何防伪标记,且验票员由于水平原因也无法进行验证真伪,故设计为一个通过机器验票进入的方式,即通过扫描仪的方式.将条形码打印在票上,在消费时通过扫描条形码进行验证.
卡则是通过销售终端根据用户的类型办理不同的卡(不同卡的消费方式不一样,如折扣,金额,次数,时间).之后,在消费终端,通过将卡放在读卡器上进行读卡,对消费数据进行处理之后放行用户.
这个项目先是由一位同事在弄,后来由于出现了金额数据上的原因.导致客户对系统产生了不好的反应,因此由我来进行重新设计并编码.要求的时间为15天,而实际上用了30天.且说说前个同事在碰到的问题:
- 前期需求不太规范.由于客户是个行政单位,在这个项目实施的过程之中,客户单位行政上发生了变化.导致负责这个项目的人员发生了变化,而导致需求临时变化.
- 设计及经验上考虑不足.未考虑到此个项目在数据上的安全及完整.而在进行一些数据结构上的设计时,有些关键性的数据并没有出现在对象属性中,如消费和销售的时间.
- 程序编码不严谨.在对一些时间的处理上,未考虑到实际系统中的运动环境与想象中的差异,而任意作出一些判断.在对销售和消费时间的处理上,取值的时间为客户端机器时间而不是服务器时间而导致当两者时间不一致时出现了销售和消费时间与真实时间不一致的问题.
- 设计不充分,未考虑到扩展.在项目运动中,客户根据实际要求,提出一些需要限制的条件或者消费卡类.由于前期未考虑到这部分,而后面在要增加此功能时,对于前者只能在数据库中增加一个字段,而对于后者,只能通过修改程序代码来解决.这就导致程序代码判断字段越来越多,且越来越复杂.或者,一直不能让软件能够适应客户的变化需求.
- 需求的更改欠考虑.在项目中,涉及到一个操作用户登陆问题.当天操作用户已打印财务数据时,就不能再登陆系统.这个需求在程序开发初期,就已经被内定为一个重要的限制.而在项目运行期间,用户的一句话让主开发同事轻易就修改了这个设定,而没有考虑到修改之后产生的后果,以致于后来在操作人员的金额数据上产生一个纠纷,并由于这个设定的修改和前面的时间问题,使得某操作人员在上交金额和实际统计金额有差异时,有相当的理由来为自己开脱.
- 对用户数据不够重视.这个是最重要的问题.由于对整个系统的完整性未欠考虑,并没有考虑到用户数据的重要性.当出现一些数据上的不一致时,直接通过修改数据库数据以达到一致的效果.而修改的数据却是用户的金额类数据,且在修改时让客户在旁边观看,以致于到后来客户都明白做的行为代表什么并且指导同事修改哪些数据.这样的结果,直接导致用户金额数据的正确性受到质疑.以造成最后,用户对数据的正确性表示怀疑.这个是最重要的问题.
当出现这些问题之后,公司要求整个项目重新设计并编码.由我来进行负责,所以这个项目从一开始就是一个救火性质的项目.
在设计中,根据现有客户提出的问题,进行整体上的重新考虑,并重新开发了系统.在开发中,卡这部分进行了重新考虑.由于前个设计,卡这部分由一位delphi同事以控件的形式内嵌于界面上(这个项目是bs系统),而导致在需要改变卡一些定义数据时,需要对这个控件进行重新修改并重新在消费终端进行注册.为了修正这个问题,决定将卡部分逻辑代码放在服务端来完成(前个设计是由控件在客户端来完成),而控件只负责与硬件交互,取得IC卡信息和与读卡器交互发出声音.这样就涉及到控件与其他进行交互的问题,主要是控件与js之间的双向交互.控件向js发生命令,再由js根据命令及相应脚本信息向指定服务发生信息,将取回的数据根据结果来控制控件与硬件的交互(如发声音).在网上找了半天,找到一个类似的方法,但用到实际中就出问题(界面是一个框架性iframe界面),而导致控件无法与实际界面取得交互.后来决定用apple的方式来进行处理,在网上也得到了apple与js之间的详细交互,并实验成功.在修改了相应代码之后,终于使apple能够工作了.便发声部分还有些问题(主要是读卡是一个连续的死循环模式,而发声同样要调用读卡器,导致出现了占用锁方面的问题),后来钻研了许久,终于以一种讨巧的方式使得读卡与发声能够近似地独立工作,而不互相影响.
一个月后,新系统正式上线.在成功将旧数据转到新系统中时,第二天就出现了新的问题.所有的读卡都出现了问题,原因就在于原读卡器提供的java动态库在读卡内码(一个惟一编码)时,出现了数据的溢出问题.原动态库RD800提供的java DLL中,读出的卡内码以int数值返回,而实际中的数据却是long型,而导致读出数据与真实数据不能对应,而不能正确读卡和刷卡.在通过与硬件厂商联系之后,终于拿到了新的dll库(其实就是java的本地库).更新之后成功运动了.
第一天,客户根据前一个系统的使用习惯,对新系统提出了一些问题.不过都是些小小的界面及显示性问题.马上在公司修改之后,在第二天进行程序更新.这样来回几天,系统终于能够完整地运行了.后来,根据用户的要求,增加了一些新的功能,由于,在设计时已经考虑到了,故新系统中的数据结构完全能够支持客户的新需求,故增加的功能都能够很好地和系统兼容运行.
整个系统,从我接手到最后客户提不出更多的需求结束,已是3个月了.中间,也实实在在地接触了客户,了解了一些客户的情况.也算是给一直从事程序开发的自己提供一些实际的用户经验.下面是我总结的一些:
- 不要把客户的水平想得太高.最开始想到的客户至少会使用电脑,而在实际中由于许多客户都是临时请来的,有的完全不懂电脑,连鼠标都不会用.所以在一些设计上,要考虑到用户的水平,尽量减少客户的操作.如,在消费终端,用户只需要点击一个<验票验卡>就可以不再用鼠标而只用扫描仪和验卡器来完成验票和验卡的一天操作了.
- 客户不会看系统中的任何提示信息.在验票中,要求验的条码长度为13位(EAN-13).在一些特殊情况下,扫描仪会扫描出非13位的条码,当界面出现alert形式的提示框(提示票条码长度不足)时,用户会直接认为这是通过,而不理会此问题.这样就导致了接下来的操作全部失效.最后,将这个警告信息以验票失败的形式放在界面上才解决这个问题.
- 客户会把任何非程序问题归结为程序上的问题.在销售终端的售卡处,要用于照相机用于采集消费者头像.(这个硬件部分不由公司提供,公司只负责软件部分).当用户由于不规范操作,出现照相机使用不了或无法与电脑相连接时,第一想到的是程序出了问题,而不是操作上的问题.一旦出现问题,就打电话让解决.我们倒成了电脑维护员了.
- 客户经常会根据自己的使用提出新的需求,而不考虑此需求是否恰当.如前面的第5条,这些修改都是由用户最先提出,后来又提出修改的.如果将客户的需求全部不加分析的接收之后,当发生某些问题时,客户永远不会承认是自己的问题,而永远会说是软件本身的问题.这样就使得当提出新的需求和修改时,我常常会先想想这个问题与设计中的一些约束是否违被.一旦出现冲突就马上提出,并且让用户写出明确的修改意见,并签字.(前个系统,都没有签字,只是由客户口头说)
- 一定要严格控制需求的变化.一旦需求确定之后,就必须要将新的需求,往后推或者直接拒绝掉.不然,一个项目永远没有结束的时候,当然也永远没有验收的时候.
现在这个项目已经全部完了,我也不想再趟这个混水了.差一点就陷在这个项目里了.现在作了这些总结,希望在以后的开发中也给自己提个醒,没出类似的错误.
有兴趣的朋友,可以去看看这个系统.看看实际运行如何.地址:成都市猛追湾游泳场.
分享到:
相关推荐
总结来说,这个文档揭示了**市云龙湖万人游泳场作为一个大型公共设施的高标准建设和精细化管理,以及其在城市文化和公共服务中的重要角色。同时,这也为其他类似设施提供了管理和安全保障的参考范例。
上海花滑游泳锦标赛电视转播工作总结是对2015年在上海举办的国际滑联花样滑冰世界锦标赛电视转播工作的全面回顾。此次赛事不仅是上海乃至中国冰上运动发展的一个里程碑,也对北京和张家口申办冬奥会起到了积极的推动...
- 清场安全:确保游泳池区域安全,完成当日工作总结。 以上岗位细则旨在为物业项目会所游泳池提供一个高效、安全、卫生的运营环境,保障业主和游客的游泳体验,同时也体现了物业公司的专业管理和人性化服务。
策划一场游泳比赛是组织者对体育活动策划能力的综合体现,它不仅需要考虑比赛的流程和规则,还需要关注参赛者的安全和活动的宣传推广。以下是对这个游泳比赛策划方案的详细解析: 一、活动背景与意义 这次游泳比赛...
1. **活动策划**:教师在暑期兴趣班结束之际策划了一场游泳比赛,旨在丰富学生的暑期生活,这体现了活动策划的重要性,包括目标设定、场地选择、人员组织等。 2. **团队协作**:文中提到学生们在比赛中相互竞争,...
7. **项目总结**: - 该项目有利于国家和人民,市场前景广阔,具有系统性工程的特点,有望成为生态农业的典范,但需要各级领导的支持和配合。 项目中提到的两种特色农产品——太空桔柚和福本脐橙,都是经过改良的...
总结来说,HTML5游泳池水波纹动画代码结合了HTML5的结构元素、CSS3的动画特性以及jQuery的事件处理和动画功能,为用户提供了互动性强且视觉效果逼真的动态体验。这种技术在网页设计、游戏开发、用户界面设计等领域都...
在体育设施的规划设计上,项目应兼顾不同年龄层和身体状况的居民需求,提供多样化的健身设施和服务,如健身房、游泳池、篮球场、羽毛球场等。同时,考虑环境保护和能源利用效率,采用绿色建筑理念和技术,确保项目的...
工程简介部分对体育中心的各个组成部分进行了概述,包括体育场、体育馆、游泳场、综合训练馆以及新建连廊等。结构概况则详细介绍了各建筑的结构特点,为后续的钢结构安装提供了基础信息。 1. 体育场:作为大型体育...
总结来说,《项目竣工验收流程指引》不仅为项目验收提供了标准化流程,还为确保项目的整体质量和安全提供了保障。通过对每个验收环节的详细规划和指导,项目团队可以更加高效地管理验收过程,从而顺利地推进项目最终...
在策划和执行一场游泳锦标赛中,软件开发扮演着不可或缺的角色。首先,赛事管理系统是必不可少的,它可以用来处理参赛者的报名、分组、成绩记录和信息发布等任务。这样的系统通常包括数据库设计,用于存储选手信息、...
【CSS3小丑鱼海底游泳动画】是一种...总结起来,CSS3小丑鱼海底游泳动画是一个展示CSS3强大动画能力的实例,通过关键帧动画、选择器、伪元素以及背景图像等特性,能创造出逼真的海底世界,为用户带来沉浸式的浏览体验。
2. **总图规划方案**:对体育中心的整体布局和空间组织的规划,包括运动场地、停车场、绿化区域等。 3. **建筑方案**:具体到各建筑物的设计,如体育馆、游泳池、健身房的造型、功能分区等。 4. **结构设计**:关于...
在本文档中,"幕墙施工...总结来说,这份幕墙施工组织设计是一个综合性的工程实施蓝图,涵盖了从设计、材料选择、施工技术到项目管理的各个方面,旨在确保某大学游泳跳水馆玻璃幕墙和屋顶的施工质量和安全高效进行。
### 知识点总结 #### 一、项目概述与背景 - **项目名称**:xx县现代农业综合开发示范区茶博园项目 - **建设地点**:位于xx县内选定的具体位置 - **建设单位**:具体建设单位名称,法人代表等信息 - **项目主管单位...
2. 游泳池:游泳是残疾人运动中常见的项目,游泳池的建设有助于提升运动员的水上技能。 3. 服务中心与行政办公楼:为运动员提供日常生活和管理工作所需的支持服务。 四、建筑工程与公用设施 建筑工程将考虑无障碍...
1. **视觉叙述**:广告通过一系列镜头切换,展示了宝湖山庄的自然景观,包括环绕的山脉、清澈的湖泊、别墅建筑以及各种配套设施,如网球场、高尔夫球场、健身房、游泳池和幼儿园。这些镜头旨在传达项目与自然和谐...
迷宫项目则是一场智力和决策能力的测试。通过反复尝试和失败,我学会了如何适应环境变化,快速做出正确的判断,同时锻炼了应对挫折的能力。 高空项目如断桥、信任桥和天使之手,无疑是整个训练中最刺激的部分。这些...
例如,可以优先考虑设立健身房、游泳池、桑拿、餐厅和儿童活动区,再根据项目的特色和定位,适当增加舞蹈室、瑜伽房、商务设施或个性化运动区等。 总结,高端公寓会所的功能配置应当全面且有针对性,既要满足住户的...
在日常生活方面,项目内设有游泳池、室内篮球场、健身房等健康设施,以及沿街的社区商业,如超市、洗衣店、影音店和中小型餐饮,提供便利的生活服务。教育方面,项目合作的红黄蓝幼儿园是中国儿童教育的知名品牌,...