JP6488608B2 - Information processing apparatus, system, and program - Google Patents
Information processing apparatus, system, and program Download PDFInfo
- Publication number
- JP6488608B2 JP6488608B2 JP2014193650A JP2014193650A JP6488608B2 JP 6488608 B2 JP6488608 B2 JP 6488608B2 JP 2014193650 A JP2014193650 A JP 2014193650A JP 2014193650 A JP2014193650 A JP 2014193650A JP 6488608 B2 JP6488608 B2 JP 6488608B2
- Authority
- JP
- Japan
- Prior art keywords
- message
- processing
- unit
- received
- communication path
- 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.)
- Active
Links
Images
Landscapes
- Data Exchanges In Wide-Area Networks (AREA)
- Communication Control (AREA)
- Information Transfer Between Computers (AREA)
- Computer And Data Communications (AREA)
Description
本発明は、情報処理装置、システム及びプログラムに関する。 The present invention relates to an information processing apparatus, system, and program.
特許文献1には、画像形成装置の操作部と外部情報端末の表示部とにおいて操作パネルとしての表示画面データを表示する技術が記載されている。
本発明は、サーバ側とクライアント側との間で複数の通信プロトコルを併用して一連の処理が実行されるシステムにおいて、クライアント側でのデータの一連の処理の受信順序に関わらず処理の順序が入れ替わってしまうことを防止することを目的とする。 The present invention provides a system in which a series of processing is executed between a server side and a client side in combination with a plurality of communication protocols, regardless of the order of reception of the series of data processing on the client side. The purpose is to prevent the change.
本発明の請求項1に係る情報処理装置は、クライアントとして機能するソフトウェアと、リクエスト/レスポンス型の第1通信プロトコルによる第1通信路を確立する第1確立手段と、前記ソフトウェアと、前記第1通信プロトコルと異なる第2通信プロトコルによる第2通信路を確立する第2確立手段と、前記ソフトウェアから前記第1通信路を介して処理の実行要求を受信する受信手段と、前記受信された実行要求に従って前記処理を実行する処理実行手段と、前記実行要求を受け付けた旨を示す第1メッセージおよび前記処理の処理状況を示す第2メッセージに、当該処理を識別するトランザクション番号、並びに、当該第1メッセージおよび当該第2メッセージを含むメッセージ群における各メッセージの処理順序を示すシーケンス番号を付与する付与手段と、前記トランザクション番号および前記シーケンス番号が付与された第1メッセージを、前記処理の完了を待機することなく前記第1通信路により前記ソフトウェアへ送信する第1送信手段と、前記処理の実行中および前記処理が完了したときに、前記トランザクション番号および前記シーケンス番号が付与された第2メッセージを前記第2通信路により前記ソフトウェアへ送信する第2送信手段とを有することを特徴とする。
An information processing apparatus according to
本発明の請求項2に係る情報処理装置は、サーバとして機能するソフトウェアと、リクエスト/レスポンス型の第1通信プロトコルによる第1通信路を確立する第1確立手段と、前記ソフトウェアと、前記第1通信プロトコルと異なる第2通信プロトコルによる第2通信路を確立する第2確立手段と、前記ソフトウェアへ前記第1通信路を介して処理の実行要求を送信する第1送信手段と、前記ソフトウェアから前記第1通信路を介して前記実行要求を受け付けた旨を示す第1メッセージを受信する第1受信手段と、前記ソフトウェアから前記第2通信路を介して前記処理の実行中における処理状況および前記処理の完了を示す第2メッセージを受信する第2受信手段と、前記受信された第1メッセージおよび前記受信された第2メッセージの各々に付された、前記送信された実行要求に対応する処理を識別するトランザクション番号、および、当該第1メッセージおよび当該第2メッセージを含むメッセージ群における各メッセージの処理順序を示すシーケンス番号に基づいて、当該第1メッセージおよび当該第2メッセージの処理順序を特定する特定手段と、前記受信された第1メッセージおよび前記受信された第2メッセージのそれぞれに対応する処理を、前記特定された処理順序で実行する処理実行手段とを有することを特徴とする。 An information processing apparatus according to a second aspect of the present invention includes software that functions as a server, first establishing means for establishing a first communication path based on a request / response type first communication protocol, the software, and the first A second establishing means for establishing a second communication path according to a second communication protocol different from the communication protocol; a first transmitting means for transmitting a processing execution request to the software via the first communication path; A first receiving means for receiving a first message indicating that the execution request has been accepted via the first communication path ; a processing status during execution of the process from the software via the second communication path; and the process a second receiving means for receiving a second message indicating completion, second message first message and the reception said received Based on a transaction number for identifying a process corresponding to the transmitted execution request and a sequence number indicating a processing order of each message in a message group including the first message and the second message. , Specifying means for specifying the processing order of the first message and the second message, and processing corresponding to each of the received first message and the received second message in the specified processing order And a processing execution means for executing the processing.
本発明の請求項3に係る情報処理装置は、請求項2に記載の構成において、前記処理実行手段は、前記ソフトウェアから受信されていない第1メッセージまたは第2メッセージより後の処理順序である第1メッセージおよび第2メッセージに対応する処理を実行しないことを特徴とする。 An information processing apparatus according to a third aspect of the present invention is the information processing apparatus according to the second aspect, wherein the processing execution means has a processing order after the first message or the second message not received from the software. The process corresponding to the first message and the second message is not executed.
本発明の請求項4に係る情報処理装置は、請求項3に記載の構成において、前記処理実行手段は、予め定められた期間以上待機しても前記受信されていない第1メッセージまたは第2メッセージが受信されなかった場合、当該受信されていない第1メッセージまたは第2メッセージより後の処理順序である第1メッセージおよび第2メッセージに対応する処理を実行することを特徴とする。
The information processing apparatus according to
本発明の請求項5に係る情報処理装置は、請求項2に記載の構成において、前記処理実行手段は、前記受信された第1メッセージまたは第2メッセージに対応する処理順序が、実行済である処理の処理順序よりも前のものである場合、当該受信された第1メッセージまたは第2メッセージに対応する処理を実行しないことを特徴とする。
An information processing apparatus according to claim 5 of the present invention is the configuration according to
本発明の請求項6に係る情報処理装置は、請求項2ないし5のいずれか1項に記載の構成において、前記処理実行手段は、対応する処理を未だ実行していない受信済みの第1メッセージおよび第2メッセージの少なくともいずれか一方が複数ある場合、当該複数の第1メッセージおよび第2メッセージの少なくともいずれか一方のうちの、属性が予め定められた条件を満たす第1メッセージおよび第2メッセージの少なくともいずれか一方に対応する処理を実行することを特徴とする。
An information processing apparatus according to claim 6 of the present invention is the configuration according to any one of
本発明の請求項7に係るシステムは、第1情報処理装置と、第2情報処理装置とを有し、前記第1情報処理装置は、クライアントとして機能する第1ソフトウェアと、リクエスト/レスポンス型の第1通信プロトコルによる第1通信路を確立する第1確立手段と、前記第1ソフトウェアと、前記第1通信プロトコルと異なる第2通信プロトコルによる第2通信路を確立する第2確立手段と、前記第1ソフトウェアから前記第1通信路を介して処理の実行要求を受信する第1受信手段と、前記受信された実行要求に従って前記処理を実行する第1処理実行手段と、前記実行要求を受け付けた旨を示す第1メッセージおよび前記処理の処理状況を示す第2メッセージに、当該処理を識別するトランザクション番号、並びに、当該第1メッセージおよび当該第2メッセージを含むメッセージ群における各メッセージの処理順序を示すシーケンス番号を付与する付与手段と、前記トランザクション番号および前記シーケンス番号が付与された第1メッセージを、前記処理の完了を待機することなく前記第1通信路により前記第1ソフトウェアへ送信する第1送信手段と、前記処理の実行中および前記処理が完了したときに、前記トランザクション番号および前記シーケンス番号が付与された第2メッセージを前記第2通信路により前記第1ソフトウェアへ送信する第2送信手段とを備え、前記第2情報処理装置は、サーバとして機能する第2ソフトウェアと、前記第1通信プロトコルによる前記第1通信路を確立する第3確立手段と、前記第2ソフトウェアと、前記第1通信プロトコルと異なる前記第2通信プロトコルによる前記第2通信路を確立する第4確立手段と、前記第2ソフトウェアへ前記第1通信路を介して処理の実行要求を送信する第3送信手段と、前記第2ソフトウェアから前記第1通信路を介して前記実行要求を受け付けた旨を示す第1メッセージを受信する第2受信手段と、前記第2ソフトウェアから前記第2通信路を介して前記送信された実行要求に対応する処理の実行中における処理状況および前記処理の完了を示す第2メッセージを受信する第3受信手段と、前記受信された第1メッセージおよび前記受信された第2メッセージの各々に付された、前記送信された実行要求に対応する処理を識別するトランザクション番号、および、当該第1メッセージおよび当該第2メッセージを含むメッセージ群における各メッセージの処理順序を示すシーケンス番号に基づいて、当該第1メッセージおよび当該第2メッセージの処理順序を特定する特定手段と、前記受信された第1メッセージおよび前記受信された第2メッセージのそれぞれに対応する処理を、前記特定された処理順序で実行する第2処理実行手段とを備えることを特徴とする。 A system according to a seventh aspect of the present invention includes a first information processing device and a second information processing device, wherein the first information processing device includes first software that functions as a client, and a request / response type First establishing means for establishing a first communication path according to a first communication protocol, the first software, second establishing means for establishing a second communication path according to a second communication protocol different from the first communication protocol, and A first receiving unit configured to receive a process execution request from the first software via the first communication path; a first process executing unit configured to execute the process according to the received execution request; and the execution request received the first message and a second message indicating the processing status of the processing indicating the fact, transaction number for identifying the process, as well as, Contact the first message And assigning means for assigning a sequence number indicating the processing order of each message in the message group including fine the second message, the first message that the transaction number and the sequence number is assigned, to wait for the completion of the process a first transmission means for not transmitting by said first communication path to the first software, when running and the processing of the processing is complete, the second message the transaction number and the sequence number is assigned and a second transmission means for transmitting to said first software by the second communication path, the second information processing apparatus, a second software functioning as a server, establishing the first communication path by the first communication protocol Different from the first establishing protocol, the second software, and the first communication protocol. Fourth establishing means for establishing the second communication path according to the second communication protocol that a third transmission means for transmitting the processing execution request via the first communication path to the second software, the second Second receiving means for receiving a first message indicating that the execution request has been received from the software via the first communication path; and the execution request transmitted from the second software via the second communication path. And a third receiving means for receiving a second message indicating the processing status during the execution of the processing corresponding to the processing and the completion of the processing, and each of the received first message and the received second message. A transaction number for identifying a process corresponding to the transmitted execution request, and a message group including the first message and the second message. Specific means for specifying the processing order of the first message and the second message based on a sequence number indicating the processing order of each message, and each of the received first message and the received second message And a second process execution means for executing a process corresponding to the above in the specified process order.
本発明の請求項8に係るプログラムは、コンピュータに、クライアントとして機能するソフトウェアと、リクエスト/レスポンス型の第1通信プロトコルによる第1通信路を確立するステップと、前記ソフトウェアと、前記第1通信プロトコルと異なる第2通信プロトコルによる第2通信路を確立するステップと、前記ソフトウェアから前記第1通信路を介して処理の実行要求を受信するステップと、前記受信された実行要求に従って前記処理を実行するステップと、前記実行要求を受け付けた旨を示す第1メッセージおよび前記処理の処理状況を示す第2メッセージに、当該処理を識別するトランザクション番号、並びに、当該第1メッセージおよび当該第2メッセージを含むメッセージ群における各メッセージの処理順序を示すシーケンス番号を付与するステップと、前記トランザクション番号および前記シーケンス番号が付与された第1メッセージを、前記処理の完了を待機することなく前記第1通信路により前記ソフトウェアへ送信するステップと、前記処理の実行中および前記処理が完了したときに、前記トランザクション番号および前記シーケンス番号が付与された第2メッセージを前記第2通信路により前記ソフトウェアへ送信するステップとを実行させるためのプログラムであることを特徴とする。 According to an eighth aspect of the present invention, there is provided a program for causing a computer to function as a client, establishing a first communication path using a request / response type first communication protocol, the software, and the first communication protocol. Establishing a second communication path based on a second communication protocol different from the above, receiving a process execution request from the software via the first communication path, and executing the process according to the received execution request a step, the second message indicating the processing status of the execution request a first message and said processing indicating the accepted transaction number for identifying the process, as well as a message including the first message and the second message Sequence that indicates the processing order of each message in the group A step of imparting number, and sending a first message to the transaction number and the sequence number is assigned, to the software by the first communication path without waiting for completion of the processing, execution of the process And a step of transmitting a second message to which the transaction number and the sequence number are assigned to the software through the second communication path when the processing is completed. To do.
本発明の請求項9に係るプログラムは、コンピュータに、サーバとして機能するソフトウェアと、リクエスト/レスポンス型の第1通信プロトコルによる第1通信路を確立するステップと、前記ソフトウェアと、前記第1通信プロトコルと異なる第2通信プロトコルによる第2通信路を確立するステップと、前記ソフトウェアへ前記第1通信路を介して処理の実行要求を送信するステップと、前記ソフトウェアから前記第1通信路を介して前記実行要求を受け付けた旨を示す第1メッセージを受信するステップと、前記ソフトウェアから前記第2通信路を介して前記処理の実行中における処理状況および前記処理の完了を示す第2メッセージを受信するステップと、前記受信された第1メッセージおよび前記受信された第2メッセージの各々に付された、前記送信された実行要求に対応する処理を識別するトランザクション番号、および、当該第1メッセージおよび当該第2メッセージを含むメッセージ群における各メッセージの処理順序を示すシーケンス番号に基づいて、当該第1メッセージおよび当該第2メッセージの処理順序を特定するステップと、前記受信された第1メッセージおよび前記受信された第2メッセージのそれぞれに対応する処理を、前記特定された処理順序で実行するステップとを実行させるためのプログラムであることを特徴とする。 According to a ninth aspect of the present invention, there is provided a program for causing a computer to function as a server, to establish a first communication path based on a request / response type first communication protocol, the software, and the first communication protocol. Establishing a second communication path according to a second communication protocol different from the above, transmitting a process execution request to the software via the first communication path, and from the software via the first communication path Receiving a first message indicating that an execution request has been received, and receiving a second message indicating a processing status during execution of the process and completion of the process from the software via the second communication path Each of the received first message and the received second message A transaction number for identifying a process corresponding to the transmitted execution request, and a sequence number indicating a processing order of each message in the message group including the first message and the second message, A step of specifying a processing order of the first message and the second message, and a step of executing processing corresponding to each of the received first message and the received second message in the specified processing order It is the program for performing these.
請求項1、2、3、7、8および9に係る発明によれば、サーバ側とクライアント側との間で複数の通信プロトコルを併用して一連の処理が実行されるシステムにおいて、クライアント側でのデータの一連の処理の受信順序に関わらず処理の順序が入れ替わってしまうことが防止される。
請求項4に係る発明によれば、クライアント側のソフトウェアで処理が停止してしまうことが防止される。
請求項5に係る発明によれば、受信されたメッセージに対応する処理を全て実行する場合に比べて、クライアント側のソフトウェアでメッセージの受信順序が入れ替わってしまった場合の処理の実行に係る負荷が軽減する。
請求項6に係る発明によれば、受信されたメッセージに対応する処理を全て実行する場合に比べて、処理の実行に係る負荷が軽減する。
According to the first, second, third, seventh, eighth, and ninth aspects of the present invention, in a system in which a series of processes are executed using a plurality of communication protocols between the server side and the client side, the client side It is possible to prevent the processing order from being changed regardless of the reception order of the series of processing of the data.
According to the fourth aspect of the present invention, it is possible to prevent the processing from being stopped by the client side software.
According to the fifth aspect of the present invention, compared to the case where all the processes corresponding to the received message are executed, the load associated with the execution of the process when the message reception order is switched in the client-side software is increased. Reduce.
According to the invention of claim 6, the load related to the execution of the process is reduced as compared with the case where all the processes corresponding to the received message are executed.
[1]実施形態
まず、図1から図11までを参照して、実施形態の情報処理システムの全体構成、ハードウェア構成及び機能構成について説明する。
[1] Embodiment First, the overall configuration, hardware configuration, and functional configuration of an information processing system according to an embodiment will be described with reference to FIGS. 1 to 11.
[1−1]全体構成
図1は、情報処理システムの全体構成の一例を示すブロック図である。図1では、通信回線2と、通信機器3と、情報処理装置10と、複数のユーザ装置20とを備える情報処理システム1が示されている。情報処理システム1は、本実施形態では、コピーやスキャン、FAX(ファクシミリ)、プリント(画像データの媒体への出力)などの機能をユーザに提供するシステムである。
[1-1] Overall Configuration FIG. 1 is a block diagram illustrating an example of the overall configuration of the information processing system. In FIG. 1, an
通信回線2は、例えばインターネットや移動体通信網、電話回線などのうちの少なくとも1つ以上を含む通信のためのシステムである。通信回線2は、自システムに接続された装置同士の通信を仲介する。通信回線2には、情報処理装置10及び通信機器3が接続されている。通信機器3は、通信機能を有する装置であり、本実施形態では無線LANの規格に準拠して無線通信を行う。通信機器3は、ユーザ装置20と無線通信を行う一方、通信回線2を介して情報処理装置10と通信する。つまり、情報処理装置10は、通信回線2及び通信機器3を介してユーザ装置20と通信する。また、情報処理装置10とユーザ装置30は、通信機器3を介することなく、直接通信するように構成してもよい。
The
情報処理装置10は、媒体に画像を形成する画像形成処理や、媒体に形成された画像を読み取る画像読取処理などの処理を行う装置である。これらの処理は、前述したコピーやスキャン、FAX、プリントなどの機能がユーザに提供される際に行われる。情報処理装置10は、自装置の操作に用いられる操作装置30を有する。操作装置30は、情報処理装置10を操作するための装置であり、いわゆるコントロールパネルである。操作装置30は、情報処理装置10の筐体に固定されており、情報処理装置10が設置されている場所に来たユーザによって用いられる。操作装置30は、例えば液晶ディスプレイ等を有し、情報処理装置10を操作するための画像データ(以下「操作画像データ」という)を表示する。操作画像データに基づき表示される操作画像について、図2を参照して説明する。
The
図2は、操作装置30に表示される操作画像の一例を示す図である。図2の例では、コピー機能を利用するための操作画像データ群A1が表示されている。操作画像データ群A1には、コピーを開始させるための操作画像データA11などが含まれている。ユーザは、操作画像データA11をタップする(軽く叩く)ことで、操作画像データA11に対応する操作、すなわちコピーを開始させる操作を行う。操作装置30は、表示した操作画像データに対して操作が行われると、その操作に対応した処理の要求を情報処理装置10に対して行う。操作画像データA11が操作された場合であれば、操作装置30は、コピー機能を提供するための処理(具体的には画像読取処理および画像形成処理を含む一連の処理。以下「コピー処理」という)を情報処理装置10に要求する。
FIG. 2 is a diagram illustrating an example of an operation image displayed on the
図1の説明に戻る。ユーザ装置20は、例えばタブレット端末やパーソナルコンピュータなどの装置である。ユーザ装置20は、ユーザによって持ち運ばれて利用されるものでもよいし、机に設置されて利用されるものでもよい。また、ユーザ装置20は、情報処理装置10の操作に限らず、他の用途(会社の業務など)にも用いられてもよい。ユーザ装置20は、操作画像データを表示し、表示した操作画像データに対して操作が行われると、その操作に対応した処理の要求を情報処理装置10に対して行うという点で、操作装置30と共通している。
Returning to the description of FIG. The
情報処理装置10は、操作装置30やユーザ装置20からの要求に基づいて処理を実行すると、実行している処理の状況を表す情報(以下「状況情報」という)をこれらの装置に送信することで、これらの装置に対して処理の状況を通知する。状況情報とは、例えば、コピー機能が利用される場合であれば、画像が読み取られた媒体の枚数や画像が形成された媒体の枚数などの処理の状況を示す情報である。
When the
図3は、表示された状況情報の例を示す図である。情報処理装置10は、例えばコピー処理を実行した場合であれば、図3(a)に示すように、コピーが完了した枚数(部数及びページ数)を表す枚数情報C11や「コピーしています。」という文字列、「白黒」、「A4」、「100%」及び「ソート」というコピーのパラメータなどを含む状況情報C1を送信する。
FIG. 3 is a diagram illustrating an example of the displayed status information. For example, in the case of executing a copy process, the
また、情報処理装置10は、コピー処理が進んで要求された枚数のコピーが完了すると、図3(b)に示すように、要求された枚数の分のコピーが完了したことを表す枚数情報C21や「コピーが完了しました。」という文字列などを含む状況情報C2を送信する。なお、枚数情報C11及びC21は、コピーを要求された枚数を分母とし、そのうちコピーが完了した枚数を分子とする分数で表されている。このように、状況情報には、処理の進捗を表す情報や処理の結果を表す情報、処理に用いられるパラメータの情報などが含まれる。操作装置30及びユーザ装置20は、いずれも、通知された状況を図3に示すように表示する表示装置でもある。以下では、操作装置30及びユーザ装置20を区別しない場合には表示装置4という。
In addition, when the copy process proceeds and the requested number of copies is completed, the
[1−2]ハードウェア構成
図4は、ユーザ装置20のハードウェア構成の一例を示すブロック図である。ユーザ装置20は、制御部21と、記憶部22と、通信部23と、表示部24と、操作部25とを備える。制御部21は、CPU(Central Processing Unit)、ROM(Read Only Memory)、RAM(Random Access Memory)及びリアルタイムクロックを備え(いずれも図示略)、CPUが、RAMをワークエリアとして用いてROMや記憶部22に記憶されたプログラムを実行することによって各部の動作を制御する。リアルタイムクロックは、現在の日時を算出してCPUに通知する。
[1-2] Hardware Configuration FIG. 4 is a block diagram illustrating an example of a hardware configuration of the
記憶部22は、ハードディスクドライブ等を備え、制御部21が制御に用いるデータやプログラム、画像データなどを記憶する。通信部23は、無線LAN(Local Area Network)の規格に準拠して無線通信を行う通信回路及びアンテナを備える通信手段であり、例えば図1に示す通信機器3と無線通信を行う。表示部24は、例えば液晶ディスプレイを有し、制御部21により制御されて表示面に画像を表示する。操作部25は、例えば自装置がタブレット端末である場合には、表示面に重ねて設けられたタッチセンサ(タッチスクリーンやタッチパネルともいう)や筐体に設けられたボタン等を備え、上述したタップ等のユーザの操作を受け付けてその操作の内容を示す操作データを制御部21に供給する。なお、自装置がパーソナルコンピュータである場合には、操作部25はキーボードやマウスを備えていてもよい。制御部21は、供給された操作データに応じた制御を行う。
The
図5は、操作装置30のハードウェア構成の一例を示すブロック図である。操作装置30は、制御部31と、記憶部32と、通信部33と、表示部34と、操作部35とを備える。以下、図4に示すブロックと共通のハードウェアを表すブロック(通信部33を除く各部)には、共通の名称を付して説明を省く。通信部33は、有線LANの規格に準拠して通信を行う通信回路と、通信用のケーブル(具体的にはLANケーブル)が有するコネクタを差し込むポートとを備える通信手段である。
FIG. 5 is a block diagram illustrating an example of a hardware configuration of the
上述したように、操作装置30とユーザ装置20を区別しない場合には表示装置4という。これに伴い、制御部31と制御部21を区別する必要がない場合には「制御部141」という。記憶部32と記憶部22を区別する必要がない場合には「記憶部142」という。表示部34と表示部24を区別する必要がない場合には「表示部144」という。操作部35と操作部25を区別する必要がない場合には「操作部145」という。
As described above, when the
図6は、情報処理装置10のハードウェア構成の一例を示すブロック図である。情報処理装置10は、制御部11と、記憶部12と、画像読取部13と、画像形成部14と、第1通信部15と、第2通信部16と、接続部17とを備える。以下、図4及び図5に示すブロックと共通のハードウェアを表すブロック(制御部11及び記憶部12)には、共通の名称を付して説明を省く。また、情報処理装置10は、UI(User Interface)部として機能する前述した操作装置30を備えている。制御部11は、本実施形態では、操作装置30を除く各部を制御する。
FIG. 6 is a block diagram illustrating an example of a hardware configuration of the
画像読取部13は、例えばCCD(Charge Coupled Devices)方式を用いて、原稿に描かれた画像を読み取る画像読取処理を行う。画像読取部13は、用紙等の媒体に形成されたコンテンツの画像を光学的に読み取って、読み取った画像を表す画像データを制御部11に供給する。画像形成部14は、例えば電子写真方式を用いて、媒体に画像を形成する画像形成処理を行う。画像形成部14は、制御部11から供給される画像データが示す画像を用紙等の媒体に形成する。なお、画像の読み取り及び画像の形成に用いられる前述した方式は、それぞれ一例であり、他の方式であってもよい。
The
第1通信部15は、通信用のケーブルやデータバスを介して操作装置30の通信部33と接続され、前述した外部装置を介さずに操作装置30と通信する。つまり、通信部33も、前述した外部装置を介さずに情報処理装置10と通信する。
The
第2通信部16は、通信用のインターフェースとして有線LANまたは無線LANの規格に準拠して通信を行う通信回路と、通信用のケーブル(LANケーブル)が有するコネクタを差し込むポートや無線LANの規格に準拠した無線の送受信装置を備え、このインターフェースを介して接続される装置と通信する通信処理を行う。第2通信部16は、図1に示す通信回線2に接続されて、外部装置(情報処理装置10にとっての外部装置であり、例えば通信機器3)を介して例えばユーザ装置20と通信する。接続部17は、SDメモリーカード等の記憶媒体を接続するスロット等を有し、それらの記憶媒体と接続する。制御部11は、接続部17を介して、それらの記憶媒体に記憶されているデータの読み出しや記憶媒体へのデータの書き込みを行う。操作装置30は、図5の説明で述べた構成を備え、第1通信部15と通信する。操作装置30は、この通信を行うことで、例えば制御部11から送信されてくるデータが示す画像を表示したり、情報処理装置10を操作するためのデータを制御部11に送信したりするユーザインターフェース部(UI部)として機能する。
The
[1−3]機能構成
図7は、情報処理システム1の機能構成の一例を示すブロック図である。情報処理システム1は、情報処理装置10(第1情報処理装置の一例)と、表示装置4(すなわち操作装置30またはユーザ装置20(第2情報処理装置の一例))とを有する。情報処理装置10は、第1確立手段101と、第2確立手段102と、第1受信手段103と、第1処理実行手段104と、付与手段105と、第1送信手段106と、第2送信手段107とを備える。第1確立手段101は、ウェブクライアントとして機能するソフトウェアと、第1通信プロトコルによる第1通信路を確立する。第2確立手段102は、第1通信プロトコルと異なる第2通信プロトコルによる第2通信路を確立する。第1受信手段103は、上記ソフトウェアから、第1確立手段101によって確立された第1通信路を介して処理の実行要求を受信する。第1処理実行手段104は、第1受信手段103によって受信された実行要求に従って処理を実行する。付与手段105は、前記受信手段103によって受信された実行要求を受け付けた旨を示す第1メッセージおよび前記処理実行手段104によって実行される処理の処理状況を示す第2メッセージに、各メッセージの処理順序を示すシーケンス番号を付与する。第1送信手段106は、付与手段105によりシーケンス番号が付与された第1メッセージを、第1通信路により上記ソフトウェアへ送信する。第2送信手段107は、付与手段105によりシーケンス番号が付与された第2メッセージを、第2通信路により上記ソフトウェアへ送信する。
[1-3] Functional Configuration FIG. 7 is a block diagram illustrating an example of a functional configuration of the
この例で、情報処理装置10の制御部11、または、制御部11および第1通信部15は、第1確立手段101、第2確立手段102、第1受信手段103、第1処理実行手段104、付与手段105、第1送信手段106および第2送信手段107の一例である。
In this example, the
表示装置4は、第3確立手段401と、第4確立手段402と、第3送信手段403と、第2受信手段404と、第3受信手段405と、特定手段406と、第2処理実行手段407とを備える。第3確立手段401は、ウェブサーバとして機能するソフトウェアと、第1通信プロトコルによる第1通信路を確立する。第4確立手段402は、上記ソフトウェアとの間で第1通信プロトコルと異なる第2通信プロトコルによる第2通信路を確立する。第3送信手段403は、上記ソフトウェアへ、第3確立手段401によって確立された第1通信路を介して処理の実行要求を送信する。第2受信手段404は、上記ソフトウェアから、第1通信路を介して、第3送信手段403によって送信された実行要求を受け付けた旨を示す第1メッセージを受信する。第3受信手段405は、上記ソフトウェアから第2通信路を介して処理の処理状況を示す第2メッセージを受信する。特定手段406は、第2受信手段404により受信された第1メッセージおよび前記第3受信手段405によって受信された第2メッセージの各々に付されたシーケンス番号に基づいて、第1メッセージおよび第2メッセージに対応する処理の処理順序を特定する。第2処理実行手段407は、受信された第1メッセージおよび第2メッセージに対応する処理を、特定手段406によって特定された処理順序で実行する。
The
この例で、ユーザ装置20の制御部21、制御部21および通信部23、操作装置30の制御部31、または制御部31および通信部33は、第3確立手段401、第4確立手段402、第3送信手段403、第2受信手段404、第3受信手段405、特定手段406および第2処理実行手段407の一例である。
In this example, the
[1−4]階層構造
図8は、情報処理システム1の構成を表す階層構造の一例を示す図である。情報処理システム1は、プレゼンテーション層40と、インターフェース50と、ファンクション層60と、ミドルウェア層70と、ハードウェア層80とを備える。プレゼンテーション層40は表示装置4(すなわち操作装置30およびユーザ装置20)の制御部141が記憶部142に記憶されたプログラムを実行することによって実現される。プレゼンテーション層40はウェブクライアントとして機能するソフトウェアの一例である。インターフェース50、ファンクション層60およびミドルウェア層70は、情報処理装置10の制御部11が記憶部12に記憶されたプログラムを実行することによって実現される。インターフェース50、ファンクション層60およびミドルウェア層70の少なくともいずれかひとつは、ウェブサーバとして機能するソフトウェアの一例である。ハードウェア層80は、情報処理装置10のハードウェア資源の集合であり、ミドルウェア層70により制御される。
[1-4] Hierarchical Structure FIG. 8 is a diagram illustrating an example of a hierarchical structure representing the configuration of the
この実施形態では、プレゼンテーション層40(すなわち表示装置4)とインターフェース50(すなわち情報処理装置10)とは、WWW(World Wide Web:ワールドワイドウェブ。以下「ウェブ」という)の規格に準拠して通信が行われる。この例で、プレゼンテーション層40とインターフェース50とは、HTTP(Hypertext Transfer Protocol)およびWebSocketにより通信を行う。
In this embodiment, the presentation layer 40 (that is, the display device 4) and the interface 50 (that is, the information processing device 10) communicate according to the WWW (World Wide Web: hereinafter referred to as “web”) standard. Is done. In this example, the
表示装置4がユーザ装置20である場合、情報処理装置10とユーザ装置20(すなわちプレゼンテーション層40とインターフェース50)は、図1の説明で述べたように、通信回線2および通信機器3を介してデータの授受を行う。すなわち、この場合、情報処理装置10およびユーザ装置20ではない通信機器(通信機器3や通信回線2が有する通信機器など。以下「他の通信機器」という)を介する通信が行われる。一方、表示装置4が操作装置30である場合、情報処理装置10と操作装置30(すなわちプレゼンテーション層40とインターフェース50)は、図6の説明で述べた第1通信部15に接続されているケーブルを介してデータの授受を行う。すなわち、この場合、前述した他の通信機器を介さない通信が行われる。上記他の通信機器には、通信機器3以外にも、例えば通信回線2が有するルータやハブ、ブリッジなどが含まれる。
When the
[1−4−1]プレゼンテーション層
操作装置30およびユーザ装置20によって実現されるプレゼンテーション層40は、ユーザによる操作を受け付ける機能(いわゆるユーザインターフェース)を実現する。プレゼンテーション層40は、UI制御部41と、デバイス制御部42と、通信部43とを備える。UI制御部41は、ユーザインターフェースを制御する部分であり、インターフェース50(すなわち情報処理装置10)から送信されてくる、上述した操作画像や状況情報を表示部144に表示したり、操作部145から供給されるデータに応じてユーザの操作を受け付けたりする。具体的には、例えば、UI制御部41は、前述した図3に示される状況情報C1や状況情報C2を表示する。ここで、状況情報の他の例について図10及び図11を参照して説明する。
[1-4-1] Presentation Layer The
図10は、表示された状況情報の例を示す図である。この例では、媒体を収納する収納部がユーザによって開かれた場合に表示される状況情報が表示されている。具体的には、「用紙収容部がセットされていません。」という文字列を含む状況情報C3が表示されている。 FIG. 10 is a diagram illustrating an example of the displayed status information. In this example, the status information displayed when the storage unit for storing the medium is opened by the user is displayed. Specifically, status information C3 including a character string “No paper storage unit is set” is displayed.
図11は、表示された状況情報の別の例を示す図である。この例では、複数の画像を記憶したSDメモリーカード等の記憶媒体が図6に示す情報処理装置10の接続部17に接続されたときに、その記憶媒体に記憶された画像のサムネイル画像の一覧を表示する処理の状況及び結果が表示されている。図11(a)では、「画像一覧を表示しています。」という文字列と、読み込みが済んだ画像から生成したサムネイル画像(この例では10個のサムネイル画像)とを含む状況情報C4が示されている。図11(b)では、「画像一覧を表示しました。」という文字列と、記憶媒体から読み出した全画像から生成したサムネイル画像の一覧とを含む状況情報C5が示されている。
FIG. 11 is a diagram illustrating another example of the displayed status information. In this example, when a storage medium such as an SD memory card storing a plurality of images is connected to the
また、UI制御部41は、例えば情報処理装置10のURL(Uniform Resource Locator)にアクセスする操作をユーザが行うことで、操作画像データの要求を情報処理装置10のインターフェース50に送信する。また、UI制御部41は、送信した操作画像データの要求の応答として情報処理装置10の操作画像管理部63から送信されてきた操作画像データが示す操作画像を表示部144に表示する。より具体的には、UI制御部41は、操作画像データによって示される操作画像の配置や大きさなどのパラメータに基づいて、操作画像を表示する。こうして表示された操作画像が例えば図2に示す操作画像データ群A1である。操作画像データを構成する情報の一例としは、HTML(Hypertext markuplanguage)形式で記述されたファイルがある。UI制御部41は、取得したHTML形式のファイルを解釈して操作画像を表示したり操作情報を受け付けるように制御している。
In addition, the
操作画像データ群A1には、コピーする原稿画像の倍率、コピーした原稿画像を形成する用紙及びコピーした原稿画像のカラーモードというパラメータをそれぞれ選択させるための操作画像(例えばボタン画像やアイコン画像)が含まれている。UI制御部41は、ユーザがこれらの操作画像を操作することで選択したり設定されるパラメータの内容をユーザに提示するために画像を表示態様を変えて表示する。図2の例では、現在選択されているコピーの倍率(この例では「110%」)を表す文字列を含む画像と、現在選択されている用紙及びカラーモードを表す操作画像(この例では「他の倍率」、「A4普通紙」、「白黒」という文字列が描かれたもの)を、選択されていない選択画像とは異なる態様(この例では線を太くする態様。ハイライトやラジオボタンなどの態様でもよい。)で表示した例である。
The operation image data group A1 includes operation images (for example, button images and icon images) for selecting parameters such as the magnification of the document image to be copied, the paper on which the copied document image is formed, and the color mode of the copied document image. include. The
操作画像データ群A1には、コピーを開始させるための操作画像データA11が含まれている。操作画像データA11が操作されると、その時点で選択されているパラメータを用いたコピーの処理がインターフェース50を介してファンクション層60に要求される。
The operation image data group A1 includes operation image data A11 for starting copying. When the operation image data A11 is operated, a copy process using the parameter selected at that time is requested to the
図8の説明に戻る。UI制御部41は、表示した操作画像に関するデータをデバイス制御部42に供給する。操作画像に関するデータとは、操作画像が操作されたか否かを判断するために用いられるデータであり、現在表示されている画面の識別情報であったり、操作画面でユーザが選択したり設定したパラメータの種類と値といったデータである。
Returning to the description of FIG. The
デバイス制御部42は、ユーザの操作に基づいてインターフェース50を介してファンクション層60へ処理の実行を要求する。デバイス制御部42は、操作画像データに対する操作がユーザにより行われると、UI制御部41から供給される操作データに基づいて、そのユーザの操作に応じた処理を情報処理装置10に要求する。
The device control unit 42 requests the
デバイス制御部42は、UI制御部41から供給されたパラメータを用いて、情報処理装置10に処理を依頼する内容を指示データとして生成し、この指示データを送信することにより処理を情報処理装置10に対して要求する。図2に示す状態で操作画像データA11に対する操作が行われた場合であれば、UI制御部41は、コピー処理依頼を示す情報と、複写倍率のパラメータとして「11%」、カラーモードのパラメータとして「白黒」、用紙サイズのパラメータとして「A4普通紙」を、デバイス制御部42へ送り、デバイス制御部142、110%の倍率でA4普通紙に白黒でコピーするための処理を表す指示データを生成して情報処理装置10に要求する。
The device control unit 42 uses the parameters supplied from the
この例で、デバイス制御部42は、UI制御部42から受けとった機能に関する指示情報とパラメータを用いて行う指示を記述した指示データを生成する。この実施形態では、指示データとしてXML(Extensible Markup Language)で記述される。デバイス制御部42は、生成した指示データを含むHTTPリクエストを生成する。デバイス制御部42は、生成したHTTPリクエストをインターフェース50に送信することで、ファンクション層60に対して処理を要求する。このようにデバイス制御部42が処理を要求するためにインターフェース50へ送信するHTTPリクエストのことを以下では「処理要求」という。なお、コピー処理が要求される場合には、指示データを含む処理要求が生成されるが、要求される処理によっては、処理要求に指示データが含まれない場合もある。例えば情報処理装置10の電源を落とす処理が要求される場合には処理要求に指示データが含まれない。
In this example, the device control unit 42 generates instruction data describing an instruction to be performed using instruction information and parameters related to the function received from the UI control unit 42. In this embodiment, the instruction data is described in XML (Extensible Markup Language). The device control unit 42 generates an HTTP request including the generated instruction data. The device control unit 42 requests the
通信部43は、UI制御部41及びデバイス制御部42がインターフェース50と行う通信を制御する。
The
[1−4−2]インターフェース50
インターフェース50は、プレゼンテーション層40とファンクション層60との接続を仲介する機能を実現する層である。プレゼンテーション層40とインターフェース50との接続は、図1に示す通信機器3等の通信機能を有する外部装置を介する場合(ユーザ装置20との接続)と、そういった外部装置を介さない場合(操作装置30との接続)とがある。インターフェース50は、ユーザ装置20及び操作装置30との通信を、共通の通信手順(HTTP、WebSocketなどの規格に準拠した通信の手順)で仲介する。インターフェース50は、例えばプレゼンテーション層40から送信されてくるHTTPリクエストを受け取ってファンクション層60に供給したり、その応答でファンクション層60から供給されるHTTPレスポンスを受け取ってプレゼンテーション層40に向けて送信したりする。
[1-4-2]
The
[1−4−3]ファンクション層60
ファンクション層60は、コピー機能やスキャン機能など、目的とする用途に沿ってデータを加工する機能を実現する層である。ファンクション層60は、受付・応答部61と、イベント通知部62と、操作画像管理部63と、操作画像DB(Data Base:データベース)64と、コピー機能やスキャン機能などを提供する機能部65とを備える。
[1-4-3]
The
受付・応答部61は、プレゼンテーション層40からインターフェース50を介して送信されてくる処理要求を受け付け、機能部65に処理を依頼する。このとき、受付・応答部61は、依頼された処理を識別する情報として、トランザクションIDを発行する。また、受付・応答部61は、その処理を要求してきた要求元(表示装置4)を識別する情報として、クライアントIDを発行する。受付・応答部61は、発行したトランザクションID及びクライアントIDと、要求元の表示装置4の通信の宛先を互いに対応付けて記憶部12に記憶させる。受付・応答部61は、機能部65に処理を依頼する際に、発行したトランザクションIDを機能部65に供給する。また、受付・応答部61は、受け付けた要求に対する応答を、インターフェース50を介してプレゼンテーション層40に送信する。応答は、要求を受け付けた旨を示すだけの場合もあれば、状況情報を含む場合もある。
The reception /
イベント通知部62は、状況情報を含む通知データを生成し、生成した通知データをWebSocketに準拠したデータに含めてインターフェース50を介してプレゼンテーション層40に送信する。
The
本実施形態では、ファンクション層60とプレゼンテーション層40は、大別して4つの方法で、要求、応答または通知の送信を行う。第1および第2の方法は、HTTPプロトコルが用いられる方法であり、これらは受付・応答部61により行われる。一方、第3の方法は、HTTPプロトコルとWebSocketプロトコルとが併用される方法であり、この方法は受付・応答部61とイベント通知部62が協働することにより行われる。第4の方法は、WebSocketプロトコルにより通知の送信が行われる方法であり、この方法はイベント通知部62により行われる。
In the present embodiment, the
第1の方法では、受付・応答部61は、プレゼンテーション層40から処理要求(HTTPリクエスト)が送信されてきた場合、ミドルウェア層70およびハードウェア層80によるその処理の実行が完了するまで待機する。この場合、受付・応答部61は、ミドルウェア層70から処理の完了が通知されると、処理が完了したときの状況を示す状況情報を含むHTTPレスポンスを、処理を要求してきたプレゼンテーション層40に送信する。具体例を挙げると、例えば図2に示す「倍率選択」の欄の「−」や「+」という操作画像をユーザが操作した場合、プレゼンテーション層40からコピーの倍率というパラメータを下げる処理や上げる処理が要求される。この場合、受付・応答部61は、要求された処理が実行されて変化したパラメータの値を含む応答をプレゼンテーション層40へ送信する。
In the first method, when a processing request (HTTP request) is transmitted from the
第2の方法では、受付・応答部61は、プレゼンテーション層40から処理要求(HTTPリクエスト)が受信された場合、要求された処理の完了を待たずにまずは処理要求が受け付けられた旨の応答(HTTPレスポンス)を送信する。その後、状況情報は、プレゼンテーション層40がHTTPによるいわゆるポーリングを行うことにより取得される。すなわち、受付・応答部61は、プレゼンテーション層40からその処理の状況の通知を求める要求(以下「通知要求」という)があったときに、その通知要求に対する応答を行う。第2の方法で応答が行われると、例えば図3(a)に示す枚数情報C11は、コピーされた画像が媒体に形成される度ではなく、ポーリングの度に通知されて表示される。このため、例えばページ数が1枚ずつ増えるのではなく、数枚ずつ増えることがある。
In the second method, when a processing request (HTTP request) is received from the
このように、受付・応答部61は、第1及び第2の方法を用いた場合、プレゼンテーション層40からの要求(処理要求または通知要求)があったときにその要求に対する応答を送信する。受付・応答部61は、第1の方法を用いた場合には、処理要求に対する応答で処理の結果を要求元のプレゼンテーション層40に送信し、第2の方法を用いた場合には、処理要求に対する応答よりもあとに受け取った通知要求に対する応答で、処理の結果およびそれ以外の処理の状況を要求元のプレゼンテーション層40に送信する。
As described above, when the first and second methods are used, the reception /
第3の方法では、受付・応答部61は、プレゼンテーション層40から処理要求(HTTPリクエスト)が受信されると、第2の方法のように、要求された処理の完了を待たずにまずは処理要求が受け付けられた旨を示す応答(HTTPレスポンス)を送信する。そのあと、イベント通知部62は、ミドルウェア層70およびハードウェア層80により実行されている処理において通知すべき状況が生じたら、通知要求がなくてもその状況を示す状況情報を含むメッセージ(通知)をWebSocketによりプレゼンテーション層40に送信する。つまり、第3の方法により通知される状況は、処理要求により実行される処理の状況である。第3の方法で通知の送信が行われると、例えば図3(a)に示す枚数情報C11のうちの「ページ数」が、コピーされた画像が媒体に形成される度に増えていく。
In the third method, when the processing request (HTTP request) is received from the
第4の方法では、イベント通知部62は、プレゼンテーション層40からの処理要求の有無に関係なく、通知すべき状況が生じたら、通知要求がなくてもその状況を示す状況情報を含むメッセージ(通知)をWebSocketによりプレゼンテーション層40に送信する。つまり、第4の方法により通知される状況は、処理要求により実行される処理とは関係がない。第4の方法では、例えば、WebSocketの規格に基づいて情報処理装置10とセッションが確立されたプレゼンテーション層40であればどれでも通知先となり得る。情報処理システム1においては、例えば、「トナー切れ」や「用紙切れ」、「収容部オープン(用紙等の媒体を収納する収納部が開いた状態)」などの状況は第4の方法で通知するように定められる。なお、第4の方法により通知される状況は、通知先であるプレゼンテーション層40(表示装置4)毎に異なっていてもよい。
In the fourth method, the
このように、イベント通知部62は、第3及び第4の方法を用いた場合、プレゼンテーション層40からの要求(処理要求及び通知要求)の有無に関係なく、能動的に(いわゆるプッシュ型の)通知を行う。イベント通知部62は、第3の方法を用いた場合には、処理要求に対する応答よりもあとに、その処理の結果およびそれ以外の処理の状況を通知し、第4の方法を用いた場合には、予め定められた処理の状況を通知する。
As described above, when the third and fourth methods are used, the
第2及び第3の方法が用いられた場合、受付・応答部61またはイベント通知部62は、どちらの場合でも、処理要求に対する応答よりもあとに、処理の結果およびそれ以外の処理の状況を送信する。また、第1から第3までの3通りの方法は、要求された処理の状況を通知するための方法である。本実施形態では、プレゼンテーション層40は、処理を要求するときに、その処理の状況(処理の結果を含む)を送信する方法(すなわち第1の方法ないし第3の方法のいずれか)を指定する。例えば、送信の方法は、デバイス制御部42によって生成される処理要求に含まれるパラメータによって指定されてもよい。受付・応答部61およびイベント通知部62は、プレゼンテーション層40によって指定された方法を用いて応答および/または通知の送信を行う。
When the second and third methods are used, in either case, the reception /
この実施形態では、状況情報は、ミドルウェア層70によって生成され、受付・応答部61またはイベント通知部62に供給される。なお、状況情報は、機能部65、受付・応答部61またはイベント通知部62によって生成されてもよい。また、イベント通知部62へ供給される状況情報は、ミドルウェア層70(または機能部65)からイベント通知部62へ直接供給されることなく、受付・応答部61を経由してイベント通知部62へ供給されてもよい。
In this embodiment, the situation information is generated by the
図8の説明に戻る。操作画像管理部63は、プレゼンテーション層40に送信する操作画像データの管理を行う。操作画像DB64は、操作画像データを格納するデータベースである。操作画像管理部63は、上述した操作画像データを、インターフェース50を介してプレゼンテーション層40に提供する。操作画像管理部63は、ユーザーインターフフェースとしての操作画面を構成する例えばHTMLで記述された操作画像データを記憶しており、操作画像要求がインターフェース50を介して送信されてくると、操作画像を含む応答を要求元に対してインターフェース50を介して送信する。
Returning to the description of FIG. The operation image management unit 63 manages operation image data to be transmitted to the
操作画像管理部63は、ユーザ装置20から操作画像要求が送信されてきた場合、それに応答してユーザ装置20に操作画像データを送信する。また、操作画像管理部63は、操作装置30から操作画像データの要求が送信されてきた場合には、それに応答して操作装置30に操作画像データを送信する。このように操作画像データの要求元(ユーザ装置20及び操作装置30)に操作画像データを送信することで、操作画像管理部63は、それらの要求元に操作画像データをそれぞれ提供する。
When an operation image request is transmitted from the
機能部65は、情報処理装置10がユーザに提供する機能を実現するためのモジュール群である。情報処理装置10の機能部65は、プレゼンテーション層40から処理要求がインターフェース50を介して送信されてくると、ミドルウェア層70を制御して、その処理要求により要求された処理を実行させる。
The
図9は、機能部65に含まれるモジュール群の一例を示す図である。機能部65には、コピー機能、スキャン機能、FAX機能、プリント機能、宛先表管理機能(宛先情報を管理する機能)、デバイス管理機能(画像読取部13の原稿セット状態や画像形成部14の媒体、消耗品の状態などを管理する機能)、認証機能、親展ボックス機能(情報処理装置10に記憶されている電子文書を管理する機能)、プレビュー機能、ダウンロード機能(プログラムの更新を制御する機能)、保守機能(リモートからの要求に従いハードウェアをメンテナンスする機能)、診断機能(ハードウェアを診断する機能)をそれぞれ実現するためのモジュールが含まれている。
FIG. 9 is a diagram illustrating an example of a module group included in the
機能部65は、例えば、処理要求に含まれている指示データを解析し、解析した指示の内容のとおりに処理が実行されるように、ミドルウェア層70を制御する。具体的には、機能部65は、指示された処理(例えばコピー処理)を指示されたパラメータで実行させる。これにより、ミドルウェア層70は、例えばユーザの操作によって定められた画質及び読取方法で媒体から画像を読み取り、読み取った画像を、ユーザの操作によって定められた出力形式、倍率、用紙及びカラーモードで形成する。
For example, the
機能部65は、ミドルウェア層70に処理の実行を指示する際に、受付・応答部61から供給されたトランザクションIDをミドルウェア層70に供給する。ミドルウェア層70は、受付・応答部61に対して、上述した状況情報とともにトランザクションIDを供給する。
When the
また、機能部65は、処理要求に記述されている方法(第1から第3の方法のうちのいずれか)を指定する記述を解析し、解析した方法(すなわち表示装置4が指定した方法)を受付・応答部61に伝達する。受付・応答部61またはイベント通知部62は、機能部65から供給されたトランザクションIDに対応付けられた通信の宛先に対して、ともに供給された状況情報を記述した通知データを、伝達された方法に則って送信する。これにより、受付・応答部61またはイベント通知部62は、処理の要求元に対して処理の状況を指定された方法で送信する。なお、機能部65は処理要求を受付・応答部61に供給するだけにして、受付・応答部61が指定された通知先の解析を行ってもよい。
Further, the
ミドルウェア層70は、ファンクション層60とハードウェア層80との中間で汎用的な処理を実行する層である。ハードウェア層80は、画像読み取りや画像形成などの処理を物理的に実現する層である。ミドルウェア層70およびハードウェア層80は、上述したコピー処理の他、スキャン処理、FAX処理、プリント処理(それぞれスキャン機能、FAX機能、プリント機能を提供するための処理)などの各種の処理を実行する。コピー処理には、図6に示す画像読取部13による画像読取処理及び画像形成部14による画像形成処理が含まれる。スキャン処理には画像読取処理が含まれ、FAX処理には第2通信部16によるFAX通信処理が含まれる。また、プリント処理には、第1通信部15による通信処理及び画像形成処理が含まれる。スキャン処理及びFAX処理には、他にも、データの取得及び出力の方法に応じて、第2通信部16を用いたデータ通信処理やデータを記憶部12に書き込む書込処理、記憶されたデータを記憶部12から読み出す読出処理などが含まれる。ミドルウェア層70およびハードウェア層80は、処理を実行すると、上述した状況情報(実行している処理の状況を表す情報)をファンクション層60に供給する。
The
図8に示す受付・応答部61、イベント通知部62、操作画像管理部63および機能部65の少なくともいずれかひとつは、図7の第1確立手段101、第2確立手段102、第1受信手段103、第1処理実行手段104、付与手段105、第1送信手段106および第2送信手段107の一例である。UI制御部41、デバイス制御部42および通信部43の少なくともいずれか一つは、第3確立手段401、第4確立手段402、第3送信手段403、第2受信手段404、第3受信手段405、特定手段406および第2処理実行手段407の一例である。
At least one of the reception /
[1−5]動作
[1−5−1]状況情報の送信動作
まず、上述した第1から第4までの4つの方法で状況情報を送信する際に各装置が行う動作の例について、図12から図15までを参照して説明する。
[1-5] Operation [1-5-1] Status Information Transmission Operation First, an example of an operation performed by each device when status information is transmitted by the above-described first to fourth methods will be described with reference to FIG. This will be described with reference to FIGS.
[1−5−1−1]状況情報の第1の送信動作
図12は、状況情報の送信方法として、上述の第1の方法が用いられる場合の各装置の動作の一例を示すシーケンス図である。図12に示す動作は、例えば、ユーザがコピーを行う前に、コピーのためのパラメータ(倍率や用紙のサイズ、カラーモードなど)を変更する操作を行うことを契機に開始される。まず、表示装置4の制御部141(プレゼンテーション層40)が、パラメータを変更する操作を受け付けると(ステップS111)、パラメータの変更の要求を記述した処理要求データをHTTPリクエストに含めて情報処理装置10に対して送信する(ステップS112)。情報処理装置10の受付・応答部61は、そのHTTPリクエストを受信すると、受信された要求の内容を解釈し(ステップS113)、解釈した内容での処理の実行を情報処理装置10のミドルウェア層70に指示する(ステップS114)。
[1-5-1-1] First Transmission Operation of Status Information FIG. 12 is a sequence diagram illustrating an example of the operation of each apparatus when the above-described first method is used as the transmission method of the status information. is there. The operation illustrated in FIG. 12 is started, for example, when the user performs an operation of changing parameters for copying (magnification, paper size, color mode, etc.) before copying. First, when the control unit 141 (presentation layer 40) of the
ミドルウェア層70は、ハードウェア層80と協働して、指示された処理、すなわちパラメータの変更を実行し(ステップS115)、その結果を表す情報を状況情報として受付・応答部61に供給する(ステップS116)。受付・応答部61は、供給された状況情報(この例ではパラメータの変更結果)を記述した通知データを生成する(ステップS117)。受付・応答部61は、生成した通知データを含むHTTPレスポンスを、処理の要求元である表示装置4に送信する(ステップS118)。表示装置4の制御部141は、送信されてきたHTTPレスポンスに含まれる状況情報を自装置の表示部144に表示させる(ステップS119)。
The
[1−5−1−2]状況情報の第2の送信動作
図13は、第2の方法が用いられる場合の各装置の動作の一例を示すシーケンス図である。図13に示す動作は、例えば、ユーザが情報処理装置10の画像読取部13に原稿をセットし、表示装置4に対してコピーを開始させる操作を行うことを契機に開始される。まず、表示装置4の制御部141は、コピーを開始させる操作を受け付けると(ステップS121)、受け付けた操作に応じた指示データを作成する(ステップS122)。制御部141は、作成した指示データを含む処理要求(HTTPリクエスト)を情報処理装置10に送信する(ステップS123)。情報処理装置10の受付・応答部61は、図8に示すインターフェース50を介して処理要求を受け取ると、受け付けた処理要求に含まれる指示データを解析することで、指示の内容を解釈する(ステップS124)。
[1-5-1-2] Second Transmission Operation of Status Information FIG. 13 is a sequence diagram illustrating an example of the operation of each device when the second method is used. The operation illustrated in FIG. 13 is started, for example, when the user sets a document on the
受付・応答部61が、解釈した内容に基づいてコピー処理をミドルウェア層70に指示すると(ステップS125)、ミドルウェア層70及びハードウェア層80が協働して、指示された内容に基づく処理(コピー処理)を実行する(ステップS126)。受付・応答部61は、コピー処理を指示したあと、コピー処理の要求を受け付けた旨を示すHTTPレスポンスを、ステップS123において受信されたHTTPリクエストの応答として表示装置4に送信する(ステップS131)。表示装置4の制御部141は、受信されたHTTPレスポンスに応じた内容を自装置の表示部144に表示させる(ステップS132)。なお、ステップS131の動作は、ステップS124またはS125の動作の前に行われてもよい。
When the reception /
第2の方法においては、表示装置4からの処理要求に対する処理状況の通知および処理完了の通知は、表示装置4がHTTPリクエストによりポーリング処理を行うことにより表示装置4に取得される。表示装置4の制御部141は、コピー処理の要求に対する応答を受け取ったあと、そのコピー処理の状況の通知を求める通知要求(HTTPリクエスト)を送信することによってポーリング処理を行う(ステップS141)。情報処理装置10の受付・応答部61は、コピー処理の状況情報がまだ供給されていなければ、その旨を示すHTTPレスポンスを表示装置4に送信する(ステップS142)。ステップS141及びS142の動作は繰り返し行われる。
In the second method, the processing status notification and the processing completion notification for the processing request from the
情報処理装置10のミドルウェア層70は、コピー(読み取った原稿を示す画像)を媒体に出力すると、それを検知して(ステップS151)、コピーが媒体に出力されたという状況を示す状況情報を受付・応答部61に供給する(ステップS152)。受付・応答部61は、状況情報が供給されたあとに通知要求(HTTPリクエスト)を受信すると(ステップS141)、状況情報を含む通知データを生成して(ステップS153)、表示装置4にHTTPレスポンスに含めて送信する(ステップS154)。表示装置4の制御部141は、ステップS132のように、HTTPレスポンスに応じた内容を自装置の表示部に表示させる(ステップS155)。
When the
[1−5−1−3]状況情報の第3の送信動作
図14は、第3の方法が用いられる場合の各装置の動作の一例を示すシーケンス図である。第1の方法および第2の方法では、表示装置4と情報処理装置10との間でHTTPによるデータの遣り取りが行われた。それに対し、第3の方法では、HTTPに加えて、WebSocketプロトコルにより情報処理装置10から表示装置4へのデータの送信が行われる。具体的には、第2の方法においてポーリングにより取得された状況情報が、第3の方法においてはWebSocketのメッセージとして表示装置4へ通知される。第2の方法と第3の方法とは、ひとつの処理を異なる方法で実現するものであり、両者は選択的に用いられる。
[1-5-1-3] Third Transmission Operation of Status Information FIG. 14 is a sequence diagram illustrating an example of the operation of each device when the third method is used. In the first method and the second method, data is exchanged between the
図14に示す動作は、図13のように、コピーを開始させる操作をユーザが行うことを契機に開始される。まず、表示装置4の制御部141は、コピーを開始させる操作を受け付けると(ステップS121)、情報処理装置10との間でWebSocketセッションを確立するための処理を行う。すなわち、制御部141は、情報処理装置10へWebSocketのハンドシェイク要求であるHTTPリクエストを送信する。このHTTPリクエストには、表示装置4を識別するクライアントIDが含まれる。
The operation shown in FIG. 14 is started when the user performs an operation to start copying as shown in FIG. First, when the
情報処理装置10のインターフェース50は、表示装置4から受信されたHTTPリクエストに基づき、WebSocketへのセッションの確立を行う。受付・応答部61は、WebSocketのハンドシェイク応答を表示装置4へ送信し、これにより、表示装置4と情報処理装置10との間でWebSocketのセッション(以下、単に「セッション」という)が確立される(ステップS160)。なお、セッションが確立されるタイミングはこのタイミングに限られない。例えば、ユーザが表示装置4を用いてウェブブラウザを起動して情報処理装置10のURL(Uniform Resource Locator)にアクセスする操作を行ったタイミングで、セッションの確立処理が行われてもよい。
The
また、受付・応答部61は、受信されたHTTPリクエストに含まれるクライアントIDを記憶部12の予め定められた領域(以下「キャッシュ領域12a」という)に格納する。キャッシュ領域12aに記憶されたクライアントIDは、セッションが正常な処理により切断された場合にキャッシュ領域12aから削除される。すなわち、キャッシュ領域12aには、情報処理装置10との間でセッションを確立中である表示装置4のクライアントID、およびセッションが処理の途中で切断されてしまった表示装置4のクライアントIDが蓄積される。
In addition, the reception /
ステップS161以降の処理において、表示装置4と情報処理装置10とは、HTTPまたはWebSocketのいずれかのプロトコルを用いてメッセージのやりとりを行う。以下、HTTPにより送受信されるメッセージ(第1メッセージの一例)とWebSocketにより送信されるメッセージ(第2メッセージの一例)とを各々区別する必要がない場合には、これらを単に「メッセージ」と称して説明する。情報処理装置10の受付・応答部61は、自装置が送信したメッセージを、そのメッセージに付与されていたクライアントID、トランザクションIDおよびシーケンスIDとともにキャッシュ領域12aに格納する。シーケンスIDは、そのメッセージを識別する識別情報である。また、表示装置4の制御部141は、自装置が受信したメッセージに付与されていたトランザクションIDおよびシーケンスIDの組を、自装置のキャッシュ領域(以下「キャッシュ領域142a」という)に格納する。キャッシュ領域142aは、記憶部142に設けられていてもよく、また、RAMに設けられてもよい。キャッシュ領域142aに格納されたIDのセットは、セッションが処理の途中で切断された場合などに参照される。
In the processing after step S161, the
図14の説明に戻る。WebSocketセッションが確立されると、制御部141は、上述した第3の方法を申し込む旨を記述した通知要求データを含むHTTPリクエストを情報処理装置10に送信する(ステップS161)。情報処理装置10の受付・応答部61は、そのHTTPリクエストを受信すると、受信されたHTTPリクエストに含まれる通知要求データに記述された申込みの内容をミドルウェア層70に伝達する(ステップS162)。ミドルウェア層70は、伝達された申込みを受け付け、表示装置4に対して今後第3の方法で状態情報の送信を行うための設定を行う(ステップS163)。ミドルウェア層70は、例えば第3の方法で通知を行うか否かを表すフラグをONにする。
Returning to the description of FIG. When the WebSocket session is established, the
次に、図13に示すステップS122からS126までの動作と、ステップS131及びS132の動作が行われる。続いて、情報処理装置10のミドルウェア層70及びハードウェア層80は、ステップS151(コピー出力の検知)の動作を行うと、上記フラグがONになっているため、コピーが媒体に出力されたという状況を示す状況情報を受付・応答部61ではなく、イベント通知部62に供給する(ステップS172)。イベント通知部62は、供給された状況情報(コピー枚数等)を記述した通知データを生成して(ステップS173)、生成したデータをステップS160で確立したWebSocketセッションを介して表示装置4に送信する(ステップS174)。表示装置4の制御部141は、受信されたデータに記述された内容(例えば図3(a)に示す状況情報C1)を自装置の表示部144に表示させる(ステップS175)。
Next, the operations from steps S122 to S126 and the operations of steps S131 and S132 shown in FIG. 13 are performed. Subsequently, when the
ミドルウェア層70及びハードウェア層80は、コピー処理を完了すると(ステップS181)、その旨を示す状況情報をイベント通知部62に供給する(ステップS182)。イベント通知部62は、この状況情報を記述した通知データ(例えば「コピーが完了しました。」という文字列を含む通知データ)を生成し(ステップS183)、生成した通知データを、WebSocketのメッセージに含めて表示装置4に送信する(ステップS184)。表示装置4の制御部141は、ステップS184で受信した通知データに記述された内容(例えば図7(b)に示す状況情報C2)を自装置の表示部に表示させる(ステップS185)。
When the
[1−5−1−4]状況情報の第4の送信動作
図15は、第4の方法が用いられる場合の各装置の動作の一例を示すシーケンス図である。第4の方法では、WebSocketにより状況情報が表示装置4へ通知される。この方法では、予め確立されたWebSocketセッション、例えば図14のステップS160で確立されたセッションが用いられる。情報処理装置10において予め定められた状況(トナー切れや用紙切れ、収容部オープンなど)が発生すると、情報処理装置10のミドルウェア層70及びハードウェア層80が協働して、その定められた状況を検知し(ステップS201)、検知した状況を表す状況情報をイベント通知部62に供給する(ステップS202)。イベント通知部62は、供給された状況情報を記述した通知データを生成し(ステップS203)、生成した通知データを、確立されているWebSocketのセッションを介して表示装置4にインターフェース50を介して送信する(ステップS204)。表示装置4の制御部141は、ステップS204で受信した通知データに記述された状況情報を自装置の表示部に表示させる(ステップS205)。
[1-5-1-4] Fourth Transmission Operation of Status Information FIG. 15 is a sequence diagram illustrating an example of the operation of each device when the fourth method is used. In the fourth method, status information is notified to the
なお、上述したように、表示装置4毎に異なる状況が通知されてもよい。その場合には、ステップS201のまえに、制御部141が、自装置に通知すべき状況を記述した通知データを情報処理装置10に通信部43を介して送信する。インターフェース50を介してそれを受け取ったイベント通知部62は、その通知すべき状況を表示装置4の宛先に対応付けて記憶しておく。イベント通知部62は、ステップS202で供給された状況情報が、記憶しておいた通知すべき状況を表している場合にその状況の通知を行う。
As described above, a different situation may be notified for each
[1−5−2]動作例1
図16は、情報処理システム1の具体的な動作の一例を示すシーケンス図である。この例では、ユーザU1が表示装置4を操作して、情報処理装置10にコピー処理を実行させる場合の動作例を説明する。この例では、表示装置4と情報処理装置10とのデータの遣り取りを行うための通信プロトコルとして、HTTP(第1通信プロトコルの一例)と、WebSocket(第2通信プロトコルの一例)が併用される。また、この例で、HTTPのBasic認証によりユーザ認証が行われる。
[1-5-2] Operation example 1
FIG. 16 is a sequence diagram illustrating an example of a specific operation of the
まず、ユーザU1は、表示装置4に対して、ウェブブラウザを起動して情報処理装置10のURLにアクセスする操作を行う。ステップS301において、表示装置4の制御部141は、ウェブブラウザを起動する。ステップS302において、制御部141は、情報処理装置10とTCP(Transmission Control Protocol)コネクション(第1通信路の一例)を確立する。このTCPコネクションは、HTTPのリクエストおよびレスポンスを送受信するための下位レイヤの通信プロトコルに用いられる。
First, the user U1 operates the
ステップS303において、制御部141は、情報処理装置10とTCPコネクションを確立し、確立したTCPコネクションを介してWebSocketのハンドシェイク要求であるHTTPリクエストを送信する。インターフェース50は、表示装置4から受信されたHTTPリクエストに基づき、WebSocketへの切り替えを行う。インターフェース50は、WebSocketのハンドシェイク応答を行い、これにより、表示装置4と情報処理装置10との間でWebSocketのセッション(第2通信路の一例)が確立される。
In step S303, the
ユーザは、情報処理装置10の画像読取部13に原稿をセットし、表示装置4に対してコピーを開始させる操作を行う。表示装置4の制御部141は、コピーを開始させる操作を受け付けると(ステップS304)、制御部141は、上述した第3の方法を申し込む旨を記述した通知要求データを含むHTTPリクエストを情報処理装置10に送信する(ステップS305)。情報処理装置10の受付・応答部61は、そのHTTPリクエストを受信すると、受信されたHTTPリクエストに含まれる通知要求データに記述された申込みの内容をミドルウェア層70に伝達する(ステップS306)。ミドルウェア層70は、伝達された申込みを受け付け、表示装置4に対して今後第3の方法で状態情報の送信を行うための設定を行う(ステップS307)。ミドルウェア層70は、例えば第3の方法で通知を行うか否かを表すフラグをONにする。
The user sets an original on the
次いで、制御部141は、受け付けた操作に応じた指示データを作成する(ステップS308)。制御部141は、作成した指示データを含む処理要求(HTTPリクエスト)を情報処理装置10に送信する(ステップS309)。情報処理装置10の受付・応答部61は、図8に示すインターフェース50を介して処理要求を受け取ると、受け付けた処理要求に含まれる指示データを解析することで、指示の内容を解釈する(ステップS310)。
Next, the
受付・応答部61が、解釈した内容に基づいてコピー処理をミドルウェア層70に指示すると(ステップS311)、ミドルウェア層70及びハードウェア層80が協働して、指示された内容に基づく処理(コピー処理)を実行する(ステップS312)。受付・応答部61は、コピー処理を指示したあと、コピー処理の要求を受け付けた旨を示すメッセージを生成する(ステップS313)。受付・応答部61は、生成したメッセージにシーケンスID(シーケンス番号の一例)とトランザクションIDとを付与する(ステップS314)。受付・応答部61は、IDが付与されたメッセージを含むHTTPリクエストを表示装置4に送信する(ステップS315)。なお、ステップS313ないしステップS315の動作は、ステップS310またはS311の動作の前に行われてもよい。
When the reception /
シーケンスIDは、個々のメッセージを識別する識別情報であり、送信されるメッセージの各々にそれぞれ異なるシーケンスIDが割り当てられる。一方、トランザクションIDは、処理単位で割り当てられる識別情報である。ひとつの処理が完了するまでに遣り取りされるメッセージには同一のトランザクションIDが付される。この例で、シーケンスIDは、複数のメッセージの各々に、メッセージが送信される順にインクリメントされた値が用いられる。また、この例で、シーケンスIDは、送信されるメッセージがHTTPで送信されるかWebSocketで送信されるかに関わらず、処理される順番を示す通し番号が付される。この例で、ステップS315で送信されるHTTPレスポンスに含まれるメッセージには、シーケンスIDとして「01」が付されている。 The sequence ID is identification information for identifying individual messages, and a different sequence ID is assigned to each message to be transmitted. On the other hand, the transaction ID is identification information assigned in units of processing. The same transaction ID is attached to messages exchanged until one process is completed. In this example, as the sequence ID, a value incremented in the order in which the messages are transmitted is used for each of the plurality of messages. In this example, the sequence ID is assigned a serial number indicating the processing order regardless of whether the message to be transmitted is transmitted by HTTP or WebSocket. In this example, “01” is assigned as the sequence ID to the message included in the HTTP response transmitted in step S315.
さて、情報処理装置10のミドルウェア層70及びハードウェア層80は、ステップS316(コピー出力の検知)の動作を行うと、上記フラグがONになっているため、コピーが媒体に出力されたという状況を示す状況情報を受付・応答部61ではなく、イベント通知部62に供給する(ステップS317)。イベント通知部62は、供給された状況情報(コピー枚数等)を記述した通知データを生成し(ステップS318)、生成したデータ(メッセージ)にシーケンスIDおよびトランザクションIDを付与する(ステップS319)。このメッセージに付与されるトランザクションIDは、ステップS314で付与されたトランザクションIDと同じ値である。一方、ステップS319でメッセージに付与されるシーケンスIDには、ステップS314で付与された値よりも処理順序が遅い旨を示す値が設定される。この例で、ステップS319でIDが付与されるメッセージには、シーケンスIDとして「02」が付される。
When the
イベント通知部62は、IDを付与したメッセージを、ステップS303で確立したWebSocketセッションを介して表示装置4に送信する(ステップS320)。
The
表示装置4の制御部141は、情報処理装置10からメッセージを受信する。制御部141は、受信されたメッセージのトランザクションIDおよびシーケンスIDに基づいて、受信されたメッセージに対応する処理の処理順序を特定する(ステップS321)。この例で、受信されるメッセージに対応する処理とは、受信されるメッセージに応じた状況情報の表示処理を含む。制御部141は、受信されたメッセージに対応する処理を、特定した処理順序で実行する。
The
図16に示す例では、ステップS315で送信されたメッセージが表示装置4に受信されるのに先立って、ステップS320で送信されたメッセージが表示装置4に受信される場合の動作を示している。表示装置4と情報処理装置10との間で遣り取りされるメッセージは、通信ネットワークを経由するため、メッセージが送信された順序とメッセージが受信される順序とが入れ替わる場合がある。
In the example illustrated in FIG. 16, the operation when the message transmitted in step S320 is received by the
上述したように、ステップS320で送信されたメッセージには、「02」のシーケンスIDが付されている。しかし、表示装置4は、このメッセージを受信したタイミングにおいて、このメッセージよりも処理順序の早い「01」のシーケンスIDが付されたメッセージを未だ受信していない。この例で、制御部141は、受信されていないメッセージがある場合に、そのメッセージが受信されるまで、そのメッセージより後の処理順序であるメッセージに対応する処理を実行しない。すなわち、制御部141は、シーケンスIDが「02」のメッセージを受信したものの、シーケンスIDが「01」のメッセージが未だ受信されていないため、シーケンスIDが「02」のメッセージに付されたトランザクションIDと同一のトランザクションIDが付されたメッセージであって、かつ、シーケンスIDが「01」のメッセージの受信を待機する(ステップS322)。
As described above, the sequence ID “02” is attached to the message transmitted in step S320. However, the
さて、ミドルウェア層70及びハードウェア層80は、コピー処理を完了すると(ステップS323)、その旨を示す状況情報をイベント通知部62に供給する(ステップS324)。イベント通知部62は、この状況情報を記述した通知データ(例えば「コピーが完了しました。」という文字列を含むデータ)を生成し(ステップS325)、生成したデータにシーケンスIDおよびトランザクションIDを付与する(ステップS326)。この例で、メッセージには、シーケンスIDとして「03」が付与される。イベント通知部62は、IDを付与したメッセージを、WebSocketセッションを介して表示装置4に送信する(ステップS327)。
When the
制御部141は、情報処理装置10からメッセージを受信する。制御部141は、受信されたメッセージのトランザクションIDおよびシーケンスIDに基づいて、受信されたメッセージに対応する処理の順序を特定する(ステップS328)。この例で、受信されたメッセージにはシーケンスIDとして「03」が付与されているものの、シーケンスIDが「01」のメッセージは未だ受信されていない。そのため、制御部141は、シーケンスIDが「01」のメッセージの受信を待機する(ステップS329)。
The
さて、ステップS329の後で、ステップS315で送信されたメッセージが表示装置4で受信される。この場合、制御部141は、受信されたメッセージに付されたトランザクションIDおよびシーケンスIDに基づいて、受信されたメッセージに対応する処理の順序を特定する(ステップS330)。シーケンスIDが「01」のメッセージが受信されたため、制御部141は、受信されたメッセージに対応する表示処理を実行する。すなわち、制御部141は、例えば指示された処理が受け付けられた旨を示す画面を表示部144に表示する。
Now, after step S329, the message transmitted in step S315 is received by the
続けて、制御部141は、既に受信されているメッセージに対応する表示処理を実行する。すなわち、制御部141は、シーケンスIDが「02」のメッセージに対応する表示処理(ステップS320で受信したメッセージに記述された内容(例えば図7(b)に示す状況情報C2)を表示部144に表示させる処理)を実行する(ステップS331)。また、制御部141は、シーケンスIDが「03」のメッセージに対応する表示処理(指示されたコピー処理が完了した旨を表示部144に表示させる処理)を実行する(ステップS332)。
Subsequently, the
ところで、複数の通信プロトコルを併用するソフトウェアにおいて、通信ネットワークを介して送信されるメッセージの受信順序が、送信された順序と入れ替わってしまう場合がある。この場合、メッセージが受信された順に各メッセージに対応する表示処理が実行された場合、表示が不適切なものとなってしまう場合がある。例えば、図16に示した例において、メッセージが受信された順に各メッセージに対応する表示処理が実行された場合、コピー処理が完了した旨の表示(図16のステップS332)がなされた後に、コピー処理の要求が受け付けられた旨の表示(ステップS330)が行われてしまい、ユーザを混乱させてしまう虞がある。それに対しこの実施形態では、複数の通信プロトコルのそれぞれの通信路を介して送信されるメッセージに、処理順序を示すシーケンスIDが付されることにより、処理順序が入れ替わってしまうことが防止される。 By the way, in software that uses a plurality of communication protocols, the reception order of messages transmitted via the communication network may be changed from the transmission order. In this case, when display processing corresponding to each message is executed in the order in which the messages are received, the display may be inappropriate. For example, in the example shown in FIG. 16, when display processing corresponding to each message is executed in the order in which the messages are received, the copy processing is completed (step S <b> 332 in FIG. 16) and then copied. A display indicating that the processing request has been accepted (step S330) is performed, which may confuse the user. On the other hand, in this embodiment, it is possible to prevent the processing order from being switched by attaching a sequence ID indicating the processing order to a message transmitted via each communication path of a plurality of communication protocols.
[2]変形例
上述した実施形態は、本発明の実施の一例に過ぎず、以下のように変形させてもよい。また、上述した実施形態及び以下に示す各変形例は、必要に応じて組み合わせて実施してもよい。
[2] Modification The above-described embodiment is merely an example of the present invention, and may be modified as follows. Moreover, you may implement combining embodiment mentioned above and each modification shown below as needed.
[2−1]メッセージに対応する処理のポリシー
上述の実施形態では、制御部141は、受信されていないメッセージ(以下「未受信メッセージ」という)がある場合に、その未受信メッセージが受信されるまで、その未受信メッセージの処理順序よりも後の処理を実行せずに待機した。処理のポリシーはこれに限られない。
[2-1] Policy of Processing Corresponding to Message In the above embodiment, when there is a message that has not been received (hereinafter referred to as “unreceived message”), the
例えば、制御部141は、未受信メッセージが受信されるまで待機し、かつ、予め定められた期間以上待機してもその未受信メッセージが受信されなかった場合、その未受信メッセージよりも後の処理順序であるメッセージに対応する処理を実行してもよい。
For example, the
また、他の例として、例えば、制御部141が、受信されていないメッセージがあるか否かに関わらず、受信されたメッセージに対応する処理を実行してもよい。この場合、制御部141は、メッセージが受信された場合、受信されたメッセージに対応する処理順序が、実行済である処理の処理順序よりも前のものである場合、受信されたメッセージに対応する処理を実行することなく、メッセージを破棄してもよい。
As another example, for example, the
また、他の例として、制御部141が、メッセージを複数受信して画面表示が追い付かない場合、メッセージに対応する処理を間引いて実行してもよい。例えば、コピー処理の進捗(10%、20%、30、…)を示すメッセージが複数受信された場合、制御部141が、全てのメッセージに対応する表示を行わずに、間引いて表示を行ってもよい。すなわち、制御部141が、対応する処理を未だ実行していない受信済のメッセージが複数ある場合、複数のメッセージの一部を選択し、選択したメッセージに対応する処理を実行してもよい。この場合、選択されなかったメッセージに対応する処理は実行されず、メッセージは破棄される。メッセージの選択の態様としては、例えば、制御部141は、予め定められたランダム関数に従ってメッセージをランダムに選択してもよく、また、複数のメッセージの中から属性が予め定められた条件を満たすものを選択してもよい。メッセージの属性としては、例えば、メッセージの優先度やメッセージの種別を示す情報が用いられてもよい。メッセージの属性は、情報処理装置10のミドルウェア層70、受付・応答部61および/またはイベント通知部62によってメッセージに付与されてもよい。この場合、制御部141は、受信されたメッセージの属性に応じてそのメッセージに対応する処理を実行するか否かを判定する。
As another example, when a plurality of messages are received and the screen display cannot catch up, the
また、制御部141が、要求する処理の種別に応じて上記ポリシーをいずれにするかを指示してもよい。この場合、制御部141が、どのポリシーを選択するかを示すパラメータを指示データに含めてもよい。
In addition, the
[2−2]通信の規格
実施形態では、ユーザ装置20は、無線LANの規格に準拠する無線通信を行う通信部を備えていたが、これに限らず、例えば操作装置30の通信部33と同様に有線LANの規格に準拠する通信を行う通信部を備えていてもよい。この場合、ユーザ装置20は、有線LANのルータやハブなどに通信用のケーブルを介して接続される。この場合のユーザ装置20の通信部も、上述した他の通信機器(ルータやハブなど)と通信する通信手段として機能する。
[2-2] Communication Standard In the embodiment, the
また、実施形態では、情報処理装置10の第1通信部と操作装置30の通信部が有線LANの規格に準拠して通信を行ったが、これに限らず、例えば、USB(Universal Serial Bus)やHDMI(登録商標)(High-Definition Multimedia Interface)などの規格に準拠する通信を行ってもよいし、他にも、無線LANやBluetooth(登録商標)、NFC(Near field communication)などの規格に準拠する無線通信を行ってもよい。いずれの場合も、操作装置30の通信部は、他のルータはハブなどの通信機器を介さずに情報処理装置10の第1通信部と通信する。このように、操作装置30の通信部は、他の通信機器を介さず情報処理装置10と通信する通信手段として機能する。
In the embodiment, the first communication unit of the
また、上述の実施形態では、情報処理装置10と表示装置4とは、HTTPおよびWebSocketの2種類の通信プロトコルを併用してデータの授受を行ったが、用いられる通信プロトコルはこれらに限られない。情報処理装置10と表示装置4とが用いる通信プロトコルは、表示装置4(ウェブクライアント)から送信される要求に対する応答を情報処理装置10(ウェブサーバ)が送信するための第1通信プロトコルと、情報処理装置10から表示装置4へ通知を送信するために第2通信プロトコルとを含むものであってもよい。
In the above-described embodiment, the
また、上述の実施形態において、情報処理装置10と表示装置4とは、SOAP(Simple Object Access Protocol)の規格に準拠したデータの授受を行ってもよい。また、情報処置装置10と表示装置4とがデータの授受を行う際に準拠するプロトコルはこれに限られない。情報処理装置10と表示装置4とは、例えばREST(Representational State Transfer)やSGML(Standard Generalized Markup Language)などの規格に準拠して通信してもよい。
Further, in the above-described embodiment, the
[2−3]操作装置の構成
操作装置30は、実施形態では図5に示すように制御部や記憶部、通信部を備えていたが、これらを備えていなくてもよい。
図17は、本変形例の情報処理装置10aのハードウェア構成の一例を示す図である。図17の例では、図6に示す各部のうち、操作装置30を除く各部を備える情報処理装置10aと、操作装置30aとが示されている。本変形例でも、操作装置30aは情報処理装置10aの筐体に固定されている。操作装置30aは、図5に示す通信部33と、UI部36とを備える。
[2-3] Configuration of Operating Device The operating
FIG. 17 is a diagram illustrating an example of a hardware configuration of the
通信部33及びUI部36は、情報処理装置10a内のバスに接続され、制御部11によって制御されるようになっている。また、通信部33は、第1通信部15とも接続されている。UI部36は、表示面と表示面に重ねられたタッチセンサとを備え、ユーザからの操作を受け付けるとともに画像を表示する。UI部36は、受け付けたユーザの操作に応じた操作データを制御部11に供給し、制御部11は、この操作データに応じた処理を行う。本変形例では、制御部11がブラウザのプログラムを実行することで図7に示す表示装置4の機能を実現する。
The
[2−4]操作装置の設置
操作装置は、実施形態や上記変形例では情報処理装置の筐体に固定されていたが、固定されていなくてもよい。例えば、操作装置が情報処理装置の筐体に固定されておらず、いわゆるリモコンとして用いられる装置であってもよい。
図18は、本変形例の情報処理装置10bのハードウェア構成の一例を示す図である。図18の例では、図6に示す各部のうち、操作装置30を除く各部を備える情報処理装置10bと、操作装置30bとが示されている。操作装置30bは、図5に示す各部を備え、図7に示す表示装置4として機能する装置である。情報処理装置10bの筐体には、操作装置30bを設置可能な形に形成された部分(以下「設置部」という)を有する。
[2-4] Installation of operating device The operating device is fixed to the housing of the information processing device in the embodiment and the above-described modified examples, but may not be fixed. For example, the controller device may be a device used as a so-called remote controller without being fixed to the housing of the information processing device.
FIG. 18 is a diagram illustrating an example of a hardware configuration of the
操作装置30bは、通信用のケーブルを介して第1通信部15に接続されており、設置部に設置された状態でユーザにより使用される。操作装置30bは、実施形態の操作装置30と同様に、他の通信機器を介さずに情報処理装置10と通信を行うローカルの表示装置4として用いられる。なお、ユーザは、操作装置30bからケーブルを取り外して、操作装置30bを別の場所に持って行き別の用途に用いてもよい。なお、図18の例では、操作装置30bに代えて、操作手段として機能する他の装置(例えば図1等に示したユーザ装置20)が接続されてもよい。また、操作装置30bを、通信機器3に接続させて、通信機器3及び通信回線2を介して情報処理装置10bと通信させてもよい。
The operating
[2−5]情報処理装置10が行う処理
上述の実施形態では、コピー処理を行う場合の動作について説明したが、情報処理装置10が行う処理はコピー処理に限られない。情報処理装置10が行う処理は、例えば上述した画像読取処理であってもよく、また、画像形成処理であってもよい。
[2-5] Process Performed by
[2−6]操作の受付方法
上述の実施形態では、制御部21は、タッチセンサでユーザの操作を受け付けたが、ユーザの操作を受け付ける方法はこれに限られない。例えば、表示装置4がタブレット端末であれば筐体に設けられたボタンで操作を受け付けてもよい。また、表示装置4がパーソナルコンピュータであればキーボードやマウスなどで操作を受け付けてもよい。
[2-6] Operation Accepting Method In the above-described embodiment, the
[2−7]メッセージの送信
イベント通知部62は、実施形態では、WebSocketの規格に準拠する通知データを送信したが、これに限らない。例えば、Cometと呼ばれる技術を用いて、表示装置4のUI制御部41が送信してきたHTTPリクエストをイベント通知部62が維持し、送信すべきメッセージ(状況情報の更新など)が発生することを契機に、イベント通知部62が、維持していたHTTPリクエストへの応答で状況情報を送信してもよい。Cometを用いた方法だと、実施形態と同様に、操作用装置からの要求が行われたときにその応答でこの送信が行われる場合に比べて、処理の状況がユーザに早く伝達されることになる。
[2-7] Transmission of Message In the embodiment, the
[2−8]発明のカテゴリ
本発明は、情報処理装置、表示装置、通信機器及びこれらの装置を備える情報処理システムの他にも、これらの装置が実施する処理を実現するための情報処理方法としても捉えられるものである。また、本発明は、情報処理装置及び表示装置というコンピュータを、上述した各手段として機能させるためのプログラムとしても捉えられるものである。このプログラムは、それを記憶させた光ディスク等の記録媒体の形態で提供されたり、インターネット等の通信回線を介して、コンピュータにダウンロードさせ、それをインストールして利用可能にするなどの形態でも提供されたりするものであってもよい。
[2-8] Category of Invention In addition to an information processing device, a display device, a communication device, and an information processing system including these devices, the present invention provides an information processing method for realizing processing performed by these devices. It can be seen as. The present invention can also be understood as a program for causing a computer called an information processing apparatus and a display apparatus to function as the above-described units. This program is provided in the form of a recording medium such as an optical disk storing the program, or in the form of being downloaded and installed on a computer via a communication line such as the Internet, etc. It may be a thing to do.
1…情報処理システム、2…通信回線、3…通信機器、4…表示装置、10…情報処理装置、20…ユーザ装置、30…操作装置、11、21、31…制御部、12、22、32…記憶部、13…画像読取部、14…画像形成部、15…第1通信部、16…第2通信部、17…接続部、23、33…通信部、24、34…表示部、25、35…操作部、101…第1確立手段、102…第2確立手段、103…第1受信手段、104…第1処理実行手段、105…付与手段、106…第1送信手段、107…第2送信手段、401…第3確立手段、402…第4確立手段、403…第3送信手段、404…第2受信手段、405…第3受信手段、406…特定手段、407…第2処理実行手段。
DESCRIPTION OF
Claims (9)
前記ソフトウェアと、前記第1通信プロトコルと異なる第2通信プロトコルによる第2通信路を確立する第2確立手段と、
前記ソフトウェアから前記第1通信路を介して処理の実行要求を受信する受信手段と、
前記受信された実行要求に従って前記処理を実行する処理実行手段と、
前記実行要求を受け付けた旨を示す第1メッセージおよび前記処理の処理状況を示す第2メッセージに、当該処理を識別するトランザクション番号、並びに、当該第1メッセージおよび当該第2メッセージを含むメッセージ群における各メッセージの処理順序を示すシーケンス番号を付与する付与手段と、
前記トランザクション番号および前記シーケンス番号が付与された第1メッセージを、前記処理の完了を待機することなく前記第1通信路により前記ソフトウェアへ送信する第1送信手段と、
前記処理の実行中および前記処理が完了したときに、前記トランザクション番号および前記シーケンス番号が付与された第2メッセージを前記第2通信路により前記ソフトウェアへ送信する第2送信手段と
を有する情報処理装置。 Software functioning as a client; first establishing means for establishing a first communication path using a request / response type first communication protocol;
A second establishing means for establishing a second communication path by a second communication protocol different from the software and the first communication protocol;
Receiving means for receiving a processing execution request from the software via the first communication path;
Processing execution means for executing the processing according to the received execution request;
The first message and a second message indicating the processing status of the processing indicating that accepts the execution request, the transaction number for identifying the process, as well, each in the message group including the first message and the second message An assigning means for assigning a sequence number indicating the processing order of messages;
First transmission means for transmitting the first message assigned with the transaction number and the sequence number to the software through the first communication path without waiting for completion of the processing ;
An information processing apparatus comprising: a second transmission unit configured to transmit the second message assigned with the transaction number and the sequence number to the software through the second communication path during execution of the process and when the process is completed. .
前記ソフトウェアと、前記第1通信プロトコルと異なる第2通信プロトコルによる第2通信路を確立する第2確立手段と、
前記ソフトウェアへ前記第1通信路を介して処理の実行要求を送信する第1送信手段と、
前記ソフトウェアから前記第1通信路を介して前記実行要求を受け付けた旨を示す第1メッセージを受信する第1受信手段と、
前記ソフトウェアから前記第2通信路を介して前記処理の実行中における処理状況および前記処理の完了を示す第2メッセージを受信する第2受信手段と、
前記受信された第1メッセージおよび前記受信された第2メッセージの各々に付された、前記送信された実行要求に対応する処理を識別するトランザクション番号、および、当該第1メッセージおよび当該第2メッセージを含むメッセージ群における各メッセージの処理順序を示すシーケンス番号に基づいて、当該第1メッセージおよび当該第2メッセージの処理順序を特定する特定手段と、
前記受信された第1メッセージおよび前記受信された第2メッセージのそれぞれに対応する処理を、前記特定された処理順序で実行する処理実行手段と
を有する情報処理装置。 Software functioning as a server; first establishing means for establishing a first communication path by a request / response type first communication protocol;
A second establishing means for establishing a second communication path by a second communication protocol different from the software and the first communication protocol;
First transmission means for transmitting a process execution request to the software via the first communication path;
First receiving means for receiving a first message indicating that the execution request has been received from the software via the first communication path;
Second receiving means for receiving, from the software, a second message indicating a processing status during execution of the processing and completion of the processing via the second communication path;
A transaction number for identifying a process corresponding to the transmitted execution request, attached to each of the received first message and the received second message, and the first message and the second message. A specifying means for specifying the processing order of the first message and the second message based on a sequence number indicating the processing order of each message in the message group including:
An information processing apparatus comprising: a process execution unit that executes processes corresponding to each of the received first message and the received second message in the specified processing order.
請求項2に記載の情報処理装置。 The information processing apparatus according to claim 2, wherein the processing execution unit does not execute processing corresponding to the first message and the second message in a processing order after the first message or the second message that has not been received from the software. .
請求項3に記載の情報処理装置。 If the first message or the second message that has not been received has not been received even after waiting for a predetermined period or longer, the process execution means is subsequent to the first message or the second message that has not been received. The information processing apparatus according to claim 3, wherein processing corresponding to a first message and a second message that are processing orders is executed.
請求項2に記載の情報処理装置。 When the processing order corresponding to the received first message or the second message is earlier than the processing order of the processing that has been executed, the processing execution means is configured to receive the received first message or second message. The information processing apparatus according to claim 2, wherein processing corresponding to two messages is not executed.
請求項2ないし5のいずれか1項に記載の情報処理装置。 When there are a plurality of received first messages and second messages for which the corresponding processing has not yet been executed, the processing execution means has at least one of the plurality of first messages and second messages. The information processing apparatus according to any one of claims 2 to 5, wherein a process corresponding to at least one of a first message and a second message satisfying a predetermined condition for an attribute is executed.
第2情報処理装置と
を有し、
前記第1情報処理装置は、
クライアントとして機能する第1ソフトウェアと、リクエスト/レスポンス型の第1通信プロトコルによる第1通信路を確立する第1確立手段と、
前記第1ソフトウェアと、前記第1通信プロトコルと異なる第2通信プロトコルによる第2通信路を確立する第2確立手段と、
前記第1ソフトウェアから前記第1通信路を介して処理の実行要求を受信する第1受信手段と、
前記受信された実行要求に従って前記処理を実行する第1処理実行手段と、
前記実行要求を受け付けた旨を示す第1メッセージおよび前記処理の処理状況を示す第2メッセージに、当該処理を識別するトランザクション番号、並びに、当該第1メッセージおよび当該第2メッセージを含むメッセージ群における各メッセージの処理順序を示すシーケンス番号を付与する付与手段と、
前記トランザクション番号および前記シーケンス番号が付与された第1メッセージを、前記処理の完了を待機することなく前記第1通信路により前記第1ソフトウェアへ送信する第1送信手段と、
前記処理の実行中および前記処理が完了したときに、前記トランザクション番号および前記シーケンス番号が付与された第2メッセージを前記第2通信路により前記第1ソフトウェアへ送信する第2送信手段と
を備え、
前記第2情報処理装置は、
サーバとして機能する第2ソフトウェアと、前記第1通信プロトコルによる前記第1通信路を確立する第3確立手段と、
前記第2ソフトウェアと、前記第1通信プロトコルと異なる前記第2通信プロトコルによる前記第2通信路を確立する第4確立手段と、
前記第2ソフトウェアへ前記第1通信路を介して処理の実行要求を送信する第3送信手段と、
前記第2ソフトウェアから前記第1通信路を介して前記実行要求を受け付けた旨を示す第1メッセージを受信する第2受信手段と、
前記第2ソフトウェアから前記第2通信路を介して前記送信された実行要求に対応する処理の実行中における処理状況および前記処理の完了を示す第2メッセージを受信する第3受信手段と、
前記受信された第1メッセージおよび前記受信された第2メッセージの各々に付された、前記送信された実行要求に対応する処理を識別するトランザクション番号、および、当該第1メッセージおよび当該第2メッセージを含むメッセージ群における各メッセージの処理順序を示すシーケンス番号に基づいて、当該第1メッセージおよび当該第2メッセージの処理順序を特定する特定手段と、
前記受信された第1メッセージおよび前記受信された第2メッセージのそれぞれに対応する処理を、前記特定された処理順序で実行する第2処理実行手段と
を備える
システム。 A first information processing device;
A second information processing device,
The first information processing apparatus
A first software functioning as a client; a first establishing means for establishing a first communication path by a request / response type first communication protocol;
A second establishing means for establishing a second communication path by a second communication protocol different from the first software and the first communication protocol;
First receiving means for receiving a process execution request from the first software via the first communication path;
First process execution means for executing the process according to the received execution request;
The first message and a second message indicating the processing status of the processing indicating that accepts the execution request, the transaction number for identifying the process, as well, each in the message group including the first message and the second message An assigning means for assigning a sequence number indicating the processing order of messages;
First transmission means for transmitting the first message assigned with the transaction number and the sequence number to the first software through the first communication path without waiting for completion of the processing ;
A second transmission unit configured to transmit the second message to which the transaction number and the sequence number are assigned to the first software through the second communication path during execution of the process and when the process is completed ;
The second information processing apparatus
A second software functioning as a server, and a third establishing means for establishing the first communication path by the first communication protocol,
It said second software, and a fourth establishing means for establishing the second communication path according to the first communication protocol is different from said second communication protocol,
Third transmission means for transmitting a process execution request to the second software via the first communication path;
Second receiving means for receiving a first message indicating that the execution request has been accepted from the second software via the first communication path;
Third receiving means for receiving a second message indicating the processing status and the completion of the processing during execution of the processing corresponding to the execution request transmitted from the second software via the second communication path;
A transaction number for identifying a process corresponding to the transmitted execution request, attached to each of the received first message and the received second message, and the first message and the second message. A specifying means for specifying the processing order of the first message and the second message based on a sequence number indicating the processing order of each message in the message group including:
And a second process execution unit configured to execute processes corresponding to each of the received first message and the received second message in the specified process order.
クライアントとして機能するソフトウェアと、リクエスト/レスポンス型の第1通信プロトコルによる第1通信路を確立するステップと、
前記ソフトウェアと、前記第1通信プロトコルと異なる第2通信プロトコルによる第2通信路を確立するステップと、
前記ソフトウェアから前記第1通信路を介して処理の実行要求を受信するステップと、
前記受信された実行要求に従って前記処理を実行するステップと、
前記実行要求を受け付けた旨を示す第1メッセージおよび前記処理の処理状況を示す第2メッセージに、当該処理を識別するトランザクション番号、並びに、当該第1メッセージおよび当該第2メッセージを含むメッセージ群における各メッセージの処理順序を示すシーケンス番号を付与するステップと、
前記トランザクション番号および前記シーケンス番号が付与された第1メッセージを、前記処理の完了を待機することなく前記第1通信路により前記ソフトウェアへ送信するステップと、
前記処理の実行中および前記処理が完了したときに、前記トランザクション番号および前記シーケンス番号が付与された第2メッセージを前記第2通信路により前記ソフトウェアへ送信するステップと
を実行させるためのプログラム。 On the computer,
A software functioning as a client; and establishing a first communication path using a request / response type first communication protocol;
Establishing a second communication path with the software and a second communication protocol different from the first communication protocol;
Receiving an execution request for processing from the software via the first communication path;
Executing the process in accordance with the received execution request;
The first message and a second message indicating the processing status of the processing indicating that accepts the execution request, the transaction number for identifying the process, as well, each in the message group including the first message and the second message Assigning a sequence number indicating the message processing order;
Transmitting the first message with the transaction number and the sequence number to the software via the first communication path without waiting for the completion of the processing ;
A program for executing the step of transmitting the second message to which the transaction number and the sequence number are assigned to the software through the second communication path during execution of the process and when the process is completed .
サーバとして機能するソフトウェアと、リクエスト/レスポンス型の第1通信プロトコルによる第1通信路を確立するステップと、
前記ソフトウェアと、前記第1通信プロトコルと異なる第2通信プロトコルによる第2通信路を確立するステップと、
前記ソフトウェアへ前記第1通信路を介して処理の実行要求を送信するステップと、
前記ソフトウェアから前記第1通信路を介して前記実行要求を受け付けた旨を示す第1メッセージを受信するステップと、
前記ソフトウェアから前記第2通信路を介して前記処理の実行中における処理状況および前記処理の完了を示す第2メッセージを受信するステップと、
前記受信された第1メッセージおよび前記受信された第2メッセージの各々に付された、前記送信された実行要求に対応する処理を識別するトランザクション番号、および、当該第1メッセージおよび当該第2メッセージを含むメッセージ群における各メッセージの処理順序を示すシーケンス番号に基づいて、当該第1メッセージおよび当該第2メッセージの処理順序を特定するステップと、
前記受信された第1メッセージおよび前記受信された第2メッセージのそれぞれに対応する処理を、前記特定された処理順序で実行するステップと
を実行させるためのプログラム。 On the computer,
A software functioning as a server; and establishing a first communication path using a request / response type first communication protocol;
Establishing a second communication path with the software and a second communication protocol different from the first communication protocol;
Transmitting a process execution request to the software via the first communication path;
Receiving a first message indicating that the execution request has been accepted from the software via the first communication path;
Receiving from the software a second message indicating a processing status during execution of the processing and completion of the processing via the second communication path;
A transaction number for identifying a process corresponding to the transmitted execution request, attached to each of the received first message and the received second message, and the first message and the second message. Identifying the processing order of the first message and the second message based on a sequence number indicating the processing order of each message in the message group including:
Executing a process corresponding to each of the received first message and the received second message in the specified processing order.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2014193650A JP6488608B2 (en) | 2014-09-24 | 2014-09-24 | Information processing apparatus, system, and program |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2014193650A JP6488608B2 (en) | 2014-09-24 | 2014-09-24 | Information processing apparatus, system, and program |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2016066167A JP2016066167A (en) | 2016-04-28 |
JP6488608B2 true JP6488608B2 (en) | 2019-03-27 |
Family
ID=55804176
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2014193650A Active JP6488608B2 (en) | 2014-09-24 | 2014-09-24 | Information processing apparatus, system, and program |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP6488608B2 (en) |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP6825439B2 (en) * | 2017-03-22 | 2021-02-03 | 富士ゼロックス株式会社 | Terminal devices, information information systems and programs |
JP6802777B2 (en) * | 2017-11-24 | 2020-12-23 | 株式会社カカクコム | Methods, programs and systems for requesting execution of processing with improved fault tolerance and responding as a result. |
Family Cites Families (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH11184784A (en) * | 1997-12-19 | 1999-07-09 | Fuji Xerox Co Ltd | Server with execution situation reporting function and client with execution situation displaying function |
JP3944229B2 (en) * | 2000-12-28 | 2007-07-11 | フューチャーアーキテクト株式会社 | Framework system |
JP4363204B2 (en) * | 2004-02-04 | 2009-11-11 | ヤマハ株式会社 | Communication terminal |
JP2009239444A (en) * | 2008-03-26 | 2009-10-15 | Mitsubishi Electric Corp | Packet sequence control method, receiver, transmitter, and communicating system |
US8560696B2 (en) * | 2009-04-28 | 2013-10-15 | Intel Corporation | Transmission of advanced-MAP information elements in mobile networks |
-
2014
- 2014-09-24 JP JP2014193650A patent/JP6488608B2/en active Active
Also Published As
Publication number | Publication date |
---|---|
JP2016066167A (en) | 2016-04-28 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP6471441B2 (en) | Information processing apparatus, system, and program | |
JP6451175B2 (en) | Image processing apparatus, system, and program | |
US9092704B2 (en) | Image forming system, image forming apparatus, and recording medium | |
JP5743671B2 (en) | Information processing apparatus and control method thereof | |
JP2012090077A (en) | Portable terminal, and method for operating processing apparatus | |
JP6040878B2 (en) | Printing apparatus, printing control apparatus, printing system, and program | |
US9377981B2 (en) | Image forming system that sends schedule information of image forming apparatus over network | |
JP5817766B2 (en) | Information processing apparatus, communication system, and program | |
JP6488608B2 (en) | Information processing apparatus, system, and program | |
JP6561444B2 (en) | Information processing apparatus, information processing system, and program | |
US20180097944A1 (en) | Information processing apparatus | |
JP6476685B2 (en) | INFORMATION PROCESSING DEVICE, INFORMATION PROCESSING SYSTEM, DISPLAY DEVICE, AND PROGRAM | |
JP6492486B2 (en) | Information processing apparatus, information processing system, and program | |
JP6471440B2 (en) | Information processing apparatus, information processing system, and program | |
JP6471439B2 (en) | Information processing apparatus, system, and program | |
JP6424538B2 (en) | INFORMATION PROCESSING APPARATUS, INFORMATION PROCESSING SYSTEM, AND PROGRAM | |
JP6341016B2 (en) | Image forming system, image forming apparatus, and program | |
JP2016066159A (en) | Information processing device, information processing system, and program | |
JP2008294792A (en) | Multifunction device | |
JP2017063372A (en) | Information processing device and program | |
KR20180001294A (en) | System and method of providing mobile printing | |
JP2005301611A (en) | Parameter processor and parameter setting method therefor | |
JP2005192106A (en) | Service processing apparatus, service processing system, and input terminal | |
JP2009187540A (en) | System and method for managing state information of document processor |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20170831 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20180427 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20180508 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20180705 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20181113 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20190109 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20190129 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20190211 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 6488608 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
S533 | Written request for registration of change of name |
Free format text: JAPANESE INTERMEDIATE CODE: R313533 |
|
R350 | Written notification of registration of transfer |
Free format text: JAPANESE INTERMEDIATE CODE: R350 |