发明内容
为了解决上述技术问题或者至少部分地解决上述技术问题,本发明实施例提供了一种打印文件处理方法、装置、电子设备和存储介质,增强了打印机的文件处理效率,降低了打印文件的泄露风险,提高了数据安全性。
本发明实施例提供了一种打印文件处理方法,包括:
响应客户端发送的打印请求,创建环形缓冲区;接收所述客户端发送的多个打印文件,并依次将多个所述打印文件写入所述环形缓冲区;依次读取所述环形缓冲区中的各所述打印文件,并将读取完成的所述打印文件发送至打印机;响应客户端发送的打印完成指令,停止对所述环形缓冲区的写入操作,并在读取完成多个所述打印文件时,停止对所述环形缓冲区的读取操作;将所述打印文件及所述打印文件的状态信息保存至加密数据库,删除所述环形缓冲区。
进一步的,所述环形缓冲区包括读指针和写指针;所述写指针指向所述环形缓冲区中可写入的缓冲区,所述读指针指向所述环形缓冲区中可读的所述打印文件。
进一步的,所述方法还包括:接收所述客户端的打印文件删除请求,获取所述请求对应的打印文件的状态信息;基于各所述打印文件的状态信息,从各所述打印文件中确定待删除的第一目标打印文件;将所述第一目标打印文件放入文件处理队列中,更新所述第一目标打印文件的状态信息,生成删除完成的结果信息并发送至所述客户端。
进一步的,所述方法还包括确定所述文件处理队列中所述第一目标打印文件的内存容量;若所述内存容量大于预设值,则将所述第一目标打印文件拆分成若干个内存符合预定阈值要求的第一目标打印子文件;对所述第一目标打印子文件执行并行删除操作,并更新所述第一目标打印文件的状态信息。
进一步的,基于各所述打印文件的所述状态信息,从各所述打印文件中确定待删除的第一目标打印文件,所述状态信息包括初始状态、删除状态、已删除状态、恢复状态和已恢复状态; 从状态流转图中查找可流转至删除状态的目标状态信息,其中,所述状态流转图为各状态信息之间的流转有向图;基于各所述打印文件的状态信息,确定与所述目标状态信息匹配的第一目标打印文件。
进一步的,所述方法还包括:接收所述客户端对所述打印文件的恢复请求,根据所述第一目标打印文件的状态信息,从所述第一目标打印文件中确定待恢复的第二目标打印文件和停止删除操作的第三目标打印文件;在进行恢复处理之前,先生成恢复完成的结果信息并发送至客户端;在发送所述恢复完成的结果信息至客户端后,停止对所述第三目标打印文件对应的多个内存符合预定阈值要求的第三目标打印子文件的并行删除操作,并将所述第三目标打印文件从所述文件处理队列中移除;将所述第二目标打印文件放入文件处理队列中,以对所述第二目标打印文件对应的多个内存符合预定阈值要求的第二目标打印子文件执行并行的恢复操作,并更新所述第二目标打印文件和第三目标打印文件的状态信息。
进一步的,所述方法还包括:接收所述客户端的打印文件恢复请求,获取所述请求对应的打印文件的状态信息;基于各所述打印文件的状态信息,从各所述打印文件中确定待删除的第四目标打印文件;将所述第四目标打印文件放入文件处理队列中,生成恢复完成的结果信息并发送至所述客户端。
本发明实施例还提供了一种打印文件处理装置,包括:
创建模块,被配置为响应客户端发送的打印请求,创建环形缓冲区;写入模块,被配置为接收所述客户端发送的多个打印文件,并依次将多个所述打印文件写入所述环形缓冲区;读取模块,被配置为依次读取所述环形缓冲区中的各所述打印文件,并将读取完成的所述打印文件发送至打印机;停止模块,被配置为响应客户端发送的打印完成指令,停止对所述环形缓冲区的写入操作,并在读取完成多个所述打印文件时,停止对所述环形缓冲区的读取操作;保存模块,被配置为将所述打印文件及所述打印文件的状态信息保存至加密数据库,删除所述环形缓冲区。
本发明实施例还提供了一种电子设备,所述电子设备包括:
一个或多个处理器;存储装置,用于存储一个或多个程序;当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如上所述的打印文件处理方法。
本发明实施例还提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如上所述的打印文件处理方法。
本发明实施例还提供了一种计算机程序产品,该计算机程序产品包括计算机程序或指令,该计算机程序或指令被处理器执行时实现如上所述的打印文件处理方法。
本发明实施例提供的技术方案与现有技术相比至少具有如下优点:
(1)本发明相对于临时数据文件存储的方式,环形缓冲区省去了对打印文件流的操作时间,大大提高了打印效率;
(2)环形缓冲区也避免了打印异常而引起的打印文件遗漏删除问题,保证了打印的安全性;
(3)允许用户对打印文件进行选择性的删除和恢复,通过异步化机制和对打印文件的拆分模式,提高了子打印文件的执行并行度,从而提升打印文件的处理速度,降低了因为打印文件的处理而对服务器线上稳定性的影响;
(4)避免了删除和恢复可能存在的互相影响,防止出现状态信息错乱的情况。
具体实施方式
下面将参照附图更详细地描述本发明的实施例。虽然附图中显示了本发明的某些实施例,然而应当理解的是,本发明可以通过各种形式来实现,而且不应该被解释为限于这里阐述的实施例,相反提供这些实施例是为了更加透彻和完整地理解本发明。应当理解的是,本发明的附图及实施例仅用于示例性作用,并非用于限制本发明的保护范围。
应当理解,本发明的方法实施方式中记载的各个步骤可以按照不同的顺序执行,和/或并行执行。此外,方法实施方式可以包括附加的步骤和/或省略执行示出的步骤。本发明的范围在此方面不受限制。
本文使用的术语“包括”及其变形是开放性包括,即“包括但不限于”。术语“基于”是“至少部分地基于”。术语“一个实施例”表示“至少一个实施例”;术语“另一实施例”表示“至少一个另外的实施例”;术语“一些实施例”表示“至少一些实施例”。其他术语的相关定义将在下文描述中给出。
需要注意,本发明中提及的“第一”、“第二”等概念仅用于对不同的装置、模块或单元进行区分,并非用于限定这些装置、模块或单元所执行的功能的顺序或者相互依存关系。
需要注意,本发明中提及的“一个”、“多个”的修饰是示意性而非限制性的,本领域技术人员应当理解,除非在上下文另有明确指出,否则应该理解为“一个或多个”。
在当前技术中,打印机服务器在接收到打印文件后,通过创建临时数据文件对打印文件进行写入存储,再通过另一个线程解析读取文件,并将其发送到打印机进行打印。上述打印流程如图 1所示,打印过程中使用临时数据文件作为中间数据的存储,在写打印文件和读打印文件的操作中会有一定的耗时;而且如果打印过程异常结束,可能会使临时数据文件无法正常删除,导致多余的文件残存,在数据安全上存在一定的隐患。
本发明实施例的方案中,使用环形缓冲区作为中间数据的存储,省去了对打印文件的操作,在效率上更加高效;在打印异常结束的情况下,缓冲区会自动释放,保证了数据的安全性。
请参考图2所示,本发明实施例提供了一种打印文件处理方法的流程图。
步骤210,响应客户端发送的打印请求,创建环形缓冲区。
步骤220,接收所述客户端发送的多个打印文件,并依次将多个所述打印文件写入所述环形缓冲区。
步骤230,依次读取所述环形缓冲区中的各所述打印文件,并将读取完成的所述打印文件发送至打印机。
步骤240,响应客户端发送的打印完成指令,停止对所述环形缓冲区的写入操作,并在读取完成多个所述打印文件时,停止对所述环形缓冲区的读取操作。
步骤250,将所述打印文件及所述打印文件的状态信息保存至加密数据库,删除所述环形缓冲区。
在本实施例中,服务器接收到打印客户端发送来的请求后,创建固定大小的环形缓冲区,环形缓冲区用于临时存放打印文件,其按照严格的先进先出顺序进行处理,打印文件往里面写入,逻辑线程在后面进行异步读取,先写入的打印文件先进行读取。服务器在接收到多个打印文件后,依次循环将打印文件写入到环形缓冲区中,异步线程按照上述规则从缓冲区中一次循环读取打印文件,并将读取出的打印文件直接发送给打印机进行打印。
可选地,环形缓冲区包括读指针和写指针;写指针指向环形缓冲区中可写入的缓冲区,读指针指向环形缓冲区中可读的打印文件。通过移动读指针和写指针就可以实现缓冲区的打印文件的读取和写入。环形缓冲区可以包括多个子缓冲区,在初始状态下,读指针和写指针都指向环形缓冲区的第一个子缓冲区处;在写入了一个打印文件a后,写指针已经移动到第二个子缓冲区的位置,而读指针没有移动;在有一次进行了打印文件a的读取和打印文件b的写入之后,写指针移动到第三个子缓冲区的位置,而读指针移动到第二个子缓冲区的位置。
环形缓冲区所有的读取和写入操作都是在一个固定的存储空间内进行;而队列缓冲区在写入的时候,可能会分配存储空间用于存储新元素,在读取时,可能会释放废弃元素的存储空间。所以环形方式相比队列方式,少掉了对于缓冲区元素所用存储空间的分配、释放,提高了打印过程中文件处理的效率。
进一步地,客户端在发送完所有的打印文件后,或者打印异常客户端停止打印,即生成打印完成指令发送至服务端。服务端响应于该指令,在所有接收的打印文件写入完成后,停止对环形缓冲区的写入操作,关闭缓冲区的写入通道;在读取完成上述所有打印文件且写入通道关闭时,停止对环形缓冲区的读取操作,关闭读取通道。
为了方便用户后续对打印文件的调用,同时保证打印文件的数据安全性,在完成了打印流程后,将所有打印文件及打印文件的状态信息保存至服务端的加密数据库(在加密数据库中的文件,只有获得对应具体密钥才可以访问)中,然后将打印文件从环形缓冲区中清空,并删除环形缓冲区。
具体地,状态信息用于表征该打印文件在服务器中的存储状态,此时打印文件的状态信息为初始状态。
本发明实施例提供的打印文件处理方法,相对于临时数据文件存储的方式,环形缓冲区省去了对打印文件流的操作时间,大大提高了打印效率;此外,环形缓冲区也避免了由于打印异常引起的打印文件的漏删除问题,保证了打印的安全性。
进一步地,作为本发明的一些可选实施例,用户在打印完成后,可以在任意时间对存储在加密数据库中的打印文件可以进行删除、恢复(避免用户反悔或者误操作)等操作。此时,加密数据库中的打印文件的状态信息则不尽相同。如果用户对打印文件进行了删除操作,则打印文件的状态信息为删除;如果该打印文件已经被删除,则打印文件的状态信息为已删除;如果用户对已经删除的打印文件进行了恢复操作,则打印文件的状态信息为恢复;如果该打印文件已经恢复完成,则打印文件的状态信息为已恢复。
具体地应用场景一,当用户想要对打印文件进行删除时,本实施例提供的方法包括:
接收所述客户端的打印文件删除请求,获取所述请求对应的打印文件的状态信息;基于各所述打印文件的状态信息,从各所述打印文件中确定待删除的第一目标打印文件;将所述第一目标打印文件放入文件处理队列中,更新所述第一目标打印文件的状态信息,生成删除完成的结果信息并发送至所述客户端。
用户向服务端发起对打印文件的删除指令,客户端在确定用户时该打印文件的所有者之后,基于加密数据库的密钥以及打印文件的标识生成打印文件删除请求。服务器根据该打印文件删除请求获取对应的打印文件以及打印文件对应的状态信息。
状态信息包括初始状态、删除状态、已删除状态、恢复状态以及已恢复状态,不是所有状态的打印文件都可以被删除,例如,删除和已删除状态的打印文件就不可以被删除。因此,服务器需要基于各所述打印文件的状态信息,从各所述打印文件中确定待删除的第一目标打印文件。
可选地,如图3所示,可以预先建立状态流程图,从该状态流转图中查找可流转至删除状态的目标状态信息。这里,状态流转图为各状态信息之间的流转有向图,所有状态信息需要按照有向图中的箭头方向进行状态的流转。从图3中可以得到,只有状态信息为:初始状态、恢复状态、已恢复状态的打印文件,才可以将进行删除操作。因此,将打印文件中处于上述三种状态的打印文件确定为待删除的第一目标打印文件。
在确定了第一目标打印文件之后,服务器将第一目标打印文件放入文件处理队列中,并将第一目标打印文件的状态信息更新为删除,生成删除完成的结果信息并发送至所述客户端。更优选的,为了降低服务器的处理压力,第一目标打印文件的删除采取异步处理的形式,即在确定了第一目标打印文件后,先把删除完成的结果信息发送至客户端告知用户,后续再根据服务器的任务处理数量,对上述第一目标打印文件进行异步删除处理。
具体地,第一目标打印文件的处理过程可以采用如下方案:
确定所述文件处理队列中所述第一目标打印文件的属性信息;基于所述第一目标打印文件的属性信息将所述第一目标打印文件拆分成若干个第一目标打印子文件;对所述第一目标打印子文件执行删除操作,并更新所述第一目标打印文件的状态信息。
更进一步的,属性信息优选为第一目标打印文件的内存信息,对于内存较大的第一目标打印文件,直接处理所需的时间过长,因此,本实施例优选的将第一目标打印文件拆分成若干个内存符合预设阈值的第一目标打印子文件,以便并行对多个第一目标打印子文件执行删除操作。在完成对第一目标打印文件的删除操作之后,将第一目标打印文件的状态信息更新为已删除。
具体地应用场景二,当用户想要对删除的打印文件进行恢复时,本实施例提供的方法包括:
接收所述客户端的打印文件恢复请求,获取所述请求对应的打印文件的状态信息;基于各所述打印文件的状态信息,从各所述打印文件中确定待删除的第四目标打印文件;将所述第四目标打印文件放入文件处理队列中,生成恢复完成的结果信息并发送至所述客户端。
用户向服务端发起对打印文件的恢复指令,客户端在确定用户时该打印文件的所有者之后,基于加密数据库的密钥以及打印文件的标识生成打印文件恢复请求。服务器根据该打印文件恢复请求获取对应的打印文件以及打印文件对应的状态信息。
如上所述,服务器需要基于各所述打印文件的状态信息,从各所述打印文件中确定待恢复的第四目标打印文件。从图3中可以得到,只有状态信息为:删除状态、已删除状态的打印文件,才可以将进行恢复操作。因此,将打印文件中处于上述两种状态的打印文件确定为待恢复的第四目标打印文件。
在确定了第四目标打印文件之后,服务器将第四目标打印文件放入文件处理队列中,并将第四目标打印文件的状态信息更新为恢复,生成恢复完成的结果信息并发送至所述客户端。更优选的,为了降低服务器的处理压力,第四目标打印文件的恢复采取异步处理的形式,即在确定了第四目标打印文件后,先把恢复完成的结果信息发送至客户端告知用户,后续再根据服务器的任务处理数量,对上述第四目标打印文件进行异步恢复处理。第四目标打印文件的处理过程可以参考上述第一目标打印文件的处理方案,本实施例在此不做赘述。需要说明的是,在完成对第四目标打印文件的恢复操作之后,将第一目标打印文件的状态信息更新为已恢复。
根据上述实施例的方案,一方面,用户可以对打印文件进行选择性的删除和恢复;另一方面,通过异步化机制对打印文件进行处理时,并通过对打印文件的拆分模式,提高子打印文件的执行并行度,从而提升打印文件的处理速度,降低了因为打印文件的处理而对服务器线上稳定性的影响。
具体地,应用场景三,作为应用场景一的延续,当用户想要对正在删除的打印文件进行恢复时,由于删除和恢复可能存在互相影响,从而出现对于同一打印文件,可能会出现状态信息错乱的情况。为了解决上述问题,本实施例采取的方案如下:
接收所述客户端对所述打印文件的恢复请求,根据所述第一目标打印文件的状态信息,从所述第一目标打印文件中确定待恢复的第二目标打印文件和停止删除操作的第三目标打印文件;生成恢复完成的结果信息并发送至客户端;停止对所述第三目标打印文件对应的多个内存符合预定阈值要求的第三目标打印子文件的并行删除操作,并将所述第三目标打印文件从所述文件处理队列中移除;将所述第二目标打印文件放入文件处理队列中,以便对所述第二目标打印文件对应的多个内存符合预定阈值要求的第二目标打印子文件执行并行恢复操作,并更新所述第二目标打印文件和第三目标打印文件的状态信息。
具体地,在接收到恢复请求后,服务器根据第一目标打印文件的状态信息,确定状态信息为已删除的第二目标打印文件和状态信息为删除的第三目标打印文件。在确定了第二目标打印文件和第三目标打印文件之后,服务器停止对第三目标打印文件对应的各第三目标打印子文件的并行删除操作,并将第三目标打印文件从文件处理队列中移除;此外,服务器将将所述第二目标打印文件放入文件处理队列中,以便对所述第二目标打印文件对应的多个内存符合预定阈值要求的第二目标打印子文件执行恢复操作。在执行完成上述操作后,将第二目标打印文件的状态信息更新为恢复,将第三目标打印文件的状态信息更新为已恢复,生成恢复完成的结果信息并发送至所述客户端。
第二目标打印文件的处理过程可以参考上述第一目标打印文件的处理方案,本实施例在此不做赘述。需要说明的是,在完成对第二目标打印文件的恢复操作之后,将第二目标打印文件的状态信息更新为已恢复。
具体地,应用场景四,若打印文件在加密数据库中的存储时间超过预设时长,且在这预设时长内用户并未对上述打印文件下发任何删除或恢复指令,则为了提高服务器的存储空间,可以对打印文件进行彻底删除。具体地删除流程可参见应用场景一,需要说明的是,在完成对打印文件的彻底删除操作之后,将第一目标打印文件的状态信息更新为彻底删除,且该彻底删除的打印文件不可再恢复。
在本实施例中,通过引入状态信息,可以确定多个打印文件中每个打印文件当前是否已经被删除,避免了删除流程和恢复流程的互相影响,提高了打印文件的变更速度。
在一个实施例中,参考图4所示,提供了一种打印文件处理装置的结构示意图。该装置可用于执行图2或图3所示的打印文件处理方法,该装置包括:创建模块310、写入模块320、读取模块330、停止模块340和保存模块350;其中,
创建模块310,被配置为响应客户端发送的打印请求,创建环形缓冲区;写入模块320,被配置为接收所述客户端发送的多个打印文件,并依次将多个所述打印文件写入所述环形缓冲区;读取模块330,被配置为依次读取所述环形缓冲区中的各所述打印文件,并将读取完成的所述打印文件发送至打印机;停止模块340,被配置为响应客户端发送的打印完成指令,停止对所述环形缓冲区的写入操作,并在读取完成多个所述打印文件时,停止对所述环形缓冲区的读取操作;保存模块350,被配置为将所述打印文件及所述打印文件的状态信息保存至加密数据库,删除所述环形缓冲区。
进一步地,所述环形缓冲区包括读指针和写指针;所述写指针指向所述环形缓冲区中可写入的缓冲区,所述读指针指向所述环形缓冲区中可读的所述打印文件。
进一步地,所述装置还包括:获取模块,确定模块和更新模块;其中,
获取模块被配置为,接收所述客户端的打印文件删除请求,获取所述请求对应的打印文件的状态信息;确定模块被配置为,基于各所述打印文件的状态信息,从各所述打印文件中确定待删除的第一目标打印文件;更新模块被配置为,将所述第一目标打印文件放入文件处理队列中,更新所述第一目标打印文件的状态信息,生成删除完成的结果信息并发送至所述客户端。
进一步地,更新模块进一步被配置为,确定所述文件处理队列中所述第一目标打印文件的属性信息;基于所述第一目标打印文件的属性信息将所述第一目标打印文件拆分成若干个第一目标打印子文件;对所述第一目标打印子文件执行删除操作,并更新所述第一目标打印文件的状态信息。
进一步地,所述状态信息包括初始状态、删除状态、已删除状态、恢复状态以及已恢复状态;确定模块进一步被配置为,基于各所述打印文件的状态信息,从各所述打印文件中确定待删除的第一目标打印文件;从状态流转图中查找可流转至删除状态的目标状态信息;其中,所述状态流转图为各状态信息之间的流转有向图;基于各所述打印文件的状态信息,确定与所述目标状态信息匹配的第一目标打印文件。
进一步地,确定模块进一步被配置为,接收所述客户端对所述打印文件的恢复请求,根据所述第一目标打印文件的状态信息,从所述第一目标打印文件中确定待恢复的第二目标打印文件和停止删除操作的第三目标打印文件;生成模块进一步被配置为,生成恢复完成的结果信息并发送至客户端;停止模块进一步被配置为,停止对所述第三目标打印文件对应的多个第三目标打印子文件的并行删除操作,并将所述第三目标打印文件从所述文件处理队列中移除;更新模块,进一步被配置为,将所述第二目标打印文件放入文件处理队列中,以便对所述第二目标打印文件对应的多个第二目标打印子文件执行并行恢复操作,并更新所述第二目标打印文件和第三目标打印文件的状态信息。
进一步地,获取模块进一步被配置为,接收所述客户端的打印文件恢复请求,获取所述请求对应的打印文件的状态信息;确定模块进一步被配置为,基于各所述打印文件的状态信息,从各所述打印文件中确定待删除的第四目标打印文件;生成模块进一步被配置为,将所述第四目标打印文件放入文件处理队列中,生成恢复完成的结果信息并发送至所述客户端。
需要说明的是,本发明实施例所提供的打印文件处理装置对应的可用于执行上述各方法实施例的技术方案,其实现原理和技术效果类似,此处不再赘述。
图5为本发明实施例中的一种电子设备的结构示意图。下面具体参考图5,其示出了适于用来实现本发明实施例中的电子设备500的结构示意图。本发明实施例中的电子设备500可以包括但不限于诸如移动电话、笔记本电脑、数字广播接收器、PDA(个人数字助理)、PAD(平板电脑)、PMP(便携式多媒体播放器)、车载终端(例如车载导航终端)、可穿戴电子设备等等的移动终端以及诸如数字TV、台式计算机、智能家居设备等等的固定终端。图5示出的电子设备仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图5所示,电子设备500可以包括处理装置(例如中央处理器、图形处理器等)501,其可以根据存储在只读存储器(ROM)502中的程序或者从存储装置508加载到随机访问存储器(RAM)503中的程序而执行各种适当的动作和处理以实现如本发明所述的实施例的方法。在RAM 503中,还存储有电子设备500操作所需的各种程序和数据。处理装置501、ROM502以及RAM 503通过总线504彼此相连。输入/输出(I/O)接口505也连接至总线504。
通常,以下装置可以连接至I/O接口505:包括例如触摸屏、触摸板、键盘、鼠标、摄像头、麦克风、加速度计、陀螺仪等的输入装置506;包括例如液晶显示器(LCD)、扬声器、振动器等的输出装置507;包括例如磁带、硬盘等的存储装置508;以及通信装置509。通信装置509可以允许电子设备500与其他设备进行无线或有线通信以交换数据。虽然图5示出了具有各种装置的电子设备500,但是应理解的是,并不要求实施或具备所有示出的装置。可以替代地实施或具备更多或更少的装置。
特别地,根据本发明的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本发明的实施例包括一种计算机程序产品,其包括承载在非暂态计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码,从而实现如上所述的方法。在这样的实施例中,该计算机程序可以通过通信装置509从网络上被下载和安装,或者从存储装置508被安装,或者从ROM502被安装。在该计算机程序被处理装置501执行时,执行本发明实施例的方法中限定的上述功能。
需要说明的是,本发明上述的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本发明中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本发明中,计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读信号介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:电线、光缆、RF(射频)等等,或者上述的任意合适的组合。
在一些实施方式中,终端、服务器可以利用诸如HTTP(HyperText TransferProtocol,超文本传输协议)之类的任何当前已知或未来研发的网络协议进行通信,并且可以与任意形式或介质的数字数据通信(例如,通信网络)互连。通信网络的示例包括局域网(“LAN”),广域网(“WAN”),网际网(例如,互联网)以及端对端网络(例如,ad hoc端对端网络),以及任何当前已知或未来研发的网络。
上述计算机可读介质可以是上述电子设备中所包含的;也可以是单独存在,而未装配入该电子设备中。
上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该电子设备执行时,使得该电子设备:
响应客户端发送的打印请求,创建环形缓冲区;接收所述客户端发送的多个打印文件,并依次将多个所述打印文件写入所述环形缓冲区;依次读取所述环形缓冲区中的各所述打印文件,并将读取完成的所述打印文件发送至打印机;响应客户端发送的打印完成指令,停止对所述环形缓冲区的写入操作,并在读取完成多个所述打印文件时,停止对所述环形缓冲区的读取操作;将所述打印文件及所述打印文件的状态信息保存至加密数据库,删除所述环形缓冲区。
可选地,当上述一个或者多个程序被该电子设备执行时,该电子设备还可以执行上述实施例所述的其他步骤。
附图中的流程图和框图,图示了按照本发明各种实施例的方法、装置和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,依照所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本发明实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现。其中,单元的名称在某种情况下并不构成对该单元本身的限定。
在本发明的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦除可编程只读存储器(EPROM或快闪存储器)、光纤、便捷式紧凑盘只读存储器(CD-ROM)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
以上描述仅为本发明的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本发明中所涉及的公开范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述公开构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本发明中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。
此外,虽然采用特定次序描绘了各操作,但是这不应当理解为要求这些操作以所示出的特定次序或以顺序次序执行来执行。在一定环境下,多任务和并行处理可能是有利的。同样地,虽然在上面论述中包含了若干具体实现细节,但是这些不应当被解释为对本发明的范围的限制。在单独的实施例的上下文中描述的某些特征还可以组合地实现在单个实施例中。相反地,在单个实施例的上下文中描述的各种特征也可以单独地或以任何合适的子组合的方式实现在多个实施例中。
尽管已经采用特定于结构特征和/或方法逻辑动作的语言描述了本主题,但是应当理解所附权利要求书中所限定的主题未必局限于上面描述的特定特征或动作。相反,上面所描述的特定特征和动作仅仅是实现权利要求书的示例形式。