【原】RSS工具开发手记(01)---Kick off
经过一个月充实的调整后(徒步自助游、摄影、打羽毛球,真怀念啊~~)。终于接到新的开发任务---开发一个可以解析、阅读RSS的工具。该工具需要运行在PC和手机端,换句话来说也就是要支持不同的终端版本。
对于开发人员来说,没有什么比挑战自己的能力更能让人兴奋地了!在接到开发任务并且和客户进行前期沟通后,对项目的需求有了一个基本的了解:
◆RSS阅读器运行在PC终端还包括C/S和B/S形式
◆RSS阅读器必须支持实时提醒(就像QQ的消息提醒那样)
◆RSS阅读器必须支持搜索功能(即关键字的全文搜索,二次过滤)
◆RSS阅读器必须支持排序功能(即自动排序和手动拖拽排序)
◆RSS阅读器必须支持目录功能(即把相关的RSS频道组织在同一个目录下)
◆RSS阅读器必须支持0.9x,1.0,2.0的协议
◆RSS阅读器必须支持基于内存和关系的数据库持久方式
◆RSS阅读器必须支持OMPL的导入和导出功能
◆RSS阅读器可选支持对文章的收藏功能
需求虽说不多,但每一个都不是省油的灯。包括了RSS解析引擎和阅读器,仔细分析了一下这些需求,发现重难点和技术点集中在下面几个:
◆软件必须适应不同的终端,不同的访问方式,不同版本的协议。对设计通用性要求较高
◆软件必须解析和生成XML,涉及到大量的字符串和格式处理。对XML和性能要求较高
◆软件必须具备实时监控功能,且具备主动推送功能,对多线程和异步通讯要求较高
◆软件必须支持不同的持久化方式,对缓存和持久化要求较高
◆软件必须支持基于全文的搜索,对搜索技术有一定要求
◆软件界面必须是支持拖拽功能的,对GUI和Ajax有一定要求
基于上面的分析结果,首先制定开发计划,划分阶段任务:
Phase 1: Prototype构建
此阶段的主要任务是过滤需求中最基本最核心的部分---RSS feed的解析和生成。没有了对RSS的解析和生成一切都是空谈,细化下来则包括了:
◆读入既有RSS文件和解析
◆构建新的RSS文件和保存
Phase 2: 阶段更新和提醒功能
此阶段的主要任务是在Phase 1的基础上fix bug,增加了后台对RSS消息源的阶段检查、更新及提醒功能。细化下来则包括了:
◆修正Phase 1的bug
◆定期检查RSS消息源是否有更新
◆同步更新RSS feed文件
◆提醒RSS订阅客户
Phase 3: 全文搜索和二次过滤功能
此阶段的主要任务是在Phase 2的基础上fix bug,增加了对RSS工具获取到的news进行二次过滤。细化下来则包括了:
◆对订阅结果进行二次过滤(即在RSS自动获取的内容基础上进行过滤)
◆对订阅结果进行全文搜索(即在RSS自动获取的内容基础上进行关键字搜索)
Phase 4: 持久化功能
此阶段的主要任务是在Phase 3的基础上fix bug,增加了对内存数据库和传统数据库的持久化支持。细化下来则包括了:
◆支持使用hsqldb进行内存数据库的读取和存储
◆支持使用Hibernate进行传统数据库的读取和存储
Phase 5: 导入导出和收藏功能
此阶段的主要任务是在Phase 4的基础上fix bug,增加了OMPL的导入导出功能。细化下来则包括了:
◆导入其他OMPL文件到阅读器
◆导出阅读器的订阅列表为OMPL文件(支持不同的协议和版本)
◆喜爱文章的收藏功能
Phase 6: PC B/S版的阅读器开发
此阶段的主要任务是在Phase 5的基础上fix bug,开始进行基于浏览器的阅读器开发。细化下来则包括了:
◆阅读器工具栏(包括OMPL导入导出工具,偏好设置工具,及其他工具)
◆阅读器订阅列表(支持自动排序和手动拖拽排序,支持目录管理)
◆阅读器新闻列表(显示RSS最新更新的新闻的标题)
◆阅读器内容窗口(显示选中新闻的内容)
◆阅读器搜索窗口(显示搜索框,搜索结果将分别在新闻列表和内容窗口显示)
◆阅读器收藏窗口(显示用户收藏的通过RSS阅读器获取的文章)
◆阅读器和解析引擎的通讯
目前初步的计划就是开发出B/S版的RSS阅读工具,毕竟B/S是以后发展的主流。基于C/S模式的软件也许在实时提醒上实现起来比B/S要相对简单一点(因为浏览器是典型的“拉”方式获取数据,必须用户主动地刷新页面去更新数据),但是自从Ajax技术出现后这已经不是问题了。
先从最熟悉的J2EE Web开发开始。Come on ! Kick off~~
-------------------------------------------------------------
生活就像打牌,不是要抓一手好牌,而是要尽力打好一手烂牌。