CN106371934A - 一种基于windows文件系统驱动的第三方存储协议文件访问系统和访问方法 - Google Patents
一种基于windows文件系统驱动的第三方存储协议文件访问系统和访问方法 Download PDFInfo
- Publication number
- CN106371934A CN106371934A CN201610721408.7A CN201610721408A CN106371934A CN 106371934 A CN106371934 A CN 106371934A CN 201610721408 A CN201610721408 A CN 201610721408A CN 106371934 A CN106371934 A CN 106371934A
- Authority
- CN
- China
- Prior art keywords
- file
- layer
- application
- windows
- request
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Communication Control (AREA)
Abstract
本发明公开了一种基于windows文件系统驱动的第三方存储协议文件访问系统和访问方法,系统包括应用层部署应用层程序,支持部署各种不同存储协议的应用程序,用户通过应用层发起对文件操作的请求;驱动层提供windows API,根据应用层的请求I/O管理器调用相应的接口生成对应文件操作的IO请求包IRP,直至IRP返回相应结果;应用服务层提供多种协议的封装接口,以及提供windows文件路径与其他协议路径的转换规则,应用层服务将收到的请求转化成对应应用的存储协议的请求并调用相应的接口,文件操作请求执行完成后将结果反馈给驱动层。本发明能够在windows文件系统驱动上封装多种第三方存储协议,使得电视台业务系统可以实现多种协议的使用而无需更改所有应用的IO模块,提高了系统的可用性。
Description
技术领域
本发明涉及数据存储访问领域,特别是一种基于windows文件系统驱动的第三方存储协议文件访问系统和访问方法。
背景技术
IRP(I/O Request Packet)是由I/O管理器发出的,I/O管理器是用户态与内核态之间的桥梁,当用户态进程发出I/O请求时,I/O管理器就捕获这些请求,将其转换为IRP请求,发送给驱动程序。I/O管理器负责所有I/O请求的调度和管理工作,根据请求的不同内容,选择相应的驱动程序对象,设备对象,并生成、发送、释放各种不同的IRP。
传统的电视台业务数据多存储在本地系统中,通常采用Windows的标准接口对文件进行操作。但是随着融媒体的逐步发展,电视台的业务系统也逐渐扩张变得复杂,通常需要对通过互联网、云平台、异地系统等对文件进行操作,这时一个系统中便包含了多种协议的请求,如FTP、S3、HTTP等。
传统的windows应用都是通用windows API访问文件系统的,I/O管理器根据请求的不同类型选择相应的接口生成不同文件操作的IRP。如果要访问S3或者FTP,就意味着需要重新修改所有的IO模块,因为各个协议对文件的操作均有一套不同的API,而且各种协议对文件的访问方式也各不相同,例如:windows有文件系统,需要通过文件系统访问文件;S3不具有文件系统,S3的存储容器是Bucket,相当于windows的文件夹,但不允许嵌套;而FTP对文件的访问则是通过IP地址……因此,要更改文件的访问方式,必须重新修改所有应用的IO模块。当系统中的应用很少时,这种方式还可以接受;但当应用数目增大到一定数目时,这种方式的工程量将变得非常大,很不方便。
发明内容
本发明的目的在于克服现有技术的不足,提供一种基于windows文件系统驱动的第三方存储协议文件访问系统和访问方法能够在windows文件系统驱动上封装多种第三方存储协议,使得电视台业务系统可以实现多种协议的使用而无需更改所有应用的IO模块。
本发明的目的是通过以下技术方案来实现的:一种基于windows文件系统驱动的第三方存储协议文件访问系统,它包括应用层、驱动层和应用层服务,所述的应用层部署应用层程序,支持部署各种不同存储协议的应用程序,用户通过应用层发起对文件操作的请求;所述的驱动层提供windows API,根据应用层的请求I/O管理器调用相应的接口生成对应文件操作的IO请求包IRP,直至IRP返回相应结果;所述的应用服务层提供多种协议的封装接口,以及提供windows文件路径与其他协议路径的转换规则,应用层服务将收到的请求转化成对应应用的存储协议的请求并调用相应的接口,文件操作请求执行完成后将结果反馈给驱动层。
所述的IRP包含文件操作类型、文件路径。
所述的协议包括FTP、S3、FTTP。
一种基于windows文件系统驱动的第三方存储协议文件访问系统的访问方法,它包括如下步骤:
1)用户通过应用层的应用发起文件操作的请求;
2)驱动层根据用户请求调用对应文件操作的windows接口生成文件操作IRP并将操作请求发送给应用层服务;
3)应用层服务依据IRP类型确定文件操作类型,并根据应用的协议以及文件路径将windows路径转化为对应协议的文件路径;
4)应用层服务执行用户的文件操作请求,并将执行结果发送给驱动层;
5)驱动层收到执行结果后完成文件操作的IRP响应并将结果反馈给应用层;
6)应用层将操作结果反馈给用户。
所述的IRP中的文件路径为windows路径。
本发明的有益效果是:本发明提供了一种基于windows文件系统驱动的第三方存储协议文件访问系统和访问方法,能够在windows文件系统驱动上封装多种第三方存储协议,对于用户的请求在驱动层仍然基于windows 的API,而当应用使用的存储协议是S3、FTP等其他协议时,驱动层将请求发送给应用层服务,在应用层服务调用相应的封装好的存储协议的接口以完成用户请求的文件操作,使得电视台业务系统可以实现多种协议的使用而无需更改所有应用的IO模块,提高了系统的可用性。
附图说明
图1为访问系统结构图;
图2为访问方法流程图。
具体实施方式
下面结合附图进一步详细描述本发明的技术方案,但本发明的保护范围不局限于以下所述。
如图1所示,一种基于windows文件系统驱动的第三方存储协议文件访问系统,它包括应用层、驱动层和应用层服务,所述的应用层部署应用层程序,支持部署各种不同存储协议的应用程序,用户通过应用层发起对文件操作的请求;所述的驱动层提供windowsAPI,根据应用层的请求I/O管理器调用相应的接口生成对应文件操作的IO请求包IRP,直至IRP返回相应结果;所述的应用服务层提供多种协议的封装接口,以及提供windows文件路径与其他协议路径的转换规则,应用层服务将收到的请求转化成对应应用的存储协议的请求并调用相应的接口,文件操作请求执行完成后将结果反馈给驱动层。
所述的IRP包含文件操作类型、文件路径。
所述的协议包含但不限于FTP、S3、FTTP,将第三方协议封装放在应用层服务中,提供相应的接口,是可扩展的。
如图2所示,一种基于windows文件系统驱动的第三方存储协议文件访问系统的访问方法,它包括如下步骤:
1)用户通过应用层的应用发起文件操作的请求;
2)驱动层根据用户请求调用对应文件操作的windows接口生成文件操作IRP并将操作请求发送给应用层服务;
3)应用层服务依据IRP类型确定文件操作类型,并根据应用的协议以及文件路径将windows路径转化为对应协议的文件路径;
4)应用层服务执行用户的文件操作请求,并将执行结果发送给驱动层;
5)驱动层收到执行结果后完成文件操作的IRP响应并将结果反馈给应用层;
6)应用层将操作结果反馈给用户。
所述的IRP中的文件路径为windows路径。
本发明能够在windows文件系统驱动上封装多种第三方存储协议,对于用户的请求在驱动层仍然基于windows 的API,而当应用使用的存储协议是S3、FTP等其他协议时,驱动层将请求发送给应用层服务,在应用层服务调用相应的封装好的存储协议的接口以完成用户请求的文件操作,使得电视台业务系统可以实现多种协议的使用而无需更改所有应用的IO模块,提高了系统的可用性。
Claims (5)
1.一种基于windows文件系统驱动的第三方存储协议文件访问系统,其特征在于:它包括应用层、驱动层和应用层服务,所述的应用层部署应用层程序,支持部署各种不同存储协议的应用程序,用户通过应用层发起对文件操作的请求;所述的驱动层提供windows API,根据应用层的请求I/O管理器调用相应的接口生成对应文件操作的IO请求包IRP,直至IRP返回相应结果;所述的应用服务层提供多种协议的封装接口,以及提供windows文件路径与其他协议路径的转换规则,应用层服务将收到的请求转化成对应应用的存储协议的请求并调用相应的接口,文件操作请求执行完成后将结果反馈给驱动层。
2.根据权利要求1所述的一种基于windows文件系统驱动的第三方存储协议文件访问系统,其特征在于:所述的IRP包含文件操作类型、文件路径。
3.根据权利要求1所述的一种基于windows文件系统驱动的第三方存储协议文件访问系统,其特征在于:所述的协议包括FTP、S3、FTTP。
4.如权利要求1-3中任意一项所述的一种基于windows文件系统驱动的第三方存储协议文件访问系统的访问方法,其特征在于:它包括如下步骤:
1)用户通过应用层的应用发起文件操作的请求;
2)驱动层根据用户请求调用对应文件操作的windows接口生成文件操作IRP并将操作请求发送给应用层服务;
3)应用层服务依据IRP类型确定文件操作类型,并根据应用的协议以及文件路径将windows路径转化为对应协议的文件路径;
4)应用层服务执行用户的文件操作请求,并将执行结果发送给驱动层;
5)驱动层收到执行结果后完成文件操作的IRP响应并将结果反馈给应用层;
6)应用层将操作结果反馈给用户。
5.根据权利要求4所述的一种基于windows文件系统驱动的第三方存储协议文件访问方法,其特征在于:所述的IRP中的文件路径为windows路径。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610721408.7A CN106371934A (zh) | 2016-08-25 | 2016-08-25 | 一种基于windows文件系统驱动的第三方存储协议文件访问系统和访问方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610721408.7A CN106371934A (zh) | 2016-08-25 | 2016-08-25 | 一种基于windows文件系统驱动的第三方存储协议文件访问系统和访问方法 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN106371934A true CN106371934A (zh) | 2017-02-01 |
Family
ID=57879124
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201610721408.7A Pending CN106371934A (zh) | 2016-08-25 | 2016-08-25 | 一种基于windows文件系统驱动的第三方存储协议文件访问系统和访问方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN106371934A (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113296910A (zh) * | 2021-05-17 | 2021-08-24 | 深圳市优必选科技股份有限公司 | 文件系统的调用方法、装置、终端设备及可读存储介质 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5771379A (en) * | 1995-11-01 | 1998-06-23 | International Business Machines Corporation | File system and method for file system object customization which automatically invokes procedures in response to accessing an inode |
CN1553325A (zh) * | 2003-06-05 | 2004-12-08 | 联想(北京)有限公司 | 一种透明扩充文件系统功能的方法 |
CN1841317A (zh) * | 2005-03-31 | 2006-10-04 | 株式会社日立制作所 | 文件系统和构建及增强文件系统功能的方法 |
CN101459669A (zh) * | 2008-12-29 | 2009-06-17 | 成都市华为赛门铁克科技有限公司 | 一种网络文件系统的访问方法和装置 |
CN102065071A (zh) * | 2009-11-17 | 2011-05-18 | 北京同有飞骥科技股份有限公司 | 一种支持多传输协议的存储设备 |
CN103731489A (zh) * | 2013-12-27 | 2014-04-16 | 华为技术有限公司 | 一种数据存储方法、系统和设备 |
-
2016
- 2016-08-25 CN CN201610721408.7A patent/CN106371934A/zh active Pending
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5771379A (en) * | 1995-11-01 | 1998-06-23 | International Business Machines Corporation | File system and method for file system object customization which automatically invokes procedures in response to accessing an inode |
CN1553325A (zh) * | 2003-06-05 | 2004-12-08 | 联想(北京)有限公司 | 一种透明扩充文件系统功能的方法 |
CN1841317A (zh) * | 2005-03-31 | 2006-10-04 | 株式会社日立制作所 | 文件系统和构建及增强文件系统功能的方法 |
CN101459669A (zh) * | 2008-12-29 | 2009-06-17 | 成都市华为赛门铁克科技有限公司 | 一种网络文件系统的访问方法和装置 |
CN102065071A (zh) * | 2009-11-17 | 2011-05-18 | 北京同有飞骥科技股份有限公司 | 一种支持多传输协议的存储设备 |
CN103731489A (zh) * | 2013-12-27 | 2014-04-16 | 华为技术有限公司 | 一种数据存储方法、系统和设备 |
Non-Patent Citations (3)
Title |
---|
张尧学 等: "《计算机操作系统教程(第4版)》", 31 October 2013, 清华大学出版社 * |
王兰英 等: "基于IRP的Windows设备驱动程序文件操作的实现", 《四川理工学院学报(自然科学版)》 * |
裴灿浩: "可支持多协议盘阵的存储加密技术研究", 《中国博士学位论文全文数据库 信息科技辑》 * |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113296910A (zh) * | 2021-05-17 | 2021-08-24 | 深圳市优必选科技股份有限公司 | 文件系统的调用方法、装置、终端设备及可读存储介质 |
CN113296910B (zh) * | 2021-05-17 | 2023-12-15 | 深圳市优必选科技股份有限公司 | 文件系统的调用方法、装置、终端设备及可读存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110019081B (zh) | 数据持久化处理方法、装置、系统及可读存储介质 | |
KR102015071B1 (ko) | 음성 활성 데이터 패킷의 데이터 구조 풀링 | |
AU2014386583B8 (en) | Inter-process communication method based on application layer of android and basic application communication system | |
US20240031309A1 (en) | Data Processing Method, Apparatus, Device and Storage Medium | |
CN107566541A (zh) | 容器网络资源分配方法、系统、存储介质和电子设备 | |
WO2017080391A1 (zh) | 一种网络服务部署方法和装置 | |
CN110311989A (zh) | 一种灰度发布方法、装置、存储介质、设备及系统 | |
CN101889427A (zh) | 用于移动通信网络的应用系统发布方法、运营方法及系统 | |
WO2004021127A3 (en) | Method and apparatus for planning resources base on events in a master queue | |
CN102439983B (zh) | 一种数据快速分发方法和装置 | |
WO2017041649A1 (zh) | 一种应用部署方法及设备 | |
CN109634751B (zh) | 一种利用electron框架实现应用层和底层通信的方法 | |
WO2015051702A1 (zh) | 移动终端多apn网络通道并发网络系统及其创建方法 | |
EP3091712B1 (en) | Smart device for realizing multiple-device collaboration and working method for multiple-device collaboration | |
CN105592019B (zh) | 双执行环境之间双向访问应用的方法 | |
CN108234149A (zh) | 一种网络请求的管理方法和装置 | |
CN105786511A (zh) | 终端设备Web应用管理的实现方法 | |
EP4322483A1 (en) | System architecture for implementing dds communication on basis of autosar, communication method, and device | |
WO2017000616A1 (zh) | 访问云数据的方法及装置、存储介质 | |
CN106371934A (zh) | 一种基于windows文件系统驱动的第三方存储协议文件访问系统和访问方法 | |
CN103002047A (zh) | 一种rpc式web服务架构方法 | |
CN105847190A (zh) | 一种数据传输方法及处理器 | |
CN107438097A (zh) | 网络请求处理方法及装置 | |
CN104486444A (zh) | 云管理平台的异构api转化系统 | |
CN111294377B (zh) | 一种依赖关系的网络请求发送方法、终端装置及存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20170201 |