IM聊实现客户端之间信息交互需求文档
需求分析说明书 |
HuaXinIM聊软件 |
潘浩 |
2016/5/6 |
一、引言
1.编写目的
HuaXinIM聊软件是基于TCP/IP协议和XMPP协议实现的一款聊天软件,主要基于华信内部教学大型通信项目学习,帮助学生更好的理解Socket编程、设计模式、数据库编程、和JavaAPI使用。
2.背景
随着互联网的兴起,聊天交流的方式变得多样化,当今许多企业开发满足自己需求的网络通讯工具,方便部门与部门,员工与员工,员工与领导之间的工作交流,华信科技为了巩固学员的知识和技术架构,设计了此软件,并提供学员小组开发练习。
3.参考资料
二、项目概述
1.项目目标
本项目立足于市场上比价火热的即时聊天软件QQ为原型,设计了一条自己的聊天软件模式,并提供了很大的发散空间,可以让学员添加更多的个性设计。
2.用户特点
本项目主要用于内部学习使用。
3.设计和实现的约束和限制
3.1.开发环境
该系统拟采用C/S结构,前台采用Java的Swing技术,后台采用Java的Socket技术和JDBC技术,并结合mysql数据库做数据存储。
3.2.运行环境
中文WINXP、WIN7、WIN8,1G以上内存,服务端需要运行mysql数据库。
3.3.条件和限制
由于当前项目仅仅只是用于内部学习和讨论研究,不涉及任何商业性质,所以开发者只需要严格按照项目需求的说明实现即可。
4.软件实现原则
根据软件工程规范和当前网站的要求和特点,系统开发得遵循以下原则.
实用性原则:开发的系统必须满足实用性的需求,做到实用方便、输入数据尽量小、界面直观、易学易用,不同业务之间界面转换速度快。
功能完整性原则:所提出的业务能够在计算机平台上完成,对于同一类型的业务,由于输入要求或地址模式等条件的不同,将设计不同的功能模块。
高性能原则:系统在性能上做到数据容量小、响应速度快、稳定性高、出错率低、容错性能好等优点。
数据安全性原则:安全性永远是数据处理的重要课题,必须采取多种措施保证数据库的安全。
美观化设计原则:在满足实用性的条件下,界面设计做到美观大方、大小适中、排列整齐、各种控制键的中文名字简单明了、不同业务甚至不同功能,有不同的界面。美观的界面配色柔和,减轻视觉疲劳,给用户一个良好的计算机工作环境,并不失政府威严。
统一性原则:建立同一合理的数据库模型,实行统一的文档编排和管理;实行统一的数据库关系名、后台文件名、函数名、变量名等;实行统一的编码风格。
系统的可扩展性原则:在满足当前开发学习的基础上,考虑今后系统需要新加功能,为系统的扩充预留接口。
三、具体需求
1.功能需求
系统功能分为:登陆注册、在线用户列表、聊天功能、表情发送、历史消息、文件发送、远程协助等功能。
结构图如下:
2.具体需求
2.1.
登陆注册
处理登陆流程
用例ID |
1 |
用例名称 |
用户登陆 |
创建者 |
小张 |
创建日期 |
2016-5-5 |
最后更新者 |
最后更新日期 |
||
主执行者 |
所有已经存在账户的客户 |
||
功能描述 |
软件登陆 |
||
前置条件 |
存在注册账号 |
||
业务规则 |
1.用户名必须正确 2.密码必须正确 3.可以用手机号、账号、邮箱登陆 4.提供IP和端口号的修改 |
||
其他需求 |
界面图片 |
||
流程图 |
处理注册流程
用例ID |
2 |
用例名称 |
用户注册 |
创建者 |
小张 |
创建日期 |
2016-5-5 |
最后更新者 |
最后更新日期 |
||
主执行者 |
所有需要执行注册的角色 |
||
功能描述 |
提供账号注册,为后续登陆提供前提 |
||
前置条件 |
无 |
||
业务规则 |
1.用户名2-10位的数字或者字符 2.用户名、密码、手机号、邮箱、性别不能为空 3.手机号码必须为11位的纯数字 4.邮箱格式***@***.com |
||
其他需求 |
界面图片 |
||
流程图 |
2.2.
好友列表
用例ID |
3 |
用例名称 |
好友列表 |
创建者 |
小张 |
创建日期 |
2016-5-5 |
最后更新者 |
最后更新日期 |
||
主执行者 |
登陆成功用户 |
||
功能描述 |
1.展示当前所有在线的用户 2.上线下线消息提示 |
||
前置条件 |
用户登录成功后进入的界面 |
||
业务规则 |
展示所有在线的用户,不在线的用户直接不展示 展示个人信息:用户名 好友信息:好友姓名、好友性别 |
||
其他需求 |
界面图片 |
||
流程图 |
2.3.
聊天功能
用例ID |
4 |
用例名称 |
聊天功能 |
创建者 |
小张 |
创建日期 |
2016-5-5 |
最后更新者 |
最后更新日期 |
||
主执行者 |
登陆成功用户 |
||
功能描述 |
1.聊天界面 2.发送消息、文件、表情、远程协助、历史消息 |
||
前置条件 |
用户登录成功后进入的好友界面,并选择指定好友 |
||
业务规则 |
选择界面指定功能,执行相应操作 |
||
其他需求 |
界面图片 |
||
流程图 |
2.3.1
聊天消息
用例ID |
5 |
用例名称 |
发送聊天消息 |
创建者 |
小张 |
创建日期 |
2016-5-5 |
最后更新者 |
最后更新日期 |
||
主执行者 |
登陆成功用户 |
||
功能描述 |
1.在输入框输入聊天内容,并点击发送,会发送消息出去 2.接收消息框,显示接收到的消息内容(包括好友的和自己的消息) |
||
前置条件 |
用户登录成功后进入的好友界面,并选择指定好友进入聊天界面 |
||
业务规则 |
接收消息显示框必须显示内容:用户名、接收日期、接收时间 |
||
其他需求 |
界面图片 |
||
流程图 |
2.3.2.
表情发送
用例ID |
6 |
用例名称 |
发送聊天消息 |
创建者 |
小张 |
创建日期 |
2016-5-5 |
最后更新者 |
最后更新日期 |
||
主执行者 |
登陆成功用户 |
||
功能描述 |
可以在发送窗口选择表情,并点击发送,接收端可以接收到消息 |
||
前置条件 |
用户登录成功后进入的好友界面,并选择指定好友进入聊天界面 |
||
业务规则 |
图片正常显示 |
||
其他需求 |
界面图片 |
||
流程图 |
2.3.3.
文件发送
用例ID |
7 |
用例名称 |
发送聊天消息 |
创建者 |
小张 |
创建日期 |
2016-5-5 |
最后更新者 |
最后更新日期 |
||
主执行者 |
登陆成功用户 |
||
功能描述 |
可以在发送窗口选择表情,并点击发送,接收端可以接收到消息 |
||
前置条件 |
用户登录成功后进入的好友界面,并选择指定好友进入聊天界面 |
||
业务规则 |
发送图片,对方会收到是否接收文件的请求,如果确认接收,则开始传输文件,否则,取消发送 |
||
其他需求 |
界面图片 |
||
流程图 |
2.3.4.
远程协助
用例ID |
8 |
用例名称 |
发送聊天消息 |
创建者 |
小张 |
创建日期 |
2016-5-5 |
最后更新者 |
最后更新日期 |
||
主执行者 |
登陆成功用户 |
||
功能描述 |
可以在发送窗口选择表情,并点击发送,接收端可以接收到消息 |
||
前置条件 |
用户登录成功后进入的好友界面,并选择指定好友进入聊天界面 |
||
业务规则 |
图片正常显示 |
||
其他需求 |
界面图片 |
||
流程图 |
2.3.5
历史消息
用例ID |
9 |
用例名称 |
发送聊天消息 |
创建者 |
小张 |
创建日期 |
2016-5-5 |
最后更新者 |
最后更新日期 |
||
主执行者 |
登陆成功用户 |
||
功能描述 |
可以在发送窗口选择表情,并点击发送,接收端可以接收到消息 |
||
前置条件 |
用户登录成功后进入的好友界面,并选择指定好友进入聊天界面 |
||
业务规则 |
图片正常显示 |
||
其他需求 |
界面图片 |
||
流程图 |
四、其它需求
1.外部接口需求
1.1.用户界面
对于网站,我们强调友好的人机交互界面的同时保证平台的严肃性,尽可能给用户提供简洁的流程操作和完善的功能。
1.2.软件接口
l Mysql数据库
l 操作系统:WinXP/Win7/Win8/Win10
2.性能需求
本系统在性能上尽量做到实时性强、数据容量小、响应速度快、稳定性高、出错率低、容错性好等优点。
2.1.灵活性
2.2.数据管理能力的需求
就目前来看,该软件数据量相对单一,后台数据处理相对教简单。
3.质量要求
3.1.安全性
在本系统的设置中,主要从一下几个方面考虑系统和数据的安全性:
满足速度要求下的少量原则:余量指的是逻辑上相同的数据,在不同的记录中重复出现,或在逻辑上能导出存在于数据库的记录中。从理论上讲,余量的存在,在数据库设计的不合理,是破坏数据库一致性的潜在危险,同时会增加数据空间开销。但是,在特殊情况下,为了满足速度要求,常常设计一些余量作为数据库的记录。当余量存在时,数据库一致性不能靠数据库管理系统来保证,只能通过开发软件的计算方法来解决,余量的存在,大大增加了系统的开发难度,所以余量是万不得已才能使用,使用时,在计算方法保证数据的一致性。
3.2.可维护性
3.3.可靠性
IM聊实现客户端之间信息交互需求文档的更多相关文章
- 如何写出好的PRD(产品需求文档)(转)
作者:Cherry,2007年进入腾讯公司,一直从事互联网广告产品管理工作,目前在SNG/效果广告平台部从事效果广告的产品运营工作. PRD(Product Requirement Document, ...
- 产品需求文档(PRD)的写作方法之笔记一
1.写前准备(思维导图): http://www.woshipm.com/?p=80070 1.在写之前,请先很区分清楚什么是MRD文档(市场需求文档),BRD文档(商业需求文档),什么是PRD文档( ...
- [转]产品需求文档(PRD)的写作
产品需求对产品研发而言非常重要,写不好需求,后面的一切工作流程与活动都会受到影响.转载一篇文章,关于产品需求文档写作方面的,如下: 本文摘自(一个挺棒的医学方面专家):http://www.cnblo ...
- Android APP开发需求文档范本
Android APP开发需求文档范本 软件需求文档格式的标准写法 1.引言 1.1 编写目的 • 阐明开发本软件的目的: 1.2 项目背景 • 标识待开发软件产品的名称.代码: • 列出本项目的任 ...
- 产品需求文档 PRD
第一轮: 1,文档使用方:UI设计师 2.内容: 根据战略层定义出来产品功能范围, 说明此产品的目的,方便UI设计人员更好的理解产品 产品基本流程 详细 ...
- 优质产品需求文档(PRD)写作三大原则
在上一篇文章中有介绍,产品经理的两项主要职责包括:对产品机会进行评估,以及对开发的产品进行评估.而定义即将开发上线的产品,则需要借助产品需求文档,来进行产品的特征和功能描述.PRD文档的写作会因公司. ...
- 产品需求文档(PRD)的写作 【转】
产品需求文档(PRD)的写作 一.文章的摘要介绍 无论我们做什么事都讲究方式方法,写产品需求文档(以下称PRD文档)也是如此,之前我通过四篇文章分享了自己写PRD文档的一些方法,而这一篇文章主要是 ...
- app开发需求文档怎么写
我们在开发app前都会做需求分析,这个app开发需求文档怎么写呢?一般可以从这几点入手:确定APP方案的目标,APP方案的受众分析,APP开发方案功能设计,APP的操作系统说明方案,APP是是否是原生 ...
- 使用Try.NET创建可交互.NET文档
原文地址:Create Interactive .NET Documentation with Try .NET 原文作者:Maria 译文地址:https://www.cnblogs.com/lwq ...
随机推荐
- 【杂文】5亿大质数表(5e8)
[杂文]\(5\) 亿大质数表(\(5e8\)) 在写哈希,刷数论题时曾一度想要查质数,\(F**k\) 百度文库数据又少,翻页蛋疼,还不给复制,真的是服了. 于是在我闲的蛋疼的时候就搞了个质数表出来 ...
- css 实现 checkbox 大小调整
一般调整 checkbox 大小我们想到的是 width.height,可是设置后,发现是没有效的. 如微信小程序里面,checkbox 默认就很大,想设置小一点怎么办? transform: sca ...
- json和Jsonp 使用总结(1)
1.Json的使用 $.getJSON("subPreview", { jsonDatas: JSON.stringify(jsonData) }, function(data) ...
- [Usaco2011 Jan]道路和航线
Description Farmer John正在一个新的销售区域对他的牛奶销售方案进行调查.他想把牛奶送到T个城镇 (1 <= T <= 25,000),编号为1T.这些城镇之间通过R条 ...
- mutiset HDOJ 5349 MZL's simple problem
题目传送门 /* 这题可以用stl的mutiset容器方便求解,我对这东西不熟悉,TLE了几次,最后用读入外挂水过. 题解有O(n)的做法,还以为我是侥幸过的,后来才知道iterator it写在循环 ...
- ACM_Appleman and Card Game(简单贪心)
Appleman and Card Game Time Limit: 2000/1000ms (Java/Others) Problem Description: Appleman has n car ...
- 锚点、target="page1"、浮标回到顶部(该点未实现,能力不足)
<html> <head> <meta charset="utf-8"> <title>链接</title> <! ...
- 10046 trace and sql
1. SQLT 下载 从metalink上下载SQLT工具,参考文档 (以下大部分(SQL可以在sqlt\utl 目录下找到)) 1.1 SQLT 安装 SQLT安装在自己的schema SQLT ...
- 406 Queue Reconstruction by Height 根据身高重建队列
假设有打乱顺序的一群人站成一个队列. 每个人由一个整数对(h, k)表示,其中h是这个人的身高,k是排在这个人前面且身高大于或等于h的人数. 编写一个算法来重建这个队列.注意:总人数少于1100人.示 ...
- EasyUI系列学习(六)-Tooltip(提示框)
一.创建组件 0.Tooltip不依赖其他组件 1.使用class加载 <a href="#" class="easyui-tooltip" title= ...