Method for mobile printing

Information

  • Patent Application
  • 20030063749
  • Publication Number
    20030063749
  • Date Filed
    October 03, 2001
    23 years ago
  • Date Published
    April 03, 2003
    21 years ago
Abstract
In a method for mobile printing, a mobile device generates a symmetrical pair of encryption keys and transmits the first encryption key and a print request to an imaging device. When the mobile device receives a request from the imaging device for the second encryption key, the mobile device transmits the second encryption key to the imaging device. The imaging device then uses the second encryption key to decrypt encrypted rendered content and prints the content.
Description


[0001] The present invention relates generally to mobile electronic devices and imaging devices.


[0002] Mobile electronic devices, such as mobile phones and personal digital assistants (PDA's), enjoy widespread popularity. The capabilities and functionality of these devices also continue to increase. For example, many of these devices have Internet browsing capability, which affords access to a wide variety of content and commercial service opportunities.


[0003] One drawback with mobile electronic devices is that their limited memory, display and bandwidth capabilities restrict the type and amount of content readily available to a device user. Typically, content is formatted specifically for a mobile electronic device in a manner designed to conserve device resources. In general, rich or data-intensive content is avoided in favor of more streamlined content.


[0004] In the field of printing, these resource limitations of mobile electronic devices restrict printing opportunities. In general, the traditional printing model involves pushing content resident on an electronic device, such as a PC, to an imaging device. Many imaging devices, such as personal inkjet printers, must receive the content rendered in a printer-ready format, such as PCL-3 or other page description language. Thus, the electronic device sending the print request must first convert the content into the appropriate printer-ready format.


[0005] One attempt to increase the printing capabilities of mobile electronic devices involves referencing data content resident on a remote content provider, sometimes known as “print-by-reference”. In one example of the print-by-reference printing model, the user of a mobile device sends a print-by-reference print request to an imaging device. The print-by-reference request may include, for example, a uniform resource locator (URL) address for the content to be printed. The imaging device transmits the request to a remote print service. The print service retrieves the content from a content provider, renders the content into the printer-ready format appropriate for the imaging device and transmits the content to the imaging device for printing. A more detailed description of the print-by-reference printing model is available in U.S. patent applications Ser. No. 09/897,693 entitled PRINT BY REFERENCE SERVICE COMMUNICATION PROTOCOL AND INTERFACE and Ser. No. 09/897,646 entitled PORTABLE WIRELESS DEVICE AND PRINT DEVICE PRINT BY REFERENCE PROTOCOL, both applications assigned to Hewlett-Packard Co. Both of these applications are incorporated herein by reference in their entirety.


[0006] The mobility of the user of a mobile electronic device in the print-by-reference printing model presents potential challenges. For example, a mobile phone user waiting in an airport may desire to print a document using the print-by-reference model. The user may send a print-by-reference print request to an airport printer and wait for the printed output. Perhaps traffic is heavy on the print service or the airport printer has previous print requests in its queue. For these and various other reasons, there may be a delay in executing the user's print request. If during this delay the user must leave the area, perhaps to catch a flight, the print job will be printed despite the user's absence. In another situation, the user may be present when the print job is received by the imaging device, but may be unable to wait for the entire print job to be printed. Thus, it would be desirable to provide an improved printing method that addresses these types of situations and gives the user greater control over the printing process.






BRIEF DESCRIPTION OF THE DRAWINGS

[0007]
FIG. 1 is a block diagram of an exemplary wireless printing configuration that may be utilized in practicing the methods of the present invention.


[0008]
FIGS. 2 and 3 are a flow chart of the steps of one embodiment of the present invention.


[0009]
FIG. 4 is a flow chart of the steps of one aspect of an embodiment of the present invention.







DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

[0010]
FIG. 1 illustrates an embodiment of a wireless printing configuration 100 that may be utilized to practice the methods of the present invention. The wireless printing configuration 100 includes a mobile electronic device 102 and an imaging device 106. The imaging device may comprise, for example, an inkjet or electrophotographic printer, a fax machine, a multi-function printer/copier/scanner device, a copier, a video printer or the like. The mobile electronic device 102 may comprise, for example, a PDA, a mobile phone, a laptop PC, a wireless data terminal, or other such device with like capabilities. The mobile electronic device 102 includes a processor 110 and a memory 116, both of which are coupled to a local interface 119. The local interface may be, for example, a data bus with an accompanying control/address bus as is generally know by those with ordinary skill in the art.


[0011] The mobile device 102 also includes a wireless interface 124 that is coupled to the local interface 119 and facilitates wireless communication with the imaging device 106 and other wireless devices and/or networks. The wireless interface 124 may include, for example, a wireless modem and an appropriate network card that may be employed to transmit data to and receive data from the imaging device 106 and across the network 150. Any of various wireless communication protocols may be utilized by the mobile device 102, including but not limited to infrared, Bluetooth RF protocol and IEEE 802.11 RF protocol. The network 150 may comprise, for example, the Internet, wide area networks, local area networks or other similar networks.


[0012] The memory 116 stores several components that are executable by the processor 110. These components include, for example, an operating system 126, a print-by-reference application 128 and cryptography or encryption logic 132. The operating system 126 is executed to control the allocation and usage of hardware resources in the mobile device 102. For example, the operating system 126 controls the allocation and usage of the memory 116 and processing time, as well as performing other functionality as is generally know by those with ordinary skill in the art.


[0013] The print-by-reference application 128 may operate to execute a print-by-reference printing model. For example, the user of the mobile device 102 may transmit a print-by-reference print request to the imaging device 106. The print-by-reference print request may contain, for example, a URL address of the content to be printed. The imaging device 106 transmits the print request to a print service 156 over the network 150. The print service 156 retrieves the content identified in the print request, such as from a content provider 160, renders the retrieved content into a format appropriate for the imaging device 106 and transmits the rendered content to the imaging device for printing.


[0014] The encryption logic 132 is utilized to generate one or more encryption keys that are in turn utilized to encrypt and decrypt data. It will be appreciated that the encryption logic 132 may comprise any one of various encryption technologies well known to one of ordinary skill in the art. An example of an encryption technology commonly used with the Internet is the Secure Sockets Layer (SSL) protocol.


[0015] With reference now to one embodiment of the present invention, where a user of the mobile device 102 desires greater control over a print-by-reference print request, the print-by-reference application 128 may utilize the encryption logic 132 to generate encryption keys for encrypting and decrypting the content to be printed. In one embodiment of the present invention, the encryption logic 132 operates in the context of a print-by-reference print request to generate a symmetrical pair of encryption keys. With reference now to FIGS. 2 and 3, a flow chart of one embodiment of the method of the present invention is illustrated. Beginning with block 200, the encryption logic 132 in the mobile device 102 generates a symmetrical pair of encryption keys including a first encryption key and a second encryption key. The first and second encryption keys may be stored in the memory 116 on the mobile device 102. In block 202 the print-by-reference application 128 generates a print request that includes an address or location of the content to be printed, such as a URL. In block 204 the mobile device 102 transmits the first encryption key and the print request to the imaging device 106.


[0016] In block 206 the imaging device 106 transmits the print request and the first encryption key to a print service 156. The print service 156 retrieves the content identified in the print request, such as from a content provider 160 (block 208). It will be appreciated that the content may also reside within the print service 156. The print service 156 then renders the retrieved content into a format appropriate for the imaging device 106 (block 210), creating rendered content. In block 212 the print service 156 encrypts the rendered content with the first encryption key to create encrypted rendered content. In block 214 the print service 156 then transmits the encrypted rendered content to the imaging device 106.


[0017] Upon receiving the encrypted rendered content, in block 216 the imaging device 106 transmits a request for the second encryption key to the mobile device 102. Upon receiving the request from the imaging device 106, in block 218 the mobile device transmits the second encryption key to the imaging device. In block 220 the imaging device 106 decrypts the encrypted rendered content with the second encryption key to create decrypted rendered content. In block 222 the imaging device 106 then prints the decrypted rendered content.


[0018] In another embodiment of the present invention, the mobile device 102 may transmit the first encryption key, the print request, the address of an imaging device and the address of the mobile device directly to a print service 156 over the network 150. With reference to FIGS. 2 and 3, in this embodiment steps 204 and 206 would be replaced by the step of the mobile device transmitting the first encryption key, the print request, the address of the imaging device 106 and the address of the mobile device directly to the print service 156. Step 214 would also include transmitting the address of the mobile device 102 from the print service 156 to the imaging device 106. The remainder of the steps 208-222 would remain the same.


[0019] To complete the print request transmitted from the mobile device 102, the imaging device 106 must receive the second encryption key from the mobile device to decrypt the encrypted rendered content received from the print service 156. With reference now to FIG. 4, one embodiment that is directed to this aspect of the present invention is illustrated. Beginning with block 216, and assuming that the imaging device 106 has received the encrypted rendered content from the print service 156, the imaging device transmits a request for the second encryption key to the mobile device 102. The imaging device then starts a predetermined time period (block 230) and determines whether it has received the second encryption key from the mobile device 102 (block 232). If it has not received the second encryption key, then it determines whether the predetermined time period has expired (block 234). If the predetermined time period has expired, then the imaging device cancels the print request (block 236). In this case, because the mobile device did not respond to the request to transmit the second encryption key, this may indicate that the user of the mobile device is no longer near the imaging device 106, and perhaps has left the area. Advantageously in this situation, the print request is canceled and the content requested by the user of the mobile device is not printed. Additionally, the encrypted rendered content received by the imaging device remains encrypted, thereby protecting the content from undesired disclosure.


[0020] With continued reference to FIG. 4, block 234, if the predetermined time period has not expired, then the imaging device 106 again determines whether the second encryption key has been received (block 232). If the second encryption key has been received, then the imaging devices uses the second encryption key to decrypt the encrypted rendered content to create decrypted rendered content (block 220). In block 222 the imaging device 106 then prints the decrypted rendered content.


[0021] With reference to FIG. 1, it will be appreciated that the memory 116 may include both volatile and nonvolatile memory and data storage components. Volatile components are those that do not retain data values upon loss of power. Nonvolatile components are those that retain data upon a loss of power. Thus, the memory 116 may comprise, for example, random access memory (RAM), read-only memory (ROM), hard disk drives, floppy disks accessed via an associated floppy disk drive, compact discs accessed via a compact disc drive, magnetic tapes accessed via an appropriate tape drive, and/or other memory components, or a combination of any two or more of these memory components. In addition, the RAM may comprise, for example, static random access memory (SRAM), dynamic random access memory (DRAM), or magnetic random access memory (MRAM) and other such devices. The ROM may comprise, for example, a programmable read-only memory (PROM), an erasable programmable read-only memory (EPROM), an electrically erasable programmable read-only memory (EEPROM), or other like memory devices.


[0022] The method of printing of the present invention may be embodied in software or code executed by general purpose hardware as discussed above, or may be embodied in dedicated hardware or a combination of software/general purpose hardware and dedicated hardware. If embodied in hardware, the method of printing may be expressed or implemented as a circuit or state machine that employs any one of or a combination of a number of technologies. These technologies may include, but are not limited to, discrete logic circuits having logic gates for implementing various logic functions upon an appliation of one or more data signals, application specific integrated circuits (ASICs)having approprite logic gates, programmable gate arrays (PGAs), field programmable gate arrays (FPGAs), or other components. Such technologies are generally well known by those of ordinary skill in the art.


[0023] The block diagrams of FIGS. 2-4 show the architecture, functionality and operation of an implementation of the method of printing of the present invention. If embodied in software, each block may represent a module, segment or portion of code that comprises program instructions to implement the specified logical function(s). The program instructions may be embodied in the form of source code that comprises human-readable statements written in a programming language or machine code that comprises numerical instructions recognizable by a suitable execution system such as a processor in a computer system or other system. The machine code may be converted from the source code, etc. If embodied in hardware, each block may represent a circuit or a number of interconnected circuits to implement the specified logical funtion(s).


[0024] While the block diagrams of FIGS. 2-4 may show a specific order of execution, it will be appreciated that two or more steps in the diagrams that are shown executed in succession may be executed concurrently or with partial concurrence. In addition, any number of conunters, state variables, warning semaphores, or messages might be added to the logical flow described herein, for purposes of enhanced utility, accounting, performance measurement, troubleshooting, etc. It is understood that all such variations are within the scope of the present invention. The block diagrams of FIGS. 2-4 are relatively self-explanatory and may be utilized by one of ordinary skill in the art to create software and/or hardware to carry out the various logical functions described and illustrated.


[0025] Where the method of the present invention comprises software or code, it may be embodied in any computer-readable medium for use by or in connection with an instruction execution system such as, for example, a processor in a computer system or other system. In this sense, the method of the present invention may comprise, for example, statements including instructions and declarations that may be fetched from the computer-readable medium and executed by the instruction execution system. In the context of the present invention, a “computer-readable medium” may be any medium that can contain, store or otherwise maintain the method of the present invention for use by or in connection with an instruction execution system. The computer-readable medium may comprise any one of many physical media such as, for example, electronic, magnetic, optical, electromagnetic, infrared, or semiconductor media. More specific examples of a suitable computer-readable medium would include, but are not limited to, magnetic tapes, magnetic floppy diskettes, magnetic hard drives and compact discs. Also, the computer-readable medium may be a random access memory (RAM) including, for example, static random access memory (SRAM), dynamic random access memory (DRAM), or magnetic random access memory (MRAM). In addition, the computer-readable medium may be a read-only memory (ROM), a programmable read-only memory (PROM), an erasable programmable read-only memory (EPROM), an electrically erasable programmable read-only memory (EEPROM), or other type of memory device.


[0026] It will be appreciated that a variety of other equivalent modifications and substitutions may be made to the method of the present invention according to the concepts covered herein, depending upon the particular implementation, while still falling within the scope of the claims below.


Claims
  • 1. A method of printing using a mobile device, comprising: generating a symmetrical pair of encryption keys including a first encryption key and a second encryption key; generating a print request; transmitting the first encryption key, the print request, an address of an imaging device and an address of the mobile device to a print service; receiving a request from the imaging device for the second encryption key; and transmitting the second encryption key to the imaging device, whereby the imaging device uses the second encryption key to decrypt encrypted rendered content to create decrypted rendered content and prints the decrypted rendered content.
  • 2. The method of claim 1, wherein the print request includes a uniform resource locator that indicates a location of content to be printed.
  • 3. The method of claim 1, wherein the steps of transmitting the first encryption key, the print request, an address of an imaging device and an address of the mobile device to a print service and transmitting the second encryption key to the imaging device each comprise transmitting using a wireless communication protocol.
  • 4. The method of claim 1, further comprising the step of storing the first encryption key and the second encryption key in memory on the mobile device.
  • 5. A method of printing using a mobile device, comprising: generating a symmetrical pair of encryption keys including a first encryption key and a second encryption key; generating a print request; transmitting the first encryption key and the print request to an imaging device; receiving a request from the imaging device for the second encryption key; and transmitting the second encryption key to the imaging device, whereby the imaging device uses the second encryption key to decrypt encrypted rendered content to create decrypted rendered content and prints the decrypted rendered content.
  • 6. A method of printing, comprising: generating on a mobile device a symmetrical pair of encryption keys, the pair including a first encryption key and a second encryption; generating a print request on the mobile device; transmitting the first encryption key and the print request to an imaging device; transmitting the first encryption key and the print request from the imaging device to a print service; retrieving content identified in the print request; rendering the content to create rendered content; encrypting the rendered content with the first encryption key to create encrypted rendered content; transmitting the encrypted rendered content from the print service to the imaging device; transmitting a request for the second encryption key from the imaging device to the mobile device; transmitting the second encryption key from the mobile device to the imaging device; decrypting the encrypted rendered content using the second encryption key to create decrypted rendered content; and printing the decrypted rendered content.
  • 7. A method of printing on an imaging device, comprising: receiving a first encryption key and a print request from a mobile device; transmitting the first encryption key and the print request to a print service; receiving encrypted rendered content from the print service; requesting a second encryption key from the mobile device; receiving the second encryption key from the mobile device; decrypting the encrypted rendered content using the second encryption key to create a decrypted rendered content; and printing the decrypted rendered content.
  • 8. The method of claim 7, wherein the first encryption key and the second encryption key comprise a symmetrical pair of encryption keys.
  • 9. The method of claim 7, wherein the print request includes a uniform resource locator that indicates a location of content to be printed.
  • 10. The method of claim 7, wherein the steps of receiving the first encryption key and the print request and receiving the second encryption key each comprise receiving via a wireless communication protocol.
  • 11. The method of claim 7, further comprising the step of storing the first encryption key and the second encryption key in memory on the imaging device.
  • 12. A method of processing a print request on an imaging device, comprising: receiving a first encryption key and a print request from a mobile device; transmitting the first encryption key and the print request to a print service; receiving encrypted rendered content from the print service; requesting a second encryption key from the mobile device; and after a predetermined period during which the second encryption key is not received from the mobile device, canceling the print request.
  • 13. The method of claim 12, wherein the first encryption key and the second encryption key comprise a symmetrical pair of encryption keys.
  • 14. The method of claim 12, wherein the print request includes a uniform resource locator that indicates a location of content to be printed.
  • 15. The method of claim 12, wherein the step of receiving the first encryption key and the print request comprises receiving via a wireless communication protocol.
  • 16. The method of claim 12, further comprising the step of storing the first encryption key in memory on the imaging device.
  • 17. The method of claim 12, further comprising the steps of: after requesting a second encryption key from the mobile device, determining whether the second encryption key has been received; and if the second encryption key has not been received, then determining whether the predetermined period has expired.
  • 18. The method of claim 12, further comprising the step of: if the second encryption key is received before the predetermined period has expired, then decrypting the encrypted rendered content using the second encryption key to create a decrypted rendered content and printing the decrypted rendered content.
  • 19. A method of printing on an imaging device, comprising: receiving encrypted rendered content and an address of a mobile device from a print service; requesting an encryption key from the mobile device; receiving the encryption key from the mobile device; decrypting the encrypted rendered content using the encryption key to create a decrypted rendered content; and printing the decrypted rendered content.
  • 20. A computer program product for mobile printing comprising: code that generates a symmetrical pair of encryption keys, the pair including a first encryption key and a second encryption key; code that generates a print request; code that transmits the first encryption key and the print request to an imaging device; code that receives a request from the imaging device for the second encryption key; and code that transmits the second encryption key to the imaging device, whereby the imaging device uses the second encryption key to decrypt encrypted rendered content to create decrypted rendered content and prints the decrypted rendered content.