软件接口规范.docx
- 文档编号:18945481
- 上传时间:2024-05-31
- 格式:DOCX
- 页数:8
- 大小:26.78KB
软件接口规范.docx
《软件接口规范.docx》由会员分享,可在线阅读,更多相关《软件接口规范.docx(8页珍藏版)》请在冰点文库上搜索。
软件接口规范
一、基本要求
为了保证软件系统的完整性和健壮性,系统接口应满足下列基本要求:
1、软件接口应实现对外部系统的接入提供企业级的支持,在系统的高并发和大容量的基础上提供安全可靠的接入;
2、提供完善的信息安全机制,以实现对信息的全面保护,保证系统的正常运行,应防止大量访问,以及大量占用资源的情况发生,保证系统的健壮性;
3、提供有效的系统的可监控机制,使得软件接口的运行情况可监控,便于及时发现错误及排除故障;
4、保证在充分利用系统资源的前提下,实现系统平滑的移植和扩展,同时在系统并发增加时提供系统资源的动态扩展,以保证系统的稳定性;
5、在进行扩容、新业务扩展时,软件接口应能提供快速、方便和准确的实现方式。
二、接口通讯方式
软件接口基本采用同步请求/应答方式、异步请求/应答方式、会话方式、广播通知方式、事件订阅方式、可靠消息传输方式、文件传输方式等:
1、同步请求/应答方式:
客户端向服务器端发送服务请求,客户端阻塞等待服务器端返回处理结果;
2、异步请求/应答方式:
客户端向服务器端发送服务请求,与同步方式不同的是,在此方式下,服务器端处理请求时,客户端继续运行;当服务器端处理结束时返回处理结果;
3、会话方式:
客户端与服务器端建立连接后,可以多次发送或接收数据,同时存储信息的上下文关系;
4、广播通知方式:
由服务器端主动向客户端以单个或批量方式发出未经客户端请求的广播或通知消息,客户端可在适当的时候检查是否收到消息并定义收到消息后所采取的动作;
5、事件订阅方式:
客户端可事先向服务器端订阅自定义的事件,当这些事件发生时,服务器端通知客户端事件发生,客户端可采取相应处理。
事件订阅方式使客户端拥有了个性化的事件触发功能,能极大方便客户端及时响应所订阅的事件;
6、文件传输方式:
客户端和服务器端通过文件的方式来传输消息,并采取相应处理;
7、可靠消息传输:
在软件接口通讯中,基于消息的传输处理方式,除了可采用以上几种通讯方式外,还可采用可靠消息传输方式,即通过存储队列方式,客户端和服务器端来传输消息,采取相应处理。
三、接口安全要求
为了保证软件系统的安全运行,各种接口方式都应该保证其接入的安全性。
软件接口安全是系统安全的一个重要组成部分。
保证软件接口的自身安全,通过接口实现技术上的安全控制,做到对安全事件的“可知、可控、可预测”,是实现系统安全的一个重要基础。
根据软件接口连接特点与业务特色,制定专门的安全技术实施策略,保证接口的数据传输和数据处理的安全性。
系统应在接入点的网络边界实施软件接口的安全控制。
软件接口的安全控制在逻辑上包括:
安全评估、访问控制、入侵检测、口令认证、安全审计、防恶意代码、加密解密等内容。
四、传输控制要求
传输控制利用高速数据通道技术实现把前端的大数据量并发请求分发到后端,从而保证应用系统在大量客户端同时请求服务时,能够保持快速、稳定的工作状态。
系统应采用传输控制手段降低软件接口网络负担,提高软件接口吞吐能力,保证系统的整体处理能力。
具体手段包括负载均衡、伸缩性与动态配置管理、网络调度等功能:
1、负载均衡:
为了确保软件接口服务吞吐量最大,软件接口应自动地在系统中完成动态负载均衡调度;
2、伸缩性与动态配置管理:
由系统自动伸缩管理方式或动态配置管理方式实现队列管理、存取资源管理,以及接口应用的恢复处理等;
3、网络调度:
在双方接口之间设置多个网络通道,实现软件接口的多数据通道和容错性,保证当有一网络通道通讯失败时,进行自动的切换,实现软件接口连接的自动恢复。
五、接口测试要求
软件接口的测试是测试系统组件间接口的一种测试。
软件接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点。
测试的重点是要检查数据的交换,传递和控制管理过程,以及系统间的相互逻辑依赖关系等。
软件接口测试共分为如下三类:
1、系统与系统之间的调用;
2、上层服务对下层服务的调用;
3、同层服务之间的调用。
不同类型的接口测试方法可能不一致,但总体来说,不管是哪种类型,被测接口即为服务方,测试手段为客户方,接口测试的目的就是:
通过测试手段,去验证软件接口满足其声明提供的功能。
软件接口测试是一个完整的体系,包括功能测试,性能测试等。
六、常用接口技术
1、J2EE/EJB
n技术描述
EnterpriseJavaBean(EJB)是可重用的、可移植的J2EE组件。
EJB包括三种主要类型:
会话bean、实体bean和消息驱动的bean。
会话bean执行独立的、解除耦合的任务,譬如检查客户的信用记录。
实体bean是一个复杂的业务实体,它代表数据库中存在的业务对象。
消息驱动的bean用于接收异步JMS消息。
EJB由封装业务逻辑的方法组成,众多远程和本地客户端可以调用这些方法。
另外,EJB在容器里运行,这样开发人员只要关注bean里面的业务逻辑,不必担心复杂、容易出错的问题,譬如事务支持、安全性和远程对象访问、高速缓存和并发等。
在EJB规范中,这些特性和功能由EJB容器负责实现。
容器和服务提供者实现了EJB的基础构造,这些基础构造处理了EJB的分布式、事务管理、安全性等内容。
EJB规范定义了基础构造和JavaAPI的为了适应各种情况的要求,而没有指定具体实现的技术、平台、协议。
EJB的上层的分布式应用程序是基于对象组件模型的,低层的事务服务用了API技术。
EJB技术简化了用JAVA语言编写的企业应用系统的开发、配置和执行。
n技术特点
优点:
基于规范的平台,不受限于特定的操作系统或硬件平台;基于组件体系结构,简化了复杂组件的开发;提供对事务安全性以及持续性的支持;支持多种中间件技术。
缺点:
与特定于某个操作系统或平台的实现技术相比,性能还有待进一步提高,且资源占用量较大。
2、WebService
n技术描述
WebService是一种自包含、模块化的应用,是基于网络的、分布式的模块化组件,它执行特定的任务,遵守具体的技术规范,这些规范使WebService能与其它兼容的组件进行互操作。
可以在网络上(一般是Internet)上被描述、发布、定位和调用。
WebService体系主要由以下三部分组成:
传输协议、服务描述和服务发现,由一系列标准组成,主要有:
XML(可扩展的标记语言)、SOAP(简单对象访问协议)等。
n技术特点
WebService使用标准技术,应用程序资源在各网络上均可用。
因为WebService基于HTTP、XML和SOAP等标准协议,所以即使以不同的语言编写并且在不同的操作系统上运行,它们也可以进行通信。
因此,WebService适用于网络上不同系统的分布式应用。
优点:
适用于网络上不同系统的分布式应用、标准性好、扩展性好、耦合度低;内容由标准文本组成,任何平台和程序语言都可以使用;格式的转换基本不受限制,可以满足不同应用系统的需求。
缺点:
当XML内容较大时,解释程序的执行效率较低,一般不适合用于实现大批量数据交互的接口。
3、交易中间件
n技术描述
交易中间件是专门针对联机交易处理系统而设计的。
联机交易处理系统需要处理大量并发进程,涉及到操作系统、文件系统、编程语言、数据通讯、数据库系统、系统管理、应用软件等多个环节,采用交易中间件技术可以简化操作。
交易中间件是一组程序模块,用以减少开发联机交易处理系统所需的编程量。
X/OPEN组织专门定义了分布式交易处理的标准及参考模型,把一个联机交易系统划分成资源管理(RM)、交易管理(TM)和应用(AP)三部分,并定义了应用程序、交易管理器、多个资源管理器是如何协同工作的。
资源管理器是指数据库和文件系统,交易管理器可归入交易中间件。
n技术特点
优点:
开放的体系结构,满足大用户量与实时性的要求,提供交易的完整性、控制并发、交易路由和均衡负载的管理。
缺点:
处理大数据量交易效率不高。
4、消息中间件
n技术描述
基于消息中间件的接口机制主要通过消息传递来完成系统之间的协作和通信。
通过消息中间件把应用扩展到不同的操作系统和不同的网络环境。
通过使用可靠的消息队列,提供支持消息传递所需的目录、安全和管理服务。
当一个事件发生时,消息中间件通知服务方应该进行何种操作。
其核心安装在需要进行消息传递的系统上,在它们之间建立逻辑通道,由消息中间件实现消息发送。
消息中间件可以支持同步方式和异步方式,实际上是一种点到点的机制,因而可以很好的适用于面向对象的编程方式。
消息中间件可以保证消息包传输过程的正确、可靠和及时。
消息中间件提供以下基本功能:
消息队列、触发器、信息传递、数据格式翻译、安全性控制、数据广播、错误恢复、资源定位、消息及请求的优先级设定、扩展的调试功能等。
n技术特点
消息中间件能够在任何时刻将消息进行传送或者存储转发,不会占用大量的网络带宽,可以跟踪事务,并且通过将事务存储到磁盘上实现网络故障时系统的恢复。
优点:
为不同的应用系统提供了跨多平台的消息传输;除支持同步传输模式外,还支持异步传输,有助于在应用间可靠地进行消息传输。
缺点:
与其它中间件技术一样,存在高流量的性能瓶颈问题。
5、SOCKET
n技术描述
Socket(套接字)用于描述IP地址和端口。
应用程序通过Socket向网络发出请求或应答网络请求。
Socket使用客户/服务器模式,服务端有一个进程(或多个进程)在指定的端口等待客户来连接,服务程序等待客户的连接信息,一旦连接上之后,就可以按设计的数据交换方法和格式进行数据传输。
客户端在需要的时刻发出向服务端的连接请求,然后发送服务申请消息包,服务端向客户端返回业务接口服务处理结果消息包。
n技术特点
此类接口不需要其它软件支持,只要软件接口双方做好相关约定(包括IP地址、端口号、包的格式)即可。
包的格式没有统一标准,可以随意定义。
优点:
实现简单、性能高。
缺点:
标准性差、扩展性差。
6、CORBA
n技术描述
CORBA即公共对象请求代理体系结构,是一个具有互操作性和可移植性的分布式面向对象的应用标准。
CORBA标准主要分为3个层次:
对象请求代理、公共对象服务和公共设施。
最底层是ORB(对象请求代理),规定了分布对象的定义(接口)和语言映射,实现对象间的通讯和互操作,是分布对象系统中的“软总线”;在ORB之上定义了很多公共服务,可以提供诸如并发服务、名字服务、事务(交易)服务、安全服务等各种各样的服务,同时ORB也负责寻找适于完成这一工作的对象,并在服务器对象完成后返回结果;最上层的公共设施则定义了组件框架,提供可直接为业务对象使用的服务,规定业务对象有效协作所需的协定规则。
客户将需要完成的工作交给ORB,由ORB决定由哪一个对象实例完成这个请求,然后激活这个对象,将完成请求所需要的参数传送给这个激活的对象。
除了客户传送参数的接口外,客户不需要了解其它任何信息,不必关心服务器对象的与服务无关的接口信息,这就大大简化了客户程序的工作。
ORB需要提供在不同机器间应用程序间的通信,数据转换,并提供多对象系统的无缝连接。
n技术特点
CORBA具有模型完整,独立于系统平台和开发语言,被支持程度广泛的特点。
优点:
以一种中间件的方式为不同编程语言提供协同工作的可能;对操作系统没有特殊的要求和依赖;与主流的体系架构(如J2EE)关系密切。
当需要集成的两个企业应用软件互为异构,由不同的编程语言实现时(如Java与C++),CORBA可以实现两种语言的协同工作。
缺点:
庞大而复杂,并且技术和标准的更新相对较慢;性能与具体业务实现有关。
7、文件
n技术描述
文件接口定义了服务端与客户端文件存放路径、文件名命名规则和文件格式,并开放相应的读/写操作权限。
文件接口的通讯过程包括三种:
a)同一主机内可以共享一个路径;
b)服务器端向客户端开放路径,客户端定时查看此路径下是否有新的文件,可以采用FTP等方式取走服务端开放的路径下的文件;
c)客户端向服务器端开放路径,由服务端将文件写入,客户端定时查看此路径下是否有新的文件。
网络传输方式应支持对通信机的IP地址、帐户、口令、存取目录的验证。
文件的传输应支持:
a)实时、高效和安全可靠地传送批量数据;
b)断点续传功能;
c)数据压缩传输;
d)传输过程中的差错控制。
n技术特点
优点:
文件接口不需要其它软件支持,只要接口双方约定好路径、格式、处理方式即可,实现简单、传输批量数据效率较高。
缺点:
格式没有统一标准,标准性差;需要开放文件系统权限,安全性差。
8、过程调用和共享数据表
n技术描述
过程调用和共享数据表技术实现了服务端向客户端开放可直接调用的过程和可直接进行读写操作的共享数据表,客户端直接调用服务端过程和对共享数据表进行读写操作。
接口支持各种数据库连接方式,如Login、DBLink等。
接口的通讯过程包括两种:
a)客户端直接调用服务端开放的过程或对服务端开放的共享数据表进行增、删、改和查询操作,完成业务处理;
b)客户端向开放的共享数据表中写入服务请求数据,服务端定时扫描共享数据表并作出响应,根据服务请求数据中的接口服务类型代码,进行不同的业务逻辑处理,然后向共享数据表中写入处理结果数据;客户端定时扫描共享数据表,根据处理结果数据并作出响应,进行业务后续处理。
n技术特点
此类接口不需要其它软件支持,只要接口双方做好相关约定即可;但接口没有统一标准,而且需要开放数据库权限,安全性差。
优点:
实现简单、传输批量数据效率较高。
缺点:
标准性差、适用场合有限、安全性差。
8
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件 接口 规范