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 ...
随机推荐
- 清北考前刷题day2下午好
#include<iostream> #include<cstdio> #include<cstring> #include<stack> #defin ...
- 【题解】PIE [POI2015] [P3585]
[题解]\(PIE\) \([POI2015]\) \([P3585]\) 逼自己每天一道模拟题 传送门:\(PIE\) \([POI2015]\) \([P3585]\) [题目描述] 一张 \(n ...
- MongoDB的用户权限管理
1.创建用户并授权语法:db.createUser({user:"UserName",pwd:"Password",roles:[{role:"Rol ...
- [C++ STL] vector使用详解
一.vector介绍: vector(向量): 是一种序列式容器,事实上和数组差不多,但它比数组更优越.一般来说数组不能动态拓展,因此在程序运行的时候不是浪费内存,就是造成越界.而vector正好弥补 ...
- 基本的查询流【MSSQL】
4个DML(Data Manipulation Language)命令 SELECT INSERT UPDATE DELETE 查询语法有一个特有的固定顺序 SELECT - FROM - WHERE ...
- [ USACO 2001 OPEN ] 地震
\(\\\) Description 给出一张 \(n\) 个点 \(m\) 条边的无向图,现在要建一棵生成树. 每条边都有消耗的时间 \(t_i\),也有建造的代价 \(w_i\) . 最后总金给 ...
- vs2012 jsoncpp 链接错误
解决: 项目->属性->C/C++->代码生成->运行库->设置与使用的.lib的版本一致.
- Angular JS (2)
通过Angular JS的官方教学文档,了解 routeProvider 的用法, angular.module('aaa').config(['$locationProvider','$routeP ...
- PHP7中session_start 使用注意事项,会导致浏览器刷时页面数据不更新
//PHP7中session_start 使用注意事项, session_start([ 'cache_limiter' => 'private', //在读取完毕会话数据之后马上关闭会话存储文 ...
- ARX亮显问题
转载一段acedSSSetFirst的用法仅供参考:打个比方,我创建了一个命令,这个命令的功能是提示用户选择,然后只过滤文本对象作为选择集,随后在屏幕上使得这个选择集的所有成员都亮显,并且能够显示出各 ...