|Número de publicación||US20060021068 A1|
|Tipo de publicación||Solicitud|
|Número de solicitud||US 11/165,995|
|Fecha de publicación||26 Ene 2006|
|Fecha de presentación||27 Jun 2005|
|Fecha de prioridad||12 Sep 2000|
|También publicado como||US6915425, US20020108049|
|Número de publicación||11165995, 165995, US 2006/0021068 A1, US 2006/021068 A1, US 20060021068 A1, US 20060021068A1, US 2006021068 A1, US 2006021068A1, US-A1-20060021068, US-A1-2006021068, US2006/0021068A1, US2006/021068A1, US20060021068 A1, US20060021068A1, US2006021068 A1, US2006021068A1|
|Inventores||Bin Xu, Weijun Li, Kyle Smith, Dalun Bao|
|Cesionario original||Bin Xu, Weijun Li, Kyle Smith, Dalun Bao|
|Exportar cita||BiBTeX, EndNote, RefMan|
|Citas de patentes (5), Citada por (40), Clasificaciones (11)|
|Enlaces externos: USPTO, Cesión de USPTO, Espacenet|
This application is related to co-pending U.S. patent application Ser. No. 09/659,902, filed Sep. 12, 2000, entitled “System for Managing Rights and Permitting On-Line Playback of Digital Content” which is hereby incorporated by reference as if set forth in full in this application.
This invention relates to the field of information processing and more particularly to systems for implementing off-line digital management rights.
Increased use of electronic computer networks, such as the Internet has resulted in a fundamental problem now facing content providers, namely, the problem of how to prevent the unauthorized use and distribution of digital content. These content providers include publishers of video games, music, books, medical information, information database providers, and providers of interactive web players. Examples of interactive web players currently available on the market are Quicktime 4™ available from Apple Computer, Inc.®, RealPlayer™ available from RealNetworks, Inc.® and Shockwave 7™ available from MacroMedia, Inc.®.
These content providers are concerned with getting compensated for their work. Unauthorized copying and use of content providers works deprives rightful owners of billions of dollars according to a well-known source. Unauthorized copying is exercebated because consumers can easily retrieve content, and technology is available for perfectly reproducing content.
A number of mechanisms have been developed to protect against unauthorized access and duplication and to provide digital rights management. One method is a digital rights management system that allows a set of rules to determine how the content is used. Another method (for software) for curbing unauthorized duplication is the use of a scheme which provides software tryouts or demos that typically work and expire after a specific duration. Other methods use a copy protection scheme that limits the number of copies that a user can make, after which additional copying results in corrupt copies. Further, an alternate scheme requires the presence of a license on a client workstation for the software to operate.
Many of the aforementioned schemes are typically implemented using “encryption/decryption” of the digital content. Encryption is the conversion of data into an unintelligible form, e.g., ciphertext, that cannot be easily understood by unauthorized users. Decryption is the process of converting encrypted content back into its original form such that the it becomes intelligible. Simple ciphers include the rotation of letters in the alphabet, the substitution of letters for numbers, and the “scrambling” of voice signals by inverting the sideband frequencies. More complex ciphers work according to sophisticated computer algorithms that rearrange the data bits in digital information content.
In order to easily recover the encrypted information content, the correct decryption key is required. The key is an algorithm that decodes the work of the encryption algorithm. The more complex the encryption algorithm, the more difficult it becomes to decode the communications without access to the key. Generally, there are two types of key schemes for encryption/decryption systems, namely (1) Public Key Systems (PKS) or asymmetric systems which utilize two different keys, one for encryption, or signing, and one for decryption, or verifying; and (2) nonpublic key systems that are known as symmetric, or secret key, systems.
Although the use of public or private key can be an effective way to prevent access to digital content, the transfer of keys often requires extensive coordination with the end user. Also, the use of keys in the related art does not always provide flexible licensing arrangements, or an efficient way to handle many instances of different deliverable digital content products.
Therefore, there is a need to resolve the aforementioned problem relating to conventional approaches for protecting digital information particularly with regard to managing the digital rights for off-line distribution of interactive web content and music.
A system for permitting off-line playback of digital content files, and for managing related content rights. The system comprises a content builder for encrypting the content files to prevent unauthorized access to the files, and a license module for generating a license which authorizes the user to playback the file. Advantageously, the system permits verification of the license while the user is offline, and permits decryption of the content file to permit offline playback of the content files.
In a first embodiment, the system comprises a method for permitting offline playback of a content file on a user computing device upon offline verification of the terms of a license for authorizing the playback of the content file. The method comprises the steps of identifying the license by using one or more information fields within the header, verifying the terms of the license locally on the user computing device while the user is offline, retrieving from the license, a session key for decrypting the content file, retrieving from the license, a segment which is part of the content file, decrypting the content file using the session key to permit playback of the content file for a single session, and combining the segment with the content file to permit playback of the content file.
A system for enabling the off-line playback of content files by an authorized user system, and for managing the rights to digital content files within a computer network. The system includes a content builder for encrypting the content files to prevent unauthorized access to the files. The system encrypts the files by using one or more keys which are associated with one or more segments of the content file. These keys enable an authorized user to decrypt and playback the content files at a subsequent time. When the keys are received by an end user's system, it retrieves a license from a license server which specifies the rights of the user as it relates to the content files. Therefore, at the very least, one or more keys and a license are required in order for a user to play back a content file. In this manner, the present system manages digital rights pertaining to such content files in accordance with one embodiment of the present invention. As used herein, the term “content” refers to digital information. The present invention will be further understood with reference to the diagrams and descriptions which follow.
Embodiments of the Present Invention
When content file 106 is received, content builder 116 utilizes an encryption algorithm to implement the encryption process. In one embodiment, this process is accomplished by segmenting content file 106 into variable segments, each segment being encrypted with a separate key. A “key” may be a variable value that is applied to content file 106 using an algorithm to produce encryption text. A single key or multiple keys having constant or variable lengths may be employed depending on which embodiment is implemented. After the encryption process, the keys are saved in database 102 for later retrieval during the playback process. In an exemplary embodiment, database 102 is an industry standard database system such as Oracle 8™ available from Oracle, Inc.® Content builder 116 also functions to interact with database 102 to create the necessary information to enable the sale, distribution and tracking of the content within system 100.
Advantageously, during the encryption process, content builder 116 removes a portion of content file 106 and in its place inserts a header (not shown), supplied by DRM encoder 110. The removed portion is thereafter added to a license file for authorizing playback of the content file 106. Therefore, the removed portion is considered part of the keys. Depending on the embodiment being implemented, the removed portion may be added to a pre-configured license, the terms of which are predefined. During the playback process, the pre-configured license is then retrieved when its terms are the same as the user's transaction. Alternatively, the removed portion may be saved and later added to a license which is generated on the fly during the playback process. In any event, once the license is obtained, the removed portion is thereafter recombined with the original content portion during the playback process.
Advantageously, removing a portion of content file 106 also provides a measure of extra security as the removed portion of content file 106 remains unavailable until decryption time. Therefore, copying encrypted content to another machine is completely useless without the back binding license. In this manner, the process of seeking a specific location in content file 106 during the decryption process is simplified. The header within content file 106 contains information fields such as the license name, the content file identification, and the license server URL (uniform resource locator).
The license name field enables content file 106 to be associated with the license file (containing the removed content portion). The content identification field identifies the content file 106 while the license server URL points to the address of the license server where the license is generated (or located). Although a multiple-field header is not shown, one of ordinary skill in the art will realize that the header may contain multiple fields for identifying various types of information other than those referenced above.
Alternatively, a module which implements the functionality of DRM proxy 208 may be combined with content player 212, in which case, content player 211 functions as single unit that retrieves and plays the encrypted content file. Examples of content players which are currently available on the market are Quicktime 4™ available from Apple Computer, Inc.®, RealPlayer™ available from RealNetworks, Inc.® and Shockwave 7™ available from MacroMedia, Inc.®. Although not shown, one of ordinary skill in the art will realize that various permutations of modules and modes for retrieving encrypted content 204 are possible.
In operation, after a user consummates a purchase transaction, content files 304 are delivered to and stored on the user's local disk. Of course, along with content files 304, a license (not shown) that grants the rights to play the content is also downloaded and stored within license store 318. At this point, the user may defer playback of the content, until a subsequent time that is convenient. It should be observed that content files 304 as well as the license remain encrypted, and are dynamically decrypted on the fly whenever the user initiates playback.
Upon initiation of the off-line playback process (via a user interface, not shown, for example), content player 308 begins by retrieving a first portion of encrypted content files 304 from the user's local disk. The first portion of the retrieved content file, contains a content header (described in
Because the requested key is contained within the license, DRM core 314 must identify the appropriate license. This is accomplished by reading the content header to identify the license name, and the content identification. In an alternate embodiment, when the license is not stored locally, the header may contain the URL of a license server (not shown) wherein the license is located. In addition, license data generator 316 provides DRM core 314 with a machine identification which is unique to the end user's machine for comparison with the header information.
Using all of the obtained information, DRM core 314 retrieves the license from license store 318. DRM core 314 verifies the terms of the license, and retrieves the session key which is contained within the license. Advantageously, the session key is a single session key, meaning that it enables playback of the encrypted files only for a single session. After retrieving the session keys, DRM core 314 passes the key securely back to player module 310. In turn, player module 310 forwards the key and encrypted content files 304 to DRM decoder 312 which executes the decryption process and returns the decrypted files to player module 310. Finally, content player 310 passes the decrypted content files content player 308 for playback. In this manner, the present invention permits license verification while the user is offline.
It should be noted that the preceding steps are only performed for the first portion of encrypted content after which subsequent portions are automatically played back. Further, it should be observed that there are implications for the player module 310 when it hands encrypted content to the decoder module 312, because content is encrypted on a frame-by-frame basis. This makes seeking a specific location and the content a little more difficult and, as such, the decoder module may be provided with API (application programming interface) to aid the caller in dealing with these frames. In this manner, the present invention enables system 300 to upload encrypted content files 304 and play back those content files using a content player module 310. Advantageously, system 300 allows only authorized users to playback content files in accordance with one embodiment.
In a typical operation, the user purchases content such as music recordings (for example) from the store front at a website (not shown). Numerous websites are available for purchasing various types of digital content including Disney.com®, Sony.com®, and Shockwave.com®, for example. Using a web browser or a program that is capable of posting a web form to server 416, the user initiates the transaction with the appropriate website. The transaction typically involves several round trips to the web site with the transaction concluding with a request for a box file 402. Box file 402 is a file that describes the content requested by the user, and in one embodiment has a .cBox extension.
DRM proxy 404 contains a box file handler and is registered with system 400 as the handler for files with the .cBox extension. When box file 402 is received, DRM proxy 404 directs module 406 to build a license request message for forwarding to license server 416. In one embodiment, this request is in XML (extensible markup language) format. Module 406 queries the machine identification to be included in the license request. Thereafter, DRM proxy 404 starts a network job which sends the license request message to license server 416. License server 416, in one embodiment is a CGI (common gateway interface) program available through license server 416.
Upon receipt of the license request, license server 416 verifies that the content file has been purchased prior to continuing with the processing of the license request data base 414 contains the terms of the license along with the keys for decrypting the content file. These terms are retrieved and forwarded to license generator 418. It should be observed that a different license generator is implemented for each digital rights management solution being employed on client side 422. License generator 418 generates the license which includes the terms of the license. Also included within the license, are the keys for decrypting the content file.
It should be observed that the content decryption keys are bound to the particular machine located on the client side 422. By way of example, particular information that is unique to the machine such as the machine identification number is bound to the license. In this way, the present invention implements a machine-binding solution which allows digital content playback only on a particular machine. Upon receiving the license from license generator 418, license server 416 forwards the license over the network to DRM proxy 404. In turn, DRM proxy forwards the license to module 406 for DRM-specific processing. DRM core 408 retrieves the license and stores the license within database 412.
Although not shown, the process for retrieving a license may occur subsequent to a purchase transaction such as when the user wishes to play back content offline. Further, license acquisition can also occur when there is no financial transaction involved; for example, when the user requests a trial license. A trial license permits a user to utilize the content files for a specific period after which the trial license expires. Table 1 below illustrates exemplary steps taken by system 400 to acquire a license when there is no financial transaction involved.
TABLE 1 1. A content player (not shown) asks DRM core 408 to play a content. 2. DRM core 408 checks its local store, e.g., license store 412, and finds there is no valid license available (it finds no license or license is expired). 3. DRM core 408 fields a license request message with the machine identification. 4. DRM core 408 invokes DRM proxy 404 to send a license request message. 5. DRM proxy starts a network job to send a license request message to license server 416. 6. License server 416 presents a page to collect license terms desired by the user and supported by system 400 before continuing with the processing of license request. 7. The terms of the license are collected and sent to data base 414. 8. The license request, along with the terms of the license and keys for decryption, are retrieved from data base 414 and are dispatched to license generator 418. 9. The license is generated from the obtained information. 10. The license data is returned to server 416. 11. License data is returned over the network to the DRM proxy 404. 12. DRM proxy 404 passes the license response message to DRM 406 for DRM-specific processing. 13. DRM module 406 via DRM core 408 saves the license data in its license store 412.
The present invention advantageously separates a portion of the content from the original content file until decryption time to prevent unauthorized content usage. Moreover, licenses are bound to particular machines so that copying the content to a machine other than the authorized machine is futile, The present invention also utilizes a secure data channel in which the content keys are passed in secured format. Code obfuscation is used to hide code that handles decrypted data.
Other advantages include the implementation of the DRM core and the DRM decoder within separate modules to increase the complexity for hackers, and the employment of session key-based on-line license verification to maximize security. In this manner, the system of the present invention manages rights to one or more digital content files within a computer network and limits the playback of such content files to an authorized user. Furthermore, the present invention facilitates distribution and content production, which ultimately results in a shorter product development cycle.
Description of Hardware
As with the external physical configuration shown in
Note that the concepts of “client” and “server,” as used in this application and the industry, are very loosely defined and, in fact, are not fixed with respect to machines or software processes executing on the machines. Typically, a server is a machine or process that is providing information to another machine or process, i.e., the “client,” that requests the information. In this respect, a computer or process can be acting as a client at one point in time (because it is requesting information) and can be acting as a server at another point in time (because it is providing information). Some computers are consistently referred to as “servers” because they usually act as a repository for a large amount of information that is often requested. For example, a World Wide Web (WWW, or simply, “Web”) site is often hosted by a server computer with a large storage capacity, high-speed processor and Internet link having the ability to handle many high-bandwidth communication lines.
A server machine will most likely not be manually operated by a human user on a continual basis, but, instead, has software for constantly, and automatically, responding to information requests. On the other hand, some machines, such as desktop computers, are typically thought of as client machines because they are primarily used to obtain information from the Internet for a user operating the machine.
Depending on the specific software executing at any point in time on these machines, the machine may actually be performing the role of a client or server, as the need may be. For example, a user's desktop computer can provide information to another desktop computer. Or a server may directly communicate with another server computer. Sometimes this is characterized as “peer-to-peer,” communication. Although processes of the present invention, and the hardware executing the processes, may be characterized by language common to a discussion of the Internet (e.g., “client,” “server,” “peer”) it should be apparent that software of the present invention can execute on any type of suitable hardware including networks other than the Internet.
Although software of the present invention, may be presented as a single entity, such software is readily able to be executed on multiple machines. That is, there may be multiple instances of a given software program, a single program may be executing on two or more processors in a distributed processing environment, parts of a single program may be executing on different physical machines, etc. Further, two different programs, such as a client and server program, can be executing in a single machine, or in different machines. A single program can be operating as a client for one information transaction and as a server for a different information transaction.
While the above is a complete description of exemplary specific embodiments of the invention, additional embodiments are also possible. Thus, the above description should not be taken as limiting the scope of the invention, which is defined by the appended claims along with their full scope of equivalents.
|Patente citada||Fecha de presentación||Fecha de publicación||Solicitante||Título|
|US5093914 *||15 Dic 1989||3 Mar 1992||At&T Bell Laboratories||Method of controlling the execution of object-oriented programs|
|US5222134 *||9 Abr 1991||22 Jun 1993||Tau Systems Corporation||Secure system for activating personal computer software at remote locations|
|US5530752 *||22 Feb 1994||25 Jun 1996||Convex Computer Corporation||Systems and methods for protecting software from unlicensed copying and use|
|US5673316 *||29 Mar 1996||30 Sep 1997||International Business Machines Corporation||Creation and distribution of cryptographic envelope|
|US20010011254 *||15 Dic 1998||2 Ago 2001||Jonathan Clark||Distributed execution software license server|
|Patente citante||Fecha de presentación||Fecha de publicación||Solicitante||Título|
|US7681245 *||30 Ago 2002||16 Mar 2010||Avaya Inc.||Remote feature activator feature extraction|
|US7707116||30 Ago 2002||27 Abr 2010||Avaya Inc.||Flexible license file feature controls|
|US7707405||21 Sep 2004||27 Abr 2010||Avaya Inc.||Secure installation activation|
|US7747851||30 Sep 2004||29 Jun 2010||Avaya Inc.||Certificate distribution via license files|
|US7814023||8 Sep 2005||12 Oct 2010||Avaya Inc.||Secure download manager|
|US7836511||14 Jun 2006||16 Nov 2010||Microsoft Corporation||Enforcing advertisement playback for downloaded media content|
|US7844572||30 Oct 2007||30 Nov 2010||Avaya Inc.||Remote feature activator feature extraction|
|US7885896||9 Jul 2002||8 Feb 2011||Avaya Inc.||Method for authorizing a substitute software license server|
|US7890997||20 Ene 2003||15 Feb 2011||Avaya Inc.||Remote feature activation authentication file system|
|US7913301||30 Oct 2006||22 Mar 2011||Avaya Inc.||Remote feature activation authentication file system|
|US7936873||7 May 2007||3 May 2011||Apple Inc.||Secure distribution of content using decryption keys|
|US7966520||30 Ago 2002||21 Jun 2011||Avaya Inc.||Software licensing for spare processors|
|US7975310||14 Jun 2006||5 Jul 2011||Microsoft Corporation||Offline playback of advertising supported media|
|US8041642||10 Jul 2002||18 Oct 2011||Avaya Inc.||Predictive software license balancing|
|US8171565 *||18 Ago 2009||1 May 2012||Condel International Technologies Inc.||Systems and methods for locally generating license and activating DRM agent|
|US8190918||13 Nov 2006||29 May 2012||Disney Enterprises, Inc.||Interoperable digital rights management|
|US8224751||3 May 2006||17 Jul 2012||Apple Inc.||Device-independent management of cryptographic information|
|US8229858||4 Feb 2005||24 Jul 2012||Avaya Inc.||Generation of enterprise-wide licenses in a customer environment|
|US8306918 *||11 Oct 2005||6 Nov 2012||Apple Inc.||Use of media storage structure with multiple pieces of content in a content-distribution system|
|US8347098||22 May 2007||1 Ene 2013||Apple Inc.||Media storage structures for storing content, devices for using such structures, systems for distributing such structures|
|US8620819||30 Oct 2009||31 Dic 2013||Avaya Inc.||Remote feature activator feature extraction|
|US8646102 *||15 Sep 2006||4 Feb 2014||Oracle America, Inc.||Method and apparatus for issuing rights in a digital rights management system|
|US8769698 *||5 Ene 2007||1 Jul 2014||Kabushiki Kaisha Toshiba||Apparatus and method for playback of digital content|
|US8837908 *||6 Ene 2009||16 Sep 2014||Cyberlink Corp.||Systems and methods for performing secure playback of media content|
|US8913750 *||20 Feb 2012||16 Dic 2014||Sandisk Technologies Inc.||Method for managing keys and/or rights objects|
|US8964972||3 Sep 2009||24 Feb 2015||Colin Gavrilenco||Apparatus, method, and system for digital content and access protection|
|US9027161 *||19 Feb 2014||5 May 2015||Ricoh Company, Ltd||System, method, and computer-readable recording medium for supporting license acquirement|
|US20040128551 *||20 Ene 2003||1 Jul 2004||Walker William T.||Remote feature activation authentication file system|
|US20060242083 *||26 Jun 2006||26 Oct 2006||Avaya Technology Corp.||Method and apparatus for license distribution|
|US20070067851 *||15 Sep 2006||22 Mar 2007||Fernando Gerard M||Method and apparatus for issuing rights in a digital rights management system|
|US20070083473 *||11 Oct 2005||12 Abr 2007||Farrugia Augustin J||Use of media storage structure with multiple pieces of content in a content-distribution system|
|US20070241176 *||13 Abr 2006||18 Oct 2007||Epstein Johnny S||Method and apparatus for delivering encoded content|
|US20090083856 *||5 Ene 2007||26 Mar 2009||Kabushiki Kaisha Toshiba||Apparatus and method for playback of digital content|
|US20100241855 *||17 Mar 2009||23 Sep 2010||Cyberlink Corp.||Systems and Methods for Secure Execution of Code Using a Hardware Protection Module|
|US20110047615 *||18 Ago 2009||24 Feb 2011||Condel International Technologies Inc.||Systems and methods for locally generating license and activating drm agent|
|US20120159644 *||20 Feb 2012||21 Jun 2012||Oktay Rasizade||Method for Managing Keys and/or Rights Objects|
|US20130047264 *||11 May 2011||21 Feb 2013||St-Ericsson Sa||Method and Device for Communicating Digital Content|
|US20140173762 *||19 Feb 2014||19 Jun 2014||Ricoh Company, Ltd.||System, method, and computer-readable recording medium for supporting license acquirement|
|WO2008136876A2 *||16 Ene 2008||13 Nov 2008||Apple Inc||Secure distribution of content using decryption keys|
|WO2015102877A1 *||16 Dic 2014||9 Jul 2015||Adam Elia Kidron||Method and system for playback of audio content using wireless mobile device|
|Clasificación de EE.UU.||726/30|
|Clasificación internacional||H04L29/06, G06F17/30|
|Clasificación cooperativa||H04L2463/101, H04L63/0457, G06F21/10, H04L63/102, G06F2221/2107|
|Clasificación europea||H04L63/04B6, G06F21/10, H04L63/10B|