FR2881302A1 - METHOD AND SYSTEM FOR PROTECTING COPIES OF TRANSIT-READED FILE DATA (STREAMING) - Google Patents
METHOD AND SYSTEM FOR PROTECTING COPIES OF TRANSIT-READED FILE DATA (STREAMING) Download PDFInfo
- Publication number
- FR2881302A1 FR2881302A1 FR0500650A FR0500650A FR2881302A1 FR 2881302 A1 FR2881302 A1 FR 2881302A1 FR 0500650 A FR0500650 A FR 0500650A FR 0500650 A FR0500650 A FR 0500650A FR 2881302 A1 FR2881302 A1 FR 2881302A1
- Authority
- FR
- France
- Prior art keywords
- terminal
- receiver
- data
- file
- application
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims abstract description 41
- 238000004891 communication Methods 0.000 claims abstract description 72
- 238000012545 processing Methods 0.000 claims abstract description 54
- 230000005540 biological transmission Effects 0.000 claims abstract description 42
- 238000001514 detection method Methods 0.000 claims abstract description 14
- 238000005516 engineering process Methods 0.000 claims abstract description 14
- 238000012795 verification Methods 0.000 claims description 20
- 239000000872 buffer Substances 0.000 claims description 14
- 230000006870 function Effects 0.000 claims description 13
- 239000000470 constituent Substances 0.000 claims description 12
- 230000015654 memory Effects 0.000 claims description 12
- 238000009434 installation Methods 0.000 claims description 8
- 230000000007 visual effect Effects 0.000 claims description 7
- 230000000306 recurrent effect Effects 0.000 claims description 6
- 230000000903 blocking effect Effects 0.000 claims description 5
- 238000005070 sampling Methods 0.000 claims description 5
- 230000008859 change Effects 0.000 claims description 4
- 238000010348 incorporation Methods 0.000 claims description 4
- 230000006978 adaptation Effects 0.000 claims description 2
- 238000012360 testing method Methods 0.000 description 8
- 238000010586 diagram Methods 0.000 description 4
- 239000003086 colorant Substances 0.000 description 2
- 238000007726 management method Methods 0.000 description 2
- 230000004044 response Effects 0.000 description 2
- 238000013515 script Methods 0.000 description 2
- 238000006243 chemical reaction Methods 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 239000012464 large buffer Substances 0.000 description 1
- 238000012423 maintenance Methods 0.000 description 1
- 238000012544 monitoring process Methods 0.000 description 1
- 230000008569 process Effects 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
- 238000010200 validation analysis Methods 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/12—Applying verification of the received information
- H04L63/123—Applying verification of the received information received data contents, e.g. message integrity
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/10—Protecting distributed programs or content, e.g. vending or licensing of copyrighted material ; Digital rights management [DRM]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/61—Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio
- H04L65/612—Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio for unicast
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/75—Media network packet handling
- H04L65/752—Media network packet handling adapting media to network capabilities
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/75—Media network packet handling
- H04L65/762—Media network packet handling at the source
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/75—Media network packet handling
- H04L65/764—Media network packet handling at the destination
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L2463/00—Additional details relating to network architectures or network communication protocols for network security covered by H04L63/00
- H04L2463/101—Additional details relating to network architectures or network communication protocols for network security covered by H04L63/00 applying security measures for digital rights management
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Security & Cryptography (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Computer Hardware Design (AREA)
- General Engineering & Computer Science (AREA)
- Technology Law (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Computing Systems (AREA)
- Information Transfer Between Computers (AREA)
Abstract
La présente invention concerne un procédé et un système de protection contre la copie de données représentatives d'au moins un fichier (M), dit média, transmises par au moins un terminal (1), dit fournisseur, vers au moins terminal (2) dit récepteur, via au moins un réseau (10) de communication, selon une technologie permettant la lecture d'une partie du fichier (M), par une application (200), dite de lecture de données en transit, exécutée sur des moyens (20) de traitement du terminal (2) récepteur, avant la fin de la transmission (90) de l'intégralité du fichier (M), caractérisé en ce qu'il comporte au moins une étape d'exécution (73), sur les moyens (20) de traitement du terminal (2) récepteur, d'une application (201) de vérification des moyens (22) de mémorisation du terminal (2) récepteur, mise en oeuvre de façon récurrente pour détecter si une variation de l'espace de stockage entre deux détections excède une taille prédéterminée et, le cas échéant, bloquer la transmission (90) du fichier (M).The present invention relates to a method and a system for protecting against the copy of data representative of at least one file (M), called media, transmitted by at least one terminal (1), said provider, to at least terminal (2) said receiver, via at least one communication network (10), according to a technology allowing the reading of a part of the file (M), by an application (200), called a data read-in-transit, executed on means ( 20) for processing the receiver terminal (2), before the end of the transmission (90) of the entire file (M), characterized in that it comprises at least one execution step (73), on the means (20) for processing the receiver terminal (2), an application (201) for checking the means (22) for storing the receiver terminal (2), implemented recurrently to detect whether a variation of the storage space between two detections exceeds a predetermined size and, if necessary, t, block the transmission (90) of the file (M).
Description
Procédé et système de protection contre la copie de données deMethod and system for protecting against the copying of data from
fichiers transmis par lecture en transit ( streaming ) La présente invention concerne le domaine de l'électronique et plus particulièrement de la diffusion de fichiers média par téléchargement à la demande sur un terminal client connecté à un serveur. The present invention relates to the field of electronics and more particularly to the broadcast of media files by download on demand on a client terminal connected to a server.
Le domaine de la diffusion de fichiers média est aujourd'hui très développé et de nombreux fournisseurs de fichiers médias proposent désormais des téléchargements de musiques ou de vidéos à la demande. Ce téléchargement peut consister en un envoi par Internet du fichier complet vers le terminal de l'utilisateur ou en une technique appelée streaming , en anglais (traduisible par lecture en transit en français) et consistant à to ce que le terminal de l'utilisateur qui reçoit le fichier le lit pendant le téléchargement. Au cours du streaming , les données reçues sont placées dans une mémoire tampon qui est lue pendant la réception des données suivantes. Un premier problème dans le domaine de la diffusion de fichiers média concerne le piratage des vidéos et des musiques téléchargées par Internet. Les utilisateurs peu soucieux des droits d'auteurs copient les vidéos et les musiques qu'ils téléchargent et les diffusent à d'autres utilisateurs. Les fournisseurs de fichiers médias, notamment de fichiers média payants, sont donc confrontés au problème de vouloir diffuser des fichiers média sans que ceux-ci puissent être copiés par les utilisateurs qui le téléchargent. Il est connu dans l'art antérieur des solutions utilisant un cryptage des données constitutives du fichier mais ces solutions sont facilement contournables par les utilisateurs qui usent de maintes ruses pour contourner le cryptage. Le streaming permet éventuellement d'éviter que l'intégralité du fichier ne soit stockée dans le terminal de l'utilisateur et donc que ce dernier ne copie le fichier média, mais cette solution est contournable par les utilisateurs qui possèdent des applications (par exemple de capture d'écran) permettant d'enregistrer le fichier média pendant sa lecture sur le terminal. Un second problème concerne le streaming qui doit être adapté à la capacité de débit de la connexion de l'utilisateur téléchargeant le fichier. En effet, en fonction de la vitesse de la connexion et de sa fiabilité, la mémoire tampon utilisée pendant le streaming peut être lue entièrement alors que les données suivantes ne sont pas encore reçues, si la vitesse de téléchargement est inférieure à la vitesse de lecture ou si le téléchargement a été momentanément interrompu ou ralenti. Une connexion très lente nécessite donc l'utilisation d'une mémoire tampon de taille importante pour le streaming ou l'envoi du fichier complet sans lecture en cours de transit. The field of media file delivery is now very well developed and many media file providers now offer downloads of music or video on demand. This download may consist of an Internet transmission of the complete file to the user's terminal or a technique called streaming, in English (translatable by reading in transit in French) and consisting in that the terminal of the user who receives the file reads it during the download. During streaming, the received data is placed in a buffer that is read during the reception of the following data. A first problem in the field of media file broadcasting concerns the piracy of videos and music downloaded via the Internet. Non-copyright users copy the videos and music they download and broadcast to other users. The suppliers of media files, including paid media files, are therefore faced with the problem of wanting to broadcast media files without these being copied by the users who download it. It is known in the prior art solutions using encryption of data constituting the file but these solutions are easily avoided by users who use many tricks to circumvent the encryption. Streaming possibly prevents the entire file from being stored in the user's terminal and therefore the user does not copy the media file, but this solution can be circumvented by users who have applications (for example screenshot) to save the media file while it is playing on the terminal. A second problem concerns the streaming which must be adapted to the throughput capacity of the connection of the user downloading the file. Indeed, depending on the speed of the connection and its reliability, the buffer used during the streaming can be read entirely while the following data are not yet received, if the download speed is lower than the reading speed or if the download has been momentarily paused or slowed down. A very slow connection therefore requires the use of a large buffer for streaming or sending the complete file without reading during transit.
Dans ce contexte, il est intéressant de proposer un procédé et/ou un io système de diffusion de fichiers média permettant de protéger contre la copie (piratage) les données des fichiers média envoyés aux utilisateurs et permettant d'adapter le streaming au débit de la connexion de l'utilisateur téléchargeant le fichier média. Afin d'empêcher la copie, un tel procédé et/ou système devra donc permettre d'empêcher la capture d'écran et l'accès aux données du fichier par des applications exécutées sur le terminal d'un utilisateur. Afin d'adapter le streaming au débit de la connexion, un tel procédé et/ou système devra permettre d'adapter la taille (et donc la qualité) du fichier à envoyer en fonction de la vitesse de connexion du terminal de l'utilisateur avec le serveur du fournisseur de fichiers média. In this context, it is advantageous to propose a method and / or a system for broadcasting media files making it possible to protect against copy (piracy) the data of the media files sent to the users and making it possible to adapt the streaming to the data rate of the user login downloading the media file. In order to prevent copying, such a method and / or system must therefore make it possible to prevent screen capture and access to the data of the file by applications executed on the terminal of a user. In order to adapt the streaming to the bit rate of the connection, such a method and / or system must make it possible to adapt the size (and hence the quality) of the file to be sent according to the connection speed of the user's terminal with the server of the media file provider.
La présente invention a pour but de pallier certains inconvénients de l'art antérieur en proposant un procédé de diffusion d'au moins un fichier média par un serveur, via un réseau de communication, permettant d'empêcher l'enregistrement du fichier média dans des moyens de mémorisation d'un terminal d'un utilisateur, pendant la lecture du fichier par des moyens de traitement du terminal. The purpose of the present invention is to overcome certain disadvantages of the prior art by proposing a method of broadcasting at least one media file by a server, via a communication network, making it possible to prevent the recording of the media file in means for storing a terminal of a user during the reading of the file by terminal processing means.
Ce but est atteint par un procédé de protection contre la copie de données représentatives d'au moins un fichier, dit média, transmises par au moins un terminal, dit fournisseur, vers au moins terminal dit récepteur, via au moins un réseau de communication, selon une technologie permettant la lecture d'une partie du fichier, par une application, dite de lecture de données en transit, exécutée sur des moyens de traitement du terminal récepteur, avant la fin de la transmission de l'intégralité du fichier, caractérisé en ce qu'il comporte au moins une étape d'exécution, sur les moyens de traitement du terminal récepteur, d'une application de vérification des moyens de mémorisation du terminal récepteur, mise en oeuvre de façon récurrente pour détecter si une variation de l'espace de stockage entre deux détections excède une taille prédéterminée et, le cas échéant, bloquer la transmission du fichier. This purpose is achieved by a method for protecting against the copy of data representative of at least one file, called media, transmitted by at least one terminal, said provider, to at least a terminal called receiver, via at least one communication network, according to a technology that makes it possible to read a part of the file, by an application, called a transit data reading application, executed on processing means of the receiving terminal, before the end of the transmission of the entire file, characterized in it comprises at least one step of execution, on the processing means of the receiving terminal, of a verification application of the storage means of the receiving terminal, implemented recurrently to detect whether a variation of the storage space between two detections exceeds a predetermined size and, if necessary, block the transmission of the file.
Selon une autre particularité, le procédé démarre par une connexion du terminal récepteur au terminal fournisseur grâce à une application, dite navigateur, exécutée sur les moyens de traitement du terminal récepteur, permettant une étape de chargement, dans le terminal récepteur, de données, dites d'installation, transmises par le terminal fournisseur et permettant au moins l'exécution de l'application de lecture de données en transit sur les moyens de traitement du terminal récepteur, cette application de lecture de données en transit consistant en au moins une pièce logicielle exécutée au sein du navigateur. According to another particularity, the method starts with a connection of the receiving terminal to the provider terminal by means of an application, called a browser, executed on the processing means of the receiving terminal, allowing a step of loading, in the receiving terminal, of data, called of installation, transmitted by the provider terminal and allowing at least the execution of the application for reading data in transit on the processing means of the receiving terminal, this application for reading data in transit consisting of at least one piece of software executed within the browser.
Selon une autre particularité, l'exécution de l'application de vérification récurrente des moyens de mémorisations terminal récepteur est activée par l'exécution de l'application de lecture de données en transit, au cours de la transmission des données représentatives du fichier et en ce qu'elle consiste en une détection des différents moyens de mémorisations accessibles au terminal récepteur et en un contrôle de l'espace de stockage libre et/ou utilisé dans ces moyens de mémorisation, pour détecter si une différence de cet espace de stockage entre deux détections excède une taille prédéterminée et, le cas échéant, bloquer la transmission du fichier. According to another particularity, the execution of the recurring verification application of the receiver terminal storage means is activated by the execution of the application for reading data in transit, during the transmission of the data representative of the file and in it consists of a detection of the different storage means accessible to the receiving terminal and a control of the free storage space and / or used in these storage means, for detecting whether a difference in this storage space between two detections exceeds a predetermined size and, if necessary, block the transmission of the file.
Selon une autre particularité, le procédé comporte également une étape d'exécution d'une application de contrôle des applications en cours d'exécution sur les moyens de traitement du terminal récepteur, pour vérifier que seule l'application de lecture en transit est exécutée et, dans le cas contraire, exiger la fermeture des autres applications par l'utilisateur du terminal récepteur. According to another feature, the method also comprises a step of executing a running application control application on the processing means of the receiving terminal, to verify that only the in-transit playback application is executed and if this is not the case, require the other end user to close the other applications.
Selon une autre particularité, le procédé comporte également une étape d'exécution d'une application de contrôle de la présence d'applications de piratage par capture d'écran sur les moyens de mémorisation du terminal récepteur, par comparaison des données stockées dans les moyens de mémorisation du terminal récepteur avec des données représentatives d'une liste d'informations permettant l'identification des applications de piratage par capture d'écran connues, pour détecter si de telles applications ont été installées sur le terminal récepteur et, le cas échéant, exiger leur désinstallation par l'utilisateur du terminal récepteur. According to another particularity, the method also comprises a step of executing an application for controlling the presence of screen capture hacking applications on the storage means of the receiving terminal, by comparison of the data stored in the means storing the receiving terminal with data representative of a list of information enabling identification of known screen capture hacking applications, for detecting whether such applications have been installed on the receiving terminal and, if appropriate, require their uninstallation by the user of the receiving terminal.
Selon une autre particularité, l'étape de chargement des données d'installation de la pièce logicielle correspondant à l'application de lecture en to transit est accompagnée du chargement de pièces logicielles correspondant à tout ou partie de l'application de vérification récurrente des moyens de mémorisation, de l'application de contrôle des applications en cours d'exécution et de l'application de contrôle de la présence d'applications de piratage. According to another particularity, the step of loading the installation data of the piece of software corresponding to the to-transit read application is accompanied by the loading of software pieces corresponding to all or part of the recurring verification application of the means. storage, the application control application running and the application control the presence of hacking applications.
is Selon une autre particularité, la transmission des données représentatives du fichier média comporte au moins les étapes suivantes: envoi, par des moyens de communication du terminal fournisseur, d'au moins une partie des données constitutives du fichier média vers le terminal récepteur, via le réseau communication, - réception de la partie des données constitutives du fichier média par des moyens de communication du terminal récepteur, lecture, par l'application de lecture de données en transit du terminal récepteur, de la partie des données constitutives du fichier reçue par les moyens de communications, puis présentation à l'utilisateur du terminal récepteur, grâce à une interface visuelle et/ou auditive du terminal récepteur des informations correspondant aux données reçues et lues. According to another feature, the transmission of the representative data of the media file comprises at least the following steps: sending, by means of communication of the provider terminal, at least part of the constituent data of the media file to the receiving terminal, via the communication network, - reception of the part of the constituent data of the media file by means of communication of the receiving terminal, reading, by the data reading application in transit of the receiving terminal, the part of the constituent data of the file received by the means of communication, then presentation to the user of the receiving terminal, through a visual and / or auditory interface of the receiving terminal information corresponding to the data received and read.
Selon une autre particularité, le démarrage de la transmission du fichier et notamment les premières étapes de lecture des premières données du fichier reçues et de présentation des informations correspondant aux premières données reçues et lues sont accompagnées d'au moins une étape de changement de propriétés de résolution et/ou d'échantillonnage des couleurs affichées par les moyens d'affichage du terminal récepteur et de passage du terminal récepteur dans un mode, dit asservi, par blocage de toute commande du terminal récepteur à l'exception de commandes dédiées au contrôle de l'application de lecture en transit et blocage des moyens de traitement du terminal récepteur pour permettre exclusivement l'exécution de l'application de lecture en transit et de l'application de vérification des moyens de mémorisation. According to another particularity, the start of the transmission of the file and in particular the first steps of reading the first received file data and presentation of the information corresponding to the first data received and read are accompanied by at least one step of changing the properties of the file. resolution and / or sampling of the colors displayed by the display means of the receiving terminal and of the receiving terminal in a so-called slave mode, by blocking any command of the receiving terminal with the exception of commands dedicated to the control of the application of reading in transit and blocking processing means of the receiving terminal to allow only the execution of the application of reading in transit and the verification application of the storage means.
Selon une autre particularité, le procédé comporte au moins une étape de configuration de la communication via le réseau de communication, grâce à l'envoi par le terminal fournisseur vers le terminal récepteur de données permettant une mise à jour du protocole de communication entre ces deux terminaux, ce protocole permettent des étapes d'adaptation en temps réel de la taille des données envoyées par le terminal fournisseur vers le terminal récepteur, en fonction de la vitesse de la connexion du terminal récepteur et en fonction d'éventuelles fluctuations de cette vitesse de la connexion. According to another particularity, the method comprises at least one step of configuring the communication via the communication network, by sending by the provider terminal to the data receiving terminal allowing an update of the communication protocol between these two terminals, this protocol allow steps of real-time adaptation of the size of the data sent by the provider terminal to the receiving terminal, as a function of the speed of the connection of the receiving terminal and as a function of possible fluctuations of this speed of the connection.
Selon une autre particularité, le procédé comporte au moins une étape d'identification de l'utilisateur du terminal récepteur par le terminal fournisseur. According to another particularity, the method comprises at least one step of identifying the user of the receiving terminal by the provider terminal.
Selon une autre particularité, l'étape de réception de la partie des données constitutives du fichier média est suivie d'une étape d'ajout, dans les données reçues, de données représentatives d'informations relatives à l'utilisateur du terminal récepteur, pour l'incorporation de ces informations au sein des informations contenues dans le fichier, de façon à ce que ces informations soient présentées aux utilisateurs lors de la lecture du fichier, pour permettre une identification des utilisateurs ayant réalisé une éventuelle copie analogique du fichier. According to another particularity, the step of receiving the portion of the constituent data of the media file is followed by a step of adding, in the received data, data representative of information relating to the user of the receiving terminal, for the incorporation of this information into the information contained in the file, so that this information is presented to the users during the reading of the file, to allow identification of the users having made a possible analog copy of the file.
Selon une autre particularité, l'étape de réception d'une partie des données constitutives du fichier média par les moyens de communication du terminal récepteur est suivie d'une étape de stockage temporaire de ces données dans une mémoire tampon du terminal récepteur, la taille de cette mémoire tampon étant déterminée, au cours de l'étape de configuration de la communication, en fonction de la vitesse de la connexion du terminal récepteur et permettant à l'application de vérification récurrente des moyens de mémorisation de définir la taille maximale autorisée de variation des espaces de stockage libres et/ou utilisés dans les moyens de mémorisation du terminal récepteur. According to another feature, the step of receiving part of the constituent data of the media file by the communication means of the receiving terminal is followed by a step of temporarily storing these data in a buffer memory of the receiving terminal, the size of this buffer memory being determined, during the communication configuration step, as a function of the speed of the connection of the receiver terminal and allowing the recurring verification application of the storage means to define the maximum authorized size of variation of the free storage spaces and / or used in the storage means of the receiving terminal.
s Selon une autre particularité, le procédé est mis en oeuvre par un terminal récepteur consistant en un ordinateur connecté, via un réseau de communication de type Internet, à un terminal fournisseur consistant en un serveur. According to another feature, the method is implemented by a receiving terminal consisting of a computer connected, via an Internet-type communication network, to a provider terminal consisting of a server.
Selon une autre particularité, le procédé est mis en oeuvre par un o terminal récepteur consistant en une console de jeux connectée, via un réseau de communication de type Internet, à un terminal fournisseur consistant en un serveur. In another feature, the method is implemented by a receiving terminal consisting of a gaming console connected via an Internet-type communication network to a provider terminal consisting of a server.
Un autre but de la présente invention est de proposer un système de diffusion d'au moins un fichier média par un serveur, via un réseau de is communication, permettant d'empêcher l'enregistrement du fichier média dans des moyens de mémorisation d'un terminal d'un utilisateur, pendant la lecture du fichier par des moyens de traitement du terminal. Another aim of the present invention is to propose a system for broadcasting at least one media file by a server, via an is communication network, making it possible to prevent the recording of the media file in storage means of a terminal of a user, during the reading of the file by terminal processing means.
Ce but est atteint par un système de protection contre la copie de données représentatives d'au moins un fichier, dit média, transmises par au moins un terminal, dit fournisseur, vers au moins terminal dit récepteur, via au moins un réseau de communication, selon une technologie permettant la lecture d'une partie du fichier, par une application, dite de lecture de données en transit, exécutée sur des moyens de traitement du terminal récepteur, avant la fin de la transmission de l'intégralité du fichier, caractérisé en ce que les moyens de traitement du terminal récepteur comportent des moyens de vérification de moyens de mémorisation du terminal récepteur application de vérification des moyens de mémorisation du terminal récepteur, mis en oeuvre de façon récurrente pour détecter si une variation de l'espace de stockage entre deux détections excède une taille prédéterminée et, le cas échéant, bloquer la transmission du fichier. This purpose is achieved by a system for protecting against the copy of data representative of at least one file, called media, transmitted by at least one terminal, said provider, to at least terminal called receiver, via at least one communication network, according to a technology that makes it possible to read a part of the file, by an application, called a transit data reading application, executed on processing means of the receiving terminal, before the end of the transmission of the entire file, characterized in the processing means of the receiving terminal comprise means for checking storage means of the receiving terminal verification application of the storage means of the receiving terminal, implemented recurrently to detect whether a variation of the storage space between two detections exceed a predetermined size and, if necessary, block the transmission of the file.
Selon une autre particularité, le terminal récepteur comporte des moyens de communication permettant à une application, dite navigateur, exécutée sur les moyens de traitement du terminal récepteur, d'établir une connexion avec des moyens de communication du terminal fournisseur, des moyens de traitement du terminal fournisseur permettant la gestion de la communication avec le terminal récepteur et l'envoi de données, dites d'installation, permettant au moins l'exécution de l'application de lecture de données en transit sur les moyens de traitement du terminal récepteur, cette application de lecture de données en transit consistant en une pièce logicielle exécutée au sein du navigateur. According to another particularity, the receiving terminal comprises communication means enabling an application, called a browser, executed on the processing means of the receiving terminal, to establish a connection with the communication means of the provider terminal, means for processing the provider terminal for managing communication with the receiving terminal and sending data, said installation, allowing at least the execution of the application for reading data in transit on the processing means of the receiving terminal, this streaming data reader application consisting of a piece of software executed within the browser.
Selon une autre particularité, les moyens de vérification récurrente des o moyens de mémorisations terminal récepteur sont activés par l'exécution de l'application de lecture de données en transit, au cours de la transmission des données représentatives du fichier et en ce qu'ils comportent des moyens de détection des différents moyens de mémorisations accessibles au terminal récepteur et en des moyens de contrôle de l'espace de stockage libre et/ou utilisé dans ces moyens de mémorisation, pour détecter si une différence de cet espace de stockage entre deux détections excède une taille prédéterminée et, le cas échéant, bloquer la transmission du fichier. According to another particularity, the means for recurrent verification of the receiving terminal storage means are activated by the execution of the application for reading data in transit, during the transmission of the representative data of the file and in that comprise means for detecting the different storage means accessible to the receiving terminal and means for controlling the free storage space and / or used in these storage means, for detecting whether a difference in this storage space between two detections exceeds a predetermined size and, if necessary, block the transmission of the file.
Selon une autre particularité, le terminal récepteur comporte également des moyens de contrôle des applications en cours d'exécution sur ses moyens de traitement, pour vérifier que seule l'application de lecture en transit est exécutée et, dans le cas contraire, exiger la fermeture des autres applications par l'utilisateur du terminal récepteur. According to another particularity, the receiving terminal also comprises means for controlling the applications running on its processing means, to check that only the application for reading in transit is executed and, if not, to require the closing other applications by the user of the receiving terminal.
Selon une autre particularité, le terminal récepteur comporte également des moyens de contrôle de la présence d'applications de piratage par capture d'écran sur les moyens de mémorisation du terminal récepteur, par comparaison des données stockées dans les moyens de mémorisation du terminal récepteur avec des données représentatives d'une liste d'informations permettant l'identification des applications de piratage par capture d'écran connues, pour détecter si de telles applications ont été installées sur le terminal récepteur et, le cas échéant, exiger leur désinstallation par l'utilisateur du terminal récepteur. According to another particularity, the receiving terminal also comprises means for controlling the presence of screen capture hacking applications on the storage means of the receiving terminal, by comparison of the data stored in the storage means of the receiving terminal with data representative of a list of information enabling the identification of known screen capture hacking applications, to detect if such applications have been installed on the receiving terminal and, if necessary, to require their removal by the user of the receiving terminal.
Selon une autre particularité, les moyens de traitement du terminal fournisseur permettant l'envoi des données d'installation de la pièce logicielle correspondant à l'application de lecture en transit est accompagnée de l'envoi de données fournissant au terminal récepteur les moyens de vérification récurrente des moyens de mémorisation, les moyens de contrôle des applications en cours d'exécution et les moyens de contrôle de la présence d'applications de piratage, ces données étant représentatives de pièces logicielles correspondant à tout ou partie des moyens de vérification récurrente des moyens de mémorisation, des moyens de contrôle des io applications en cours d'exécution et des moyens de contrôle de la présence d'applications de piratage. According to another particularity, the processing means of the supplier terminal for sending the installation data of the piece of software corresponding to the read-in-transit application is accompanied by the sending of data supplying the receiving terminal with the means of verification. recurrent storage means, control means running applications and control means for the presence of hacking applications, these data being representative of software parts corresponding to all or part of the recurring verification means of the means storage, means for controlling running applications and means for checking the presence of hacking applications.
Selon une autre particularité, les moyens de traitement du terminal fournisseur et les moyens de traitement du terminal récepteur permettent, d'une part, la configuration, respectivement, des moyens de communication du terminal fournisseur et des moyens de communication du terminal récepteur et, d'autre part, la détermination de la vitesse de la connexion du terminal récepteur au réseau de communication et les moyens de traitement du terminal fournisseur comportent des moyens d'adapter la taille des données transmises au terminal récepteur en fonction de la vitesse de sa connexion et en fonction d'éventuelles fluctuations de cette vitesse de connexion. According to another particularity, the processing means of the supplier terminal and the processing means of the receiving terminal allow, on the one hand, the configuration, respectively, of the communication means of the provider terminal and the communication means of the receiving terminal and, d on the other hand, the determination of the speed of the connection of the receiving terminal to the communication network and the processing means of the provider terminal comprise means of adapting the size of the data transmitted to the receiving terminal according to the speed of its connection and depending on possible fluctuations of this connection speed.
Selon une autre particularité, le terminal récepteur comporte également une interface visuelle et/ou auditive, consistant en au moins des moyens d'affichage, comporte des moyens de saisie, consistant en une souris et un clavier, et comporte une mémoire tampon pour le stockage temporaire des données reçues par ses moyens de communication et la lecture de la partie du fichier stockée dans cette mémoire tampon, par l'application de lecture en transit, le démarrage de cette lecture résultant en au moins un changement de propriétés de résolution et/ou d'échantillonnage des couleurs affichées par les moyens d'affichage et en un passage du terminal récepteur dans un mode dit asservi, dans lequel le clavier est bloqué et seule la souris permet certaines commandes dédiées au contrôle de l'application de lecture en transit. According to another particularity, the receiving terminal also comprises a visual and / or auditory interface, consisting of at least display means, comprises input means, consisting of a mouse and a keyboard, and includes a buffer memory for storage temporary data received by its means of communication and reading the portion of the file stored in this buffer, by the application of reading in transit, the start of this reading resulting in at least one change of resolution properties and / or sampling the colors displayed by the display means and in a passage of the receiving terminal in a so-called slave mode, in which the keyboard is blocked and only the mouse allows certain commands dedicated to the control of the application of reading in transit.
Selon une autre particularité, le terminal récepteur comporte également des moyens d'incorporation de données représentatives d'informations relatives à l'utilisateur du terminal récepteur, pour l'incorporation de ces informations au sein des informations contenues dans le fichier, de façon à ce que ces informations soient présentées aux utilisateurs lors de la lecture du fichier, pour permettre une identification des utilisateurs ayant réalisé une éventuelle copie analogique du fichier. According to another particularity, the receiving terminal also comprises means for incorporating data representative of information relating to the user of the receiving terminal, for the incorporation of this information into the information contained in the file, so that that this information is presented to the users during the reading of the file, to allow an identification of the users who made a possible analog copy of the file.
to Selon une autre particularité, le terminal récepteur est un ordinateur connecté à Internet. According to another particularity, the receiving terminal is a computer connected to the Internet.
Selon une autre particularité, le terminal récepteur est une console de jeux connectée à Internet. In another feature, the receiving terminal is a gaming console connected to the Internet.
D'autres particularités et avantages de la présente invention 1s apparaîtront plus clairement à la lecture de la description ci-après, faite en référence aux dessins annexés, dans lesquels: la figure 1 représente un schéma du système selon un mode de réalisation de l'invention, la figure 2 représente un schéma d'une série d'étapes préalables du procédé selon un mode de réalisation de l'invention, - la figure 3 représente un schéma d'une série d'étapes préalables de tests du procédé selon un mode de réalisation de l'invention, - la figure 4 représente un schéma d'une série d'étapes de la transmission selon un mode de réalisation du procédé de l'invention, telles qu'elles sont mises en oeuvre dans le système selon un mode de réalisation de l'invention. Other features and advantages of the present invention will appear more clearly on reading the following description, made with reference to the appended drawings, in which: FIG. 1 represents a diagram of the system according to an embodiment of the invention. FIG. 2 represents a diagram of a series of preliminary steps of the method according to one embodiment of the invention; FIG. 3 represents a diagram of a series of preliminary steps of testing the method according to a method; embodiment of the invention, - Figure 4 shows a diagram of a series of steps of the transmission according to an embodiment of the method of the invention, as they are implemented in the system according to a mode. embodiment of the invention.
L'invention concerne un procédé et un système de protection contre la copie de données représentatives d'au moins un fichier (M), dit média, transmises par au moins un terminal (1), dit fournisseur, vers au moins 3o terminal (2) dit récepteur, via au moins un réseau (10) de communication, selon une technologie permettant la lecture d'une partie du fichier (M), par une application (200), dite de lecture de données en transit, exécutée sur des i0 moyens (20) de traitement du terminal (2) récepteur, avant la fin de la transmission (90) de l'intégralité du fichier (M). Le procédé et le système selon l'invention permettent d'empêcher la copie du fichier (M) grâce à l'exécution (73), sur les moyens (20) de traitement du terminal (2) récepteur, d'une application (201) de vérification des moyens (22) de mémorisation du terminal (2) récepteur. Cette application (201) est mise en oeuvre de façon récurrente au cours de la transmission du fichier (M) pour détecter si une variation de l'espace de stockage entre deux détections excède une taille prédéterminée et, le cas échéant, bloquer la transmission (90) du fichier (M). The invention relates to a method and a system for protecting against the copy of data representative of at least one file (M), called media, transmitted by at least one terminal (1), said provider, to at least 30 terminal (2). ) said receiver, via at least one network (10) of communication, according to a technology allowing the reading of a part of the file (M), by an application (200), said data reading in transit, executed on i0 means (20) for processing the receiving terminal (2) before the end of the transmission (90) of the entire file (M). The method and the system according to the invention make it possible to prevent the file (M) from being copied by means of the execution (73), on the processing means (20) of the receiving terminal (2), of an application (201). ) verification means (22) for storing the terminal (2) receiver. This application (201) is implemented recurrently during the transmission of the file (M) to detect if a variation of the storage space between two detections exceeds a predetermined size and, where appropriate, block the transmission ( 90) of the file (M).
Bien que l'invention soit particulièrement adaptée à la diffusion de vidéo à la demande, elle ne devra pas être limitée à la transmission par streaming uniquement de fichiers de type vidéo et/ou audio car elle permet de protéger contre la copie tout type de données qui sont destinées être lue au cours de leur transmission d'un terminal (1) fournisseur vers un terminal (2) récepteur. Although the invention is particularly suitable for broadcasting video on demand, it should not be limited to streaming only video and / or audio files because it can protect against copying any type of data. which are intended to be read during their transmission from a provider terminal (1) to a receiving terminal (2).
1s Ces données peuvent naturellement être représentatives d'un film ou d'une musique, mais également, de façon non limitative, d'un texte confidentiel destiné à n'être affiché qu'une seule fois sur un terminal (2) récepteur ou de lignes de code destinées à n'être exécutées qu'une seule fois par un programme exécutant des commandes lors de la réception de ce code. 1s These data can of course be representative of a film or a music, but also, without limitation, a confidential text intended to be displayed only once on a terminal (2) receiver or lines of code intended to be executed only once by a program executing commands upon receipt of this code.
Par terminal (1) fournisseur, on entend tout terminal possédant les moyens décrits ci-après et permettant de transmettre au terminal (2) récepteur les données constitutives du fichier (M) et les données permettant l'exécution des différentes applications (200, 201, 202, 203) décrites ci-après sur le terminal (2) récepteur. De façon non limitative, le terminal (1) fournisseur consiste, dans un mode de réalisation préféré de l'invention, en un serveur diffusant des fichiers médias (M) selon la technologie dite de Streaming dynamique. Cette technologie permet d'envoyer à un terminal (2) récepteur, via un réseau de communication (par exemple de type Internet) un fichier qui peut être lu par le terminal (2) récepteur avant la fin de sa transmission via le réseau de communication. Le streaming (ou lecture en transit ) est dit dynamique lorsque le fichier (M) est stocké en plusieurs exemplaires de tailles et donc de qualités différentes sur le serveur, 2881302 Il qui adapte alors l'envoi des différentes qualités d'un même fichier (M) média en fonction de la vitesse de la connexion (101, 102) du terminal (2) récepteur et en fonction d'éventuelles fluctuations de cette vitesse de connexion. Par exemple, le terminal (2) récepteur peut posséder une connexion (101) Internet de type large bande et donc recevoir les données avec une vitesse plus élevée qu'avec une connexion (102) à faible bande passante. Cependant, la vitesse des connexions (101, 102), même large bande n'est pas toujours stable en fonction des serveurs par lesquels transitent les informations, le serveur doit donc pouvoir adapter automatiquement la qualité du fichier 5M) envoyé en fonction des variations de la bande passante de la connexion du terminal (2) récepteur de façon à éviter les interruptions de la diffusion du fichier (M), c'est- à-dire de sa lecture sur le terminal (2) récepteur. Le terminal (1) fournisseur comporte des moyens (11) de communication via au moins un réseau (10) de communication, pour l'échange de données avec d'autres terminaux connectés sur ce réseau (10) de communication, des moyens (12) de mémorisation pour le stockage de données reçues des autres terminaux ou pour le stockage de données à envoyer aux autres terminaux et des moyens (13) de traitement pour le traitement des données stockées dans les moyens (12) de mémorisation et des données échangées grâce aux moyens (11) de communication. Ces moyens (13) de traitement permettent l'exécution d'applications de gestion des échanges de données avec les autres terminaux connectés sur le réseau (10) de communication, comme expliqué en détail ci-après. Les moyens (12) de mémorisation du terminal (1) fournisseur comporte, par exemple, plusieurs bases de données relatives aux différentes données telles que celles concernant les utilisateurs, les différents fichiers médias à diffuser et les pièces logicielles permettant les communications avec les différents terminaux et les pièces logicielles permettant l'exécution des applications nécessaires à la mise en oeuvre du procédé selon un mode de réalisation de l'invention. La figure 1 représente donc, de façon non limitative, trois bases de données stockées dans les moyens (12) de mémorisation du terminal (1) fournisseur: une base (121) de données de stockage des fichiers médias (M), une base (122) de données By terminal (1) provider is meant any terminal having the means described below and for transmitting to the terminal (2) receiving the constituent data file (M) and the data for the execution of different applications (200, 201 , 202, 203) described hereinafter on the receiver terminal (2). In a nonlimiting manner, the provider terminal (1) consists, in a preferred embodiment of the invention, in a server broadcasting media files (M) according to the dynamic streaming technology. This technology makes it possible to send to a terminal (2) receiver, via a communication network (for example of the Internet type) a file that can be read by the receiving terminal (2) before the end of its transmission via the communication network. . Streaming (or reading in transit) is said to be dynamic when the file (M) is stored in several copies of sizes and therefore of different qualities on the server, 2881302 It which then adapts the sending of the different qualities of the same file ( M) as a function of the speed of the connection (101, 102) of the terminal (2) receiver and as a function of possible fluctuations of this connection speed. For example, the receiver terminal (2) may have a broadband type Internet connection (101) and thus receive the data at a higher speed than with a low bandwidth connection (102). However, the speed of the connections (101, 102), even broadband is not always stable depending on the servers through which the information flows, the server must be able to automatically adapt the quality of the file 5M) sent according to variations in the bandwidth of the connection of the terminal (2) receiver so as to avoid interruptions in the broadcast of the file (M), that is to say its reading on the terminal (2) receiver. The provider terminal (1) comprises means (11) for communication via at least one communication network (10) for the exchange of data with other terminals connected to this communication network (10). ) for storing data received from the other terminals or for storing data to be sent to the other terminals and processing means (13) for processing the data stored in the storage means (12) and the data exchanged by means the communication means (11). These processing means (13) allow the execution of data exchange management applications with the other terminals connected to the communication network (10), as explained in detail below. The means (12) for storing the provider terminal (1) comprises, for example, several databases relating to the various data such as those relating to the users, the various media files to be broadcast and the software pieces enabling communications with the various terminals. and the software pieces enabling the execution of the applications necessary for carrying out the method according to one embodiment of the invention. FIG. 1 thus represents, in a nonlimiting manner, three databases stored in the means (12) for storing the provider terminal (1): a database (121) for storing media files (M), a database ( 122) of data
UU
de stockage des informations concernant les utilisateurs du système selon l'invention et une base (123) de données de stockage des pièces logicielles nécessaires aux différents terminaux pour la mise en oeuvre de l'invention. storing information concerning the users of the system according to the invention and a database (123) of storage data of the software pieces necessary for the different terminals for the implementation of the invention.
Par terminal (2) récepteur, on entend tout terminal possédant les moyens décrits ci-après et permettant de recevoir et de lire les données constitutives du fichier (M) reçues du terminal (1) fournisseur. Dans un mode de réalisation de l'invention, le terminal (2) récepteur consiste en un ordinateur connecté à Internet. Dans un autre mode de réalisation de l'invention, le terminal (2) récepteur consiste en une console de jeux connectée à Internet. Le terminal (2) récepteur comporte des moyens (21) de communication via au moins un réseau (10) de communication, pour l'échange de données avec d'autres terminaux connectés sur ce réseau (10) de communication, des moyens (22) de mémorisation pour le stockage de données reçues des autres terminaux ou pour le stockage de données à envoyer aux autres terminaux et des moyens (20) de traitement pour le traitement des données stockées dans les moyens (22) de mémorisation et des données échangées grâce aux moyens (21) de communication. Ces moyens (20) de traitement permettent l'exécution d'applications de gestion des échanges de données avec les autres terminaux connectés sur le réseau (10) de communication, et d'applications de contrôle de opérations réalisées par le terminal (2) récepteur comme expliqué en détail ci-après. Le terminal (2) récepteur comporte également, d'une part, une interface (23) visuelle et/ou auditive, tels qu'au moins des moyens (23) d'affichage, comme un écran (23), par exemple muni de hauts parleurs et, d'autre part, des moyens de saisie tels que, par exemple, un clavier (232) et une souris (231). Il est évident qu'une manette de jeux d'une console constitue également des moyens de saisie et que toute interface visuelle et/ou auditive, autre qu'un écran muni de hauts parleurs, correspondent par équivalence aux moyens considérés ici. Les moyens (22) de mémorisation du terminal (2) récepteur peuvent consister, comme représenté sur la figure 1, en des disques durs internes (220) et/ou externe (222) (dont les espaces de stockage libres et utilisés sont représentés de façon classique en secteurs), mais également en des lecteurs/graveurs (221) de compact disques et/ou de DVD ou tout autre moyen de stockage amovible ou non. Receiver terminal (2) means any terminal having the means described below and for receiving and reading the constituent data file (M) received from the terminal (1) provider. In one embodiment of the invention, the receiving terminal (2) consists of a computer connected to the Internet. In another embodiment of the invention, the receiving terminal (2) consists of a gaming console connected to the Internet. The receiver terminal (2) comprises means (21) for communication via at least one communication network (10), for the exchange of data with other terminals connected to this communication network (10), means (22) ) for storing data received from the other terminals or for storing data to be sent to the other terminals and processing means (20) for processing the data stored in the storage means (22) and the data exchanged by means the communication means (21). These processing means (20) allow the execution of data exchange management applications with the other terminals connected to the communication network (10), and operations control applications performed by the receiver terminal (2). as explained in detail below. The receiver terminal (2) also comprises, on the one hand, a visual and / or auditory interface (23), such as at least display means (23), such as a screen (23), for example equipped with loudspeakers and, on the other hand, input means such as, for example, a keyboard (232) and a mouse (231). It is obvious that a joystick game console is also a means of capture and any visual and / or auditory interface, other than a screen equipped with speakers, correspond by equivalence to the means considered here. The means (22) for storing the receiving terminal (2) may consist, as shown in FIG. 1, of internal (220) and / or external (222) hard disks (whose free and used storage spaces are represented by conventional manner in sectors), but also in readers / burners (221) of compact discs and / or DVDs or any other means of removable storage or not.
La mise en oeuvre de l'invention nécessite le chargement d'une application (200) de lecture en transit permettant le streaming . De manière avantageuse, ce chargement peut être réalisé lors d'une connexion du terminal (2) récepteur avec le terminal (1) fournisseur, grâce à leurs moyens (21, 11) de communication respectifs. Dans un mode de réalisation de l'invention, les moyens (20) de traitement du terminal (2) récepteur exécutent une application (2000), dite navigateur, permettant à l'utilisateur du terminal (2) récepteur de se connecter au terminal (1) fournisseur dont les moyens (13) de traitement comportent les moyens nécessaires pour fournir au terminal (2) récepteur les fonctions nécessaires au streaming . II est évident qu'en l'absence de navigateur(2000) sur le terminal (2) récepteur, le terminal (1) fournisseur pourrait envoyer des données permettant l'exécution d'un navigateur (2000) sur le terminal (2) récepteur, grâce par exemple à un identifiant tel qu'une adresse IP ( Internet Protocole , selon la terminologie anglaise) fournie par l'utilisateur du terminal (2) récepteur aux gestionnaires du terminal (1) fournisseur, par exemple. The implementation of the invention requires the loading of a streaming application (200) for streaming. Advantageously, this loading can be performed during a connection of the receiver terminal (2) with the provider terminal (1), thanks to their respective communication means (21, 11). In one embodiment of the invention, the means (20) for processing the receiving terminal (2) execute an application (2000), called a browser, allowing the user of the terminal (2) to connect to the terminal ( 1) supplier whose processing means (13) comprise the means necessary to provide the terminal (2) receiving functions necessary for streaming. It is obvious that in the absence of a browser (2000) on the terminal (2) receiver, the terminal (1) provider could send data allowing the execution of a browser (2000) on the terminal (2) receiver , thanks for example to an identifier such as an IP address (Internet Protocol, according to the English terminology) provided by the user of the terminal (2) receiver to the managers of the terminal (1) provider, for example.
La mise en oeuvre du procédé selon l'invention par le système représenté sur la figure 1 va maintenant être décrite en référence avec la figure 2. Dans un mode de réalisation de l'invention, le navigateur (2000), de façon connue en soi, comporte un environnement, appelé Flash (développé par la société MacromediaTM). Cet environnement permet le développement et l'exécution de commandes, appelées FScommands (commandes Flash Studio selon la terminologie anglaise), programmées dans les langages de programmation appelés actionscript 2 et FSP script (pour scripts de commandes Flash Studio Pro ) spécifiques de l'environnement Flash . Ces langages permettent la création d'applications avancées compilées, par exemple grâce au logiciel MDM Studio Pro 2 , en applications exécutables dans l'environnement Flash d'un terminal. L'environnement Flash natif ne supporte au départ que 4 commandes pré configurées. Le procédé démarre grâce à une série (3) d'étapes d'initialisation du terminal (2) récepteur. Le démarrage (31) du navigateur (2000) et sa connexion au terminal (1) fournisseur permet le chargement (32) de classes FSP (classes du type flash studio pro , développées notamment par la société MDMTM) qui fournissent des centaines de commandes FScommands utiles pour accéder au système d'exploitation exécuté sur les moyens (20) de traitement du terminal (2) récepteur de l'utilisateur. Ces classes FSP permettent de définir des pièces logicielles exécutables au sein de l'environnement Flash du terminal (2) récepteur. Ces commandes FScommands sont lo particulièrement utiles notamment pour accéder au registre du système d'exploitation et réaliser le contrôle des moyens (22) de mémorisation du terminal (2) récepteur. Il est évident que bien l'invention soit décrite comme utilisant un environnement Flash de MacromediaTM, sa mise en oeuvre pourrait être supportée par d'autres environnements dans des langages de programmation différents, tels que l'environnement du langage orienté objet JAVATM, par exemple. Les commandes chargées sur le terminal (2) récepteur permettent de charger sur le terminal (2) récepteur une application (200) de lecture en transit qui permettra la lecture des fichiers médias (M) au cours de leur transmission par le terminal (1) fournisseur vers le terminal (2) récepteur, via le réseau (10) de communication, selon la technologie de streaming . Ces commandes permettent également la définition (33) d'objets particuliers permettant de recueillir les informations nécessaires à la mise en oeuvre du procédé selon un mode de réalisation de l'invention. Les données contenues dans ces objets seront perdues lorsque l'application (200) de lecture en transit sera arrêtée, soit par l'utilisateur, soit par le système d'exploitation. On considérera ici de façon illustrative et non limitative trois objets particuliers. Un premier objet, dit utilisateur , ainsi défini comporte les informations relatives à l'utilisateur (nom d'utilisateur, mot de passe, identifiant unique...). Un deuxième objet, dit système , 3o comporte des informations relatives aux spécifications du système d'exploitation du terminal (2) récepteur (version de WINDOWS , par exemple, administrateur système d'exploitation, langage, spécifications de l'écran, répertoire des applications, fichiers de programmes, dossier système, dossier bureau...). Un troisième objet, dit lecteur , comporte les informations concernant les différents films sélectionnés par l'utilisateur. Une fois cette configuration (33) des trois objets réalisée, le procédé nécessite une configuration de la communication entre le terminal (2) récepteur et le terminal (1) fournisseur. Le navigateur (2000) exécuté sur les moyens (20) de traitement du terminal (2) récepteur pourra, par exemple, être ainsi équipé d'une application (200) de lecture en transit permettant la lecture de fichiers (M) transmis au terminal (2) récepteur selon la technologie de streaming . The implementation of the method according to the invention by the system represented in FIG. 1 will now be described with reference to FIG. 2. In one embodiment of the invention, the browser (2000), in a manner known per se , contains an environment called Flash (developed by MacromediaTM). This environment allows the development and execution of commands, called FScommands (Flash Studio commands according to English terminology), programmed in the programming languages called actionscript 2 and FSP script (for Flash Studio Pro command scripts) specific to the environment. Flash. These languages allow the creation of advanced applications compiled, for example through the MDM Studio Pro 2 software, into executable applications in the Flash environment of a terminal. The native Flash environment initially supports only 4 pre-configured commands. The process starts with a series (3) of steps of initialization of the terminal (2) receiver. The startup (31) of the browser (2000) and its connection to the provider terminal (1) allows the loading (32) of classes FSP (classes of the type flash studio pro, developed in particular by the company MDMTM) which provide hundreds of commands FScommands useful for accessing the operating system executed on the means (20) for processing the terminal (2) receiving the user. These FSP classes make it possible to define executable pieces of software within the Flash environment of the receiver terminal (2). These FScommands commands are particularly useful in particular for accessing the operating system register and performing control of the means (22) for storing the receiving terminal (2). It is obvious that although the invention is described as using a MacromediaTM Flash environment, its implementation could be supported by other environments in different programming languages, such as the JAVATM object-oriented environment, for example . The commands loaded on the receiver terminal (2) make it possible to load on the terminal (2) receiver a streaming application (200) which will allow the reading of the media files (M) during their transmission by the terminal (1) provider to the receiver terminal (2), via the communication network (10), according to the streaming technology. These commands also make it possible to define (33) particular objects making it possible to collect the information necessary for carrying out the method according to one embodiment of the invention. The data in these objects will be lost when the streaming application (200) is stopped by either the user or the operating system. Three particular objects will be considered here in an illustrative and nonlimiting manner. A first object, said user, thus defined includes the information relating to the user (username, password, unique identifier ...). A second object, said system, 3o includes information relating to the operating system specifications of the terminal (2) receiver (version of WINDOWS, for example, operating system administrator, language, screen specifications, application directory , program files, system folder, desktop folder ...). A third object, said reader, includes the information concerning the various films selected by the user. Once this configuration (33) of the three objects has been completed, the method requires a configuration of the communication between the receiving terminal (2) and the provider terminal (1). The browser (2000) executed on the processing means (20) of the receiver terminal (2) could, for example, be equipped with a streaming application (200) for reading files (M) transmitted to the terminal. (2) receiver according to the streaming technology.
o Le chargement (32) des classes dans le terminal (2) récepteur permet l'exécution de différentes applications (201, 202, 203) qui pourront correspondre à des pièces logicielles exécutées au sein de l'environnement du navigateur (2000) ou exécutées par l'application (200) de lecture en transit chargée dans le terminal (2) récepteur. De telles applications 1s spécifiques de la protection contre la copie des données des fichiers (M) seront détaillées plus loin. o The loading (32) of the classes in the receiver terminal (2) allows the execution of different applications (201, 202, 203) which may correspond to software pieces executed within the environment of the browser (2000) or executed by the application (200) of transit playback loaded in the terminal (2) receiver. Such specific applications 1s copy protection data files (M) will be detailed below.
Le terminal (1) fournisseur peut consister en un serveur ou en un terminal d'un fournisseur de contenu relié à un serveur permettant le streaming . Le serveur du terminal (1) fournisseur et le terminal (2) récepteur selon un mode de réalisation de l'invention utilisent de façon avantageuse un protocole particulier, le protocole RTMP ( Routing Table Maintenance Protocol , selon la terminologie anglaise), différent des protocoles classiquement utilisés pour le streaming . Ce protocole particulier permet, à priori, d'empêcher la copie des données transmises par les logiciels actuels de piratage qui ne gèrent pour la plupart que les protocoles classiquement utilisés pour le streaming , tels que, par exemple, les protocoles HTTP ( Hyper Text Transfer Protocol , selon la terminologie anglaise), RTSP ( Real-Time Streaming Protocol, selon la terminologie anglaise), etc. Le serveur permettant le streaming communique ainsi avec le terminal (2) récepteur et éventuellement avec le terminal (1) fournisseur du fournisseur de contenu selon le protocole d'utilisation à distance de MacromediaTM ( macromedia remoting protocole , selon la terminologie anglaise) grâce à l'exécution sur le serveur, ou sur les moyens (13) de traitement du terminal (1) fournisseur s'il constitue le serveur, d'une application particulière, par exemple de type macromedia Coldfusion 6 enterprise . Les données transmises selon la technologie de s streaming sont envoyées selon le protocole RTMP et des applications du serveur, par exemple des applications de type SSA ( Server Side Applets , selon la terminologie anglaise), enregistrent les évènements qui se produisent pendant ses transmissions de données. The provider terminal (1) may consist of a server or terminal of a content provider connected to a server for streaming. The server of the terminal (1) supplier and the terminal (2) receiver according to one embodiment of the invention advantageously use a particular protocol, the protocol RTMP (Routing Table Maintenance Protocol, according to the English terminology), different protocols classically used for streaming. This particular protocol makes it possible, a priori, to prevent the copying of the data transmitted by the current hacking software, which for the most part only manages the protocols conventionally used for streaming, such as, for example, HTTP (Hyper Text Transfer) protocols. Protocol, according to English terminology), RTSP (Real-Time Streaming Protocol, etc.), etc. The streaming server thus communicates with the receiving terminal (2) and optionally with the content provider's provider terminal (1) according to the MacromediaTM remote protocol (macromedia remoting protocol, according to the English terminology) by means of the execution on the server, or the means (13) for processing the terminal (1) provider if it constitutes the server, a particular application, for example macromedia type Coldfusion 6 enterprise. The data transmitted according to the streaming technology is sent according to the RTMP protocol and server applications, for example applications of the Server Side Applets (SSA) type, record the events that occur during its data transmissions. .
Pour permettre les communications entre le terminal (1) fournisseur et le terminal (2) récepteur selon le protocole particulier décrit ci-dessus, une mise à jour des données concernant les classes définissant le protocole utilisé, stockées dans les moyens (22) de mémorisation du terminal (2) récepteur, est nécessaire. Pour l'utilisation du standard actionscript 2 de programmation en langage orienté objet, des classes d'utilisation à distance ( remoting classes , selon la terminologie anglaise) sont importées dans le terminal (2) récepteur, grâce à une étape (34) de mise à jour du protocole de communication. Grâce à cette mise à jour (34), une étape (35) de configuration de la communication permet de configurer un service d'utilisation à distance ( remoting service , selon la terminologie anglaise) définissant un service spécifique utilisable par le terminal (2) récepteur. Ce service délivré par le serveur permet de proposer différentes fonctions définies grâce à ces étapes de mise à jour (34) et de configuration (35). Un nouvel objet, dit service , est alors créé dans terminal (2) récepteur pour représenter une référence à un service d'utilisation à distance spécifique et aux fonctions proposées. Cet objet service sera alors utilisé pour les communications ultérieures avec le serveur. La série (3) d'étapes d'initialisation du terminal (2) récepteur se termine alors par une étape (36) de détection du système, au cours de laquelle une des commandes FScommands chargées à l'étape (32) permet de détecter les 3o spécifications du système d'exploitation du terminal (2) récepteur et d'actualiser l'objet système en recherchant les différentes informations détaillées précédemment lors de la description de cet objet. To enable communications between the provider terminal (1) and the receiver terminal (2) according to the particular protocol described above, an update of the data concerning the classes defining the protocol used, stored in the storage means (22) of the terminal (2) receiver, is necessary. For the use of the object-oriented programming language actionscript 2 standard, remoting classes are imported into the receiving terminal (2) by means of a step (34) of setting. the communication protocol. With this update (34), a step (35) for configuring the communication makes it possible to configure a remote service service (remoting service, in the English terminology) defining a specific service usable by the terminal (2). receiver. This service delivered by the server makes it possible to propose various functions defined by these update (34) and configuration (35) steps. A new object, called service, is then created in terminal (2) receiver to represent a reference to a specific remote usage service and proposed functions. This service object will then be used for subsequent communication with the server. The series (3) of steps of initialization of the terminal (2) receiver then ends with a step (36) of detection of the system, during which one of the commands FScommands loaded in step (32) makes it possible to detect the 3o operating system specifications of the terminal (2) receiver and update the system object by searching the different information detailed above when describing this object.
Le terminal (2) récepteur établit alors, grâce aux classes d'utilisation à distance ( remoting classes ) définies précédemment, une première communication avec le serveur de façon à ce que la qualité de la connexion (101, 102) du terminal (2) récepteur puisse être testée. Ainsi, une série (4) d'étape d'initialisation de la connexion consiste en une première étape d'envoi (41) d'une requête de connexion du terminal (2) récepteur vers le terminal (1) fournisseur (ou le serveur), suivie d'une étape d'affichage d'un message indiquant le statut de la connexion. Si le serveur n'envoie pas une réponse (42) dans un délai donné vers le terminal (2) récepteur, la connexion lo est soit coupée soit trop lente. L'étape d'affichage consiste alors en l'affichage (43) d'un message d'erreur permettant d'informer l'utilisateur que sa connexion est coupée ou bien trop lente pour permettre le streaming et éventuellement donner à l'utilisateur l'option pour retourner à l'étape d'envoi (41) d'une requête de connexion. Si la réponse (42) du serveur a eu 1s lieu dans le délai imparti, le message affiché indique un succès de la connexion et le terminal (2) récepteur affiche un menu permet une série (5) d'étapes d'identification de l'utilisateur du terminal (2) récepteur. L'utilisateur réalise alors une étape de saisie (51), sur les moyens (231, 323) de saisie du terminal (2) récepteur, de son nom d'utilisateur et de son mot de passe afin de charger ses éventuels réglages personnels et ses films sélectionnés les fois précédentes ou pour créer un nouveau profil d'utilisateur dans la base de données (122) des utilisateurs stockée dans les moyens (12) de mémorisation du terminal (1) fournisseur. Lorsque l'utilisateur saisie un choix de validation des nom et mot de passe saisis, le terminal (2) récepteur envoi (52) ces informations vers le terminal (1) fournisseur qui les reçoit (53) et active une fonction spécifique permettant l'authentification (54) des informations reçues. Cette authentification (54) consiste, par exemple, en une conversion du nom d'utilisateur et du mot de passe en caractères minuscules, puis en un cryptage du mot de passe d'après le nom d'utilisateur. Le nom d'utilisateur peut, par exemple, être utilisé comme une graine de cryptage ( seed , selon la terminologie anglaise). Enfin, le terminal (1) fournisseur vérifie le résultat de ce cryptage avec les données contenues dans la base de données (122) des utilisateurs. Si le résultat du cryptage n'est pas retrouvé dans la base de données (122), le terminal (1) fournisseur renvoie un message d'erreur au client pour l'informer que le mot de passe et le nom d'utilisateur saisis sont erronés ou invalides et lui proposer de s'identifier à nouveau. Si l'authentification (54) est réussie, le terminal (1) fournisseur envoie (55) un identifiant unique de l'utilisateur vers le terminal (2) récepteur. Cet identifiant pourra être utilisé pour réaliser toutes communications ultérieures avec le terminal (1) fournisseur. Selon le fournisseur de contenu, l'étape d'envoi (55) de l'identifiant pourra être accompagné d'une étape d'envoi (56) d'autres informations utiles à l'utilisateur, telles que, par exemple, des informations concernant la sélection et/ou la location et/ou l'achat de fichiers médias (M) que l'utilisateur peut effectuer grâce au terminal (1) fournisseur. The receiver terminal (2) then establishes, thanks to the remoting classes defined above, a first communication with the server so that the quality of the connection (101, 102) of the terminal (2) receiver can be tested. Thus, a series (4) of initialization step of the connection consists of a first step of sending (41) a connection request from the receiving terminal (2) to the provider terminal (1) (or the server ), followed by a step of displaying a message indicating the status of the connection. If the server does not send a response (42) within a given time to the receiving terminal (2), the connection lo is either cut off or too slow. The display step then consists in displaying (43) an error message making it possible to inform the user that his connection is cut off or else too slow to allow streaming and possibly to give the user the opportunity to option to return to the sending step (41) of a connection request. If the server response (42) has occurred within the allotted time, the displayed message indicates a success of the connection and the receiver terminal (2) displays a menu allows a series (5) of identification steps. terminal user (2). The user then performs an input step (51) on the means (231, 323) for entering the receiving terminal (2), his username and his password in order to load his possible personal settings and its films selected the previous times or to create a new user profile in the database (122) of the users stored in the means (12) of storage of the terminal (1) provider. When the user enters a validation choice of the name and password entered, the receiving terminal (2) sends (52) this information to the receiving provider terminal (1) (53) and activates a specific function allowing the authentication (54) of the received information. This authentication (54) consists, for example, in a conversion of the user name and the password in lowercase characters, then in encrypting the password according to the username. The username can, for example, be used as an encryption seed. Finally, the provider terminal (1) verifies the result of this encryption with the data contained in the database (122) of the users. If the result of the encryption is not found in the database (122), the provider terminal (1) returns an error message to the client to inform him that the password and the user name entered are wrong or invalid and suggest that he identify himself again. If the authentication (54) is successful, the provider terminal (1) sends (55) a unique identifier of the user to the receiving terminal (2). This identifier may be used to carry out any subsequent communications with the provider terminal (1). According to the content provider, the step of sending (55) the identifier may be accompanied by a step of sending (56) other useful information to the user, such as, for example, information concerning the selection and / or rental and / or purchase of media files (M) that the user can perform through the provider terminal (1).
Le terminal (1) fournisseur envoie alors au terminal (2) récepteur des données permettant la mise en oeuvre d'une série (6) d'étapes de sélection de fichiers médias (M). Un menu de sélection (61) est affiché sur les moyens (23) d'affichage du terminal (2) récepteur. La façon dont le menu principal sera configuré pourra naturellement dépendre du fournisseur de contenu qui propose les services fournis par l'invention. Ce menu de sélection (61) comportera au moins un liste de fichiers (M) médias disponibles dans au moins une base de données (121) de stockage accessibles par le terminal (1) fournisseur. L'utilisateur réalise alors une sélection (62) d'au moins un fichier (M) média disponible. Le terminal (2) récepteur pourra alors enregistrer (63) les détails du fichier sélectionné dans l'objet lecteur configuré à l'étape (33) lors de l'initialisation du terminal (2) récepteur. Le terminal (1) fournisseur pourra également enregistré ces informations dans au moins une des bases de données parmi la base de données (121) de stockage des films ou la base de données (122) de stockage des informations des utilisateurs. Suite à cette série (6) d'étapes de sélection, une série (7) d'étapes de tests de protection du fichier (M) est réalisée préalablement à la transmission du fichier (M) par streaming . The provider terminal (1) then sends the receiving terminal (2) data enabling the implementation of a series (6) of media file selection steps (M). A selection menu (61) is displayed on the display means (23) of the receiver terminal (2). The way the main menu will be configured may of course depend on the content provider that provides the services provided by the invention. This selection menu (61) will comprise at least one list of (M) media files available in at least one storage database (121) accessible by the provider terminal (1). The user then makes a selection (62) of at least one available media file (M). The receiving terminal (2) can then record (63) the details of the selected file in the reader object configured in step (33) during the initialization of the receiving terminal (2). The provider terminal (1) may also record this information in at least one of the databases of the film storage database (121) or the user information storage database (122). Following this series (6) of selection steps, a series (7) of file protection test steps (M) is performed prior to the transmission of the file (M) by streaming.
L'étape (32) de chargement des classes FSP a permis, comme indiqué précédemment de charger des commandes exécutables par le terminal (2) récepteur. De façon avantageuse, cette étape (32) a permis également de charger dans terminal (2) récepteur des pièces logicielles s exécutables sur les moyens (20) de traitement du terminal (2) récepteur, comme mentionné précédemment. Ces pièces logicielles correspondent à des applications (201, 202 et 203) permettant la mise en oeuvre de la série (7) de tests de protection du fichier (M) contre la copie. Une première série (71) d'étapes permet de tester la présence d'applications en cours lo d'exécution sur les moyens (20) de traitement du terminal (2) récepteur et le cas échéant d'exiger la fermeture de ces applications par l'utilisateur avant d'autoriser le démarrage de la transmission du fichier (M) par streaming . Ainsi, une application (202) de contrôle des applications en cours d'exécution sur les moyens (20) de traitement du terminal (2) récepteur permet de vérifier la présence d'applications actives qui pourraient être gênantes pour la lecture du fichier (M) et/ou pour la sécurité de données du fichier (M). Cette application (202) de contrôle des applications en cours réalise ainsi une étape (711) de vérification des applications actives. Si l'application (202) de contrôle des applications en cours d'exécution détermine (712) que l'application (200) de lecture en transit (au sein de laquelle elle est exécutée, par exemple) n'est pas la seule application en cours d'exécution sur les moyens (20) de traitement du terminal (2) récepteur, elle affiche (713) un message d'erreur. L'utilisateur du terminal (2) récepteur est alors invité à fermer (714) toutes les applications actives et essayer de nouveau. Si l'application (202) de contrôle des applications en cours d'exécution détermine (712) que l'application (200) de lecture en transit est bien la seule en cours d'exécution, elle active l'application (203) de contrôle de la présence d'applications de piratage par capture d'écran sur les moyens (22) de mémorisation du terminal (2) récepteur, pour réaliser une série (72) d'étape de tests de la présence de logiciels pirates dans les moyens (22) de mémorisation du terminal (2) récepteur. L'application (203) de contrôle de la présence d'applications de piratage par capture d'écran permet une première étape de chargement (721) des dernières données disponibles pour la définition des composants logiciels pirates à rechercher sur le terminal (2) récepteur. Cette étape de chargement permet une définition (722) d'une liste de composants de logiciels pirates à rechercher. L'application (203) effectue alors une recherche (723) des composants définis dans cette liste pour établir une liste de composants de logiciels pirates installés sur le terminal (2) récepteur. Une étape de comparaison (724) de la liste des composants à rechercher et des composants installés permet à l'application (203) de déterminer (725) s'il existe de telles applications de piratage sur les moyens (22) de mémorisation du terminal (2) récepteur. Si au moins une telle application de piratage est installée sur le terminal (2) récepteur, un message d'erreur (726) est affiché de façon à exiger la désinstallation (727) de cette application par l'utilisateur du terminal (2) récepteur. Suite à cette éventuelle désinstallation (727), l'application (203) retourne à l'étape (722) de définition d'une liste de composants de logiciels pirates à rechercher dans les moyens (22) de mémorisation du terminal (2) récepteur. Si aucune application de piratage par capture d'écran n'est détectée, l'application (203) active l'application (201) de vérification des moyens (22) de mémorisation du terminal (2) récepteur pour la mise en oeuvre d'une série (73) d'étapes de tests des mémoires du terminal (2) récepteur. Cette application (201) de vérification des moyens (22) de mémorisation du terminal (2) récepteur permet de vérifier l'état des différents moyens (22) de mémorisation accessibles par le terminal (2) récepteur une première fois avant le démarrage de la transmission (90) du fichier (M). Une première étape (731) de détection des mémoires accessibles par le terminal (2) récepteur permet de déterminer les différents moyens de stockage dans lesquels le terminal (2) récepteur serait susceptible de copier les données du fichier (M). Ces moyens de stockage peuvent consister, comme indiqué précédemment et comme représenté sur la figure 1, en des disques durs (220) internes du terminal (2) récepteur, en des disques durs (222) externes, en des graveurs (221) de compact disques et/ou de DVD ou en tout autre moyen de stockage amovible ou non. Une étape (732) de vérification des mémoires permet alors de déterminer l'espace de stockage libre et/ou utilisé sur ces différents moyens (22) de mémorisation. Une étape (733) supplémentaire permet de vérifier si la transmission (90) du fichier (M) est en cours. Si la transmission (90) du fichier (M) n'est pas en cours, l'application (201) de vérification des moyens (22) de mémorisation du terminal (2) récepteur ne vérifie pas si l'espace de stockage a été modifié depuis la détection précédente, mais elle active l'application (200) de lecture en transit pour requérir la transmission (90) du fichier (M) par le terminal (1) fournisseur et démarrer sa lecture sur le terminal (2) récepteur. L'application (200) de lecture en transit, dès le démarrage de la transmission (90) du fichier (M) réalise un changement (81) de propriétés de résolution et/ou d'échantillonnage des couleurs affichées par les moyens (23) d'affichage du terminal (2) récepteur. Ce changement permet que d'éventuelles applications de capture d'écran qui auraient échappé aux tests précédents ne puissent pas enregistrer les informations affichées par le terminal (2) récepteur. L'application (200) de lecture permet également de faire basculer (82) le terminal (2) récepteur en mode dit asservi dans lequel toute commande du terminal (2) récepteur à l'exception de commandes dédiées au contrôle de l'application (200) de lecture en transit est bloquée. Le mode asservi permet également le blocage des moyens (20) de traitement du terminal (2) récepteur pour permettre exclusivement l'exécution de l'application (200) de lecture en transit et de l'application (201) de vérification des moyens (22) de mémorisation. Ce mode dit asservi correspond de façon connue en soi au mode directX utilisé par exemple au cours de jeux vidéo. Ce mode asservi permettra, par exemple, de désactiver le clavier (232) et de ne permettre à l'utilisateur de ne contrôler le terminal (2) récepteur qu'à l'aide de la souris (231). Ce mode asservi permet d'empêcher l'utilisateur d'accéder à d'autres fonctions de son système d'exploitation qu'en arrêtant l'application (200) de lecture en transit. The loading step (32) of the classes FSP made it possible, as indicated previously, to load commands executable by the terminal (2) receiver. Advantageously, this step (32) has also made it possible to load in terminal (2) receiver software pieces executable on the means (20) for processing the terminal (2) receiver, as mentioned above. These pieces of software correspond to applications (201, 202 and 203) allowing the implementation of the series (7) of protection tests of the file (M) against copying. A first series (71) of steps makes it possible to test the presence of applications running on the means (20) for processing the receiving terminal (2) and, if necessary, to require the closure of these applications by the user before authorizing the start of the transmission of the file (M) by streaming. Thus, an application control application (202) running on the means (20) for processing the receiver terminal (2) makes it possible to check the presence of active applications that could be annoying for reading the file (M ) and / or for the data security of the file (M). This application (202) for controlling applications in progress thus performs a step (711) of checking active applications. If the running application control application (202) determines (712) that the streaming application (200) (in which it is running, for example) is not the only application running on the processing means (20) of the receiver terminal (2), it displays (713) an error message. The user of the terminal (2) receiver is then asked to close (714) all active applications and try again. If the running application control application (202) determines (712) that the streaming application (200) is the only one currently running, it activates the application (203) of monitoring the presence of screen capture hacking applications on the means (22) for storing the receiving terminal (2), for producing a series (72) of a step of testing for the presence of pirated software in the means (22) for storing the receiver terminal (2). The application (203) for controlling the presence of screen capture hacking applications enables a first step of loading (721) the latest available data for the definition of pirate software components to be searched on the receiver terminal (2) . This loading step allows a definition (722) of a list of pirated software components to be searched. The application (203) then searches (723) the components defined in this list to establish a list of pirated software components installed on the terminal (2) receiver. A comparison step (724) of the list of search components and installed components allows the application (203) to determine (725) whether there are such hacking applications on the terminal storage means (22). (2) receiver. If at least one such hacking application is installed on the terminal (2) receiver, an error message (726) is displayed to require the uninstall (727) of this application by the user of the terminal (2) receiver . Following this possible uninstall (727), the application (203) returns to step (722) for defining a list of pirated software components to be searched in the means (22) for storing the terminal (2) receiving . If no screen capture hacking application is detected, the application (203) activates the verification application (201) of the storage means (22) of the receiver terminal (2) for the implementation of a series (73) of steps for testing the memories of the receiver terminal (2). This application (201) for checking the means (22) for storing the receiving terminal (2) makes it possible to check the state of the different storage means (22) accessible by the receiving terminal (2) a first time before the start of the transmitting (90) the file (M). A first step (731) for detecting the memories accessible by the receiver terminal (2) makes it possible to determine the various storage means in which the receiver terminal (2) could copy the data from the file (M). These storage means may consist, as indicated previously and as shown in FIG. 1, in hard disks (220) internal to the receiver terminal (2), in external hard disks (222), in burners (221) in compact disks and / or DVDs or any other means of removable storage or not. A memory verification step (732) then makes it possible to determine the free storage space and / or used on these various storage means (22). An additional step (733) makes it possible to check whether the transmission (90) of the file (M) is in progress. If the transmission (90) of the file (M) is not in progress, the application (201) for checking the means (22) for storing the receiving terminal (2) does not check whether the storage space has been modified since the previous detection, but it activates the application (200) of reading in transit to require the transmission (90) of the file (M) by the terminal (1) provider and start reading on the terminal (2) receiver. The application (200) of reading in transit, from the start of the transmission (90) of the file (M) makes a change (81) of resolution and / or color sampling properties displayed by the means (23) displaying the terminal (2) receiver. This change allows any screen capture applications that have escaped previous tests can not record the information displayed by the terminal (2) receiver. The application (200) for reading also makes it possible to switch (82) the receiver terminal (2) in so-called slave mode in which any command from the receiver terminal (2) except for commands dedicated to the control of the application ( 200) in transit is blocked. The slave mode also makes it possible to block the means (20) for processing the receiver terminal (2) to allow only the execution of the application (200) for reading in transit and the application (201) for verifying the means ( 22). This so-called slave mode corresponds in known manner to directX mode used for example during video games. This slave mode will, for example, disable the keyboard (232) and allow the user to control the terminal (2) receiver using the mouse (231). This slave mode prevents the user from accessing other functions of his operating system by stopping the application (200) for streaming.
Une fois la transmission du fichier (M) en cours, l'application (201) de vérification des moyens (22) de mémorisation du terminal (2) récepteur est la seule à rester activée en même temps que l'application (200) de lecture en transit. L'application (201) de vérification des moyens (22) de mémorisation du terminal (2) récepteur permet, en restant activée, de contrôler les éventuelles variations de l'espace de stockage dans les moyens (22) de mémorisation du terminal (2) récepteur et le cas échéant, de bloquer la transmission (90). Cette application (201) va donc être mise en oeuvre de façon récurrente, à une fréquence prédéterminée, de façon à vérifier régulièrement que le terminal (2) récepteur ne dispose pas de nouveau moyens (22) de mémorisation et que l'espace de stockage disponible dans les différents moyens (22) de mémorisation n'a pas changé depuis la dernière vérification de plus d'une valeur déterminée de variation maximale to autorisée. Cette valeur de variation maximale autorisée pourra être fixée au préalable en fonction de paramètres déterminés, par exemple, par les fournisseurs ou pourra être déterminée de façon dynamique en fonction de la vitesse de la connexion (101, 102) que possède le terminal (2) récepteur. Once the transmission of the file (M) in progress, the application (201) for checking the means (22) for storing the terminal (2) receiver is the only one to remain activated at the same time as the application (200) of in transit reading. The application (201) for checking the means (22) for storing the receiver terminal (2) makes it possible, while remaining enabled, to check any variations in the storage space in the terminal storage means (22) (2). ) receiver and if necessary, to block the transmission (90). This application (201) will therefore be implemented recurrently, at a predetermined frequency, so as to regularly check that the receiving terminal (2) does not have new storage means (22) and that the storage space available in the different memory means (22) has not changed since the last verification of more than a determined value of maximum variation to allowed. This maximum authorized variation value may be set in advance according to parameters determined, for example, by the suppliers or may be determined dynamically according to the speed of the connection (101, 102) that the terminal (2) has. receiver.
Les étapes de la transmission (90) des données du fichier (M) selon la technologie de streaming vont maintenant être décrites telles en référence à la figure 4. La figure 4 représente les étapes de la transmission (90) des données (0101100..101101 0110101) du fichier (M), transmises par le terminal (1) fournisseur vers le terminal (2) récepteur, via le réseau (10) de communication. Les terminaux (1 et 2) et leurs différents moyens permettant la mise en oeuvre de ces étapes sont indiqués en pointillés. Les étapes de la transmission sont donc indiquées en traits pleins, telles qu'elles ont mise en oeuvre dans le système indiqué en pointillé. Lorsque la série (7) de tests de protection décrites ci-dessus ont été réalisées avec succès, l'application (200) de lecture en transit requiert l'envoi des données constitutives du fichier (M) par le terminal (1) fournisseur (le serveur). Le serveur réalise l'envoi (91), par des moyens (11) de communication, d'au moins une partie des données constitutives du fichier média (M) vers le terminal (2) récepteur, via le réseau (10) communication. La réception (92) de la partie des données constitutives du fichier média (M) 3o par des moyens (21) de communication du terminal (2) récepteur permet le stockage des données reçues dans une mémoire tampon (T) accessible par l'application (200) de lecture en transit du terminal (2) récepteur. Cette mémoire tampon (T) aura, de façon connue en soi, une taille adaptée à la vitesse de la connexion (101, 102) du terminal (2) récepteur. La taille de cette mémoire tampon (T) pourra, par exemple, permettre à l'application (201) de vérification des moyens (22) de mémorisation du terminal (2) s récepteur, de déterminer la valeur de la variation maximale autorisée de l'espace de stockage disponible dans les moyens (22) de mémorisation. De façon également connue en soi, la technologie de streaming utilisée ici pourra correspondre à la technologie de streaming dynamique, en ce sens que la taille des parties du fichier (M) envoyées au terminal (2) lo récepteur sera adaptée en temps réel en fonction de la vitesse de la connexion (101, 102) du terminal (2) récepteur et en fonction d'éventuelles fluctuation de cette vitesse de connexion. Le stockage temporaire des parties du fichier (M) reçues dans la mémoire tampon (T) permet la lecture (93), par l'application (200) de lecture de données en transit du terminal (2) récepteur, de la partie des données constitutives du fichier (M) reçue par les moyens (21) de communications. Cette application (200) permet alors la présentation (94) à l'utilisateur du terminal (2) récepteur, grâce à l'interface (23) visuelle et/ou auditive du terminal (2) récepteur des informations correspondant aux données reçues et lues. Ces étapes de lecture (93) et de présentation (94) des données reçues a lieu, de façon connue en soi, pendant la réception des données suivantes du fichier (M) par les moyens (21) de communication du terminal (2) récepteur, mais également, de façon nouvelle et inventive, pendant la vérification récurrente de l'espace de stockage présent dans les moyens (22) de mémorisation du terminal (2) récepteur. The steps of the transmission (90) of the data of the file (M) according to the streaming technology will now be described as with reference to FIG. 4. FIG. 4 represents the steps of the transmission (90) of the data (0101100 .. 101101 0110101) of the file (M) transmitted by the provider terminal (1) to the receiving terminal (2) via the communication network (10). The terminals (1 and 2) and their various means for implementing these steps are indicated in dotted lines. The transmission steps are therefore indicated in solid lines, as they have been implemented in the dashed system. When the series (7) of protection tests described above have been successfully carried out, the application (200) for reading in transit requires the sending of the data constituting the file (M) by the terminal (1) provider ( the server). The server transmits (91), by means (11) of communication, at least a portion of the constituent data of the media file (M) to the terminal (2) receiver via the network (10) communication. The reception (92) of the part of the constituent data of the media file (M) 3o by means (21) of communication of the terminal (2) receiver allows storage of the received data in a buffer (T) accessible by the application (200) for reading in transit from the receiving terminal (2). This buffer memory (T) will, in a manner known per se, a size adapted to the speed of the connection (101, 102) of the terminal (2) receiver. The size of this buffer memory (T) may, for example, allow the application (201) to verify the means (22) for storing the terminal (2) s receiver, to determine the value of the maximum authorized variation of the storage space available in the storage means (22). In a manner also known per se, the streaming technology used here may correspond to dynamic streaming technology, in that the size of the parts of the file (M) sent to the terminal (2) the receiver will be adapted in real time based the speed of the connection (101, 102) of the terminal (2) receiver and as a function of any fluctuation of this connection speed. The temporary storage of the parts of the file (M) received in the buffer memory (T) enables the reading (93), by the application (200) of reading data in transit of the terminal (2) receiver, of the data portion constitutive of the file (M) received by the means (21) of communications. This application (200) then allows the presentation (94) to the user of the terminal (2) receiver, through the interface (23) visual and / or auditory terminal (2) receiving information corresponding to the data received and read . These steps of reading (93) and presentation (94) of the received data takes place, in a manner known per se, during the reception of the following data of the file (M) by the means (21) of communication of the terminal (2) receiver , but also, in a new and inventive way, during the recurrent verification of the storage space present in the storage means (22) of the receiver terminal (2).
II doit être évident pour les personnes versées dans l'art que la présente invention permet des modes de réalisation sous de nombreuses autres formes spécifiques sans l'éloigner du domaine d'application de l'invention comme revendiqué. Par conséquent, les présents modes de réalisation doivent être considérés à titre d'illustration, mais peuvent être modifiés dans le domaine défini par la portée des revendications jointes, et l'invention ne doit pas être limitée aux détails donnés ci- dessus. It should be obvious to those skilled in the art that the present invention allows embodiments in many other specific forms without departing from the scope of the invention as claimed. Therefore, the present embodiments should be considered by way of illustration, but may be modified within the scope defined by the scope of the appended claims, and the invention should not be limited to the details given above.
Claims (25)
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
FR0500650A FR2881302A1 (en) | 2005-01-21 | 2005-01-21 | METHOD AND SYSTEM FOR PROTECTING COPIES OF TRANSIT-READED FILE DATA (STREAMING) |
PCT/IB2006/000094 WO2006077490A1 (en) | 2005-01-21 | 2006-01-20 | Protection method and system against copying of data in files transmitted by streaming |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
FR0500650A FR2881302A1 (en) | 2005-01-21 | 2005-01-21 | METHOD AND SYSTEM FOR PROTECTING COPIES OF TRANSIT-READED FILE DATA (STREAMING) |
Publications (1)
Publication Number | Publication Date |
---|---|
FR2881302A1 true FR2881302A1 (en) | 2006-07-28 |
Family
ID=34993209
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
FR0500650A Pending FR2881302A1 (en) | 2005-01-21 | 2005-01-21 | METHOD AND SYSTEM FOR PROTECTING COPIES OF TRANSIT-READED FILE DATA (STREAMING) |
Country Status (2)
Country | Link |
---|---|
FR (1) | FR2881302A1 (en) |
WO (1) | WO2006077490A1 (en) |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8997172B2 (en) * | 2010-11-08 | 2015-03-31 | Citrix Systems, Inc. | Controlling information disclosure during application streaming and publishing |
CN112688922B (en) * | 2020-12-11 | 2024-07-12 | 深圳前海微众银行股份有限公司 | Data transmission method, system, equipment and medium |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20010000541A1 (en) * | 1998-06-14 | 2001-04-26 | Daniel Schreiber | Copyright protection of digital images transmitted over networks |
US20030200459A1 (en) * | 2002-04-18 | 2003-10-23 | Seeman El-Azar | Method and system for protecting documents while maintaining their editability |
-
2005
- 2005-01-21 FR FR0500650A patent/FR2881302A1/en active Pending
-
2006
- 2006-01-20 WO PCT/IB2006/000094 patent/WO2006077490A1/en not_active Application Discontinuation
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20010000541A1 (en) * | 1998-06-14 | 2001-04-26 | Daniel Schreiber | Copyright protection of digital images transmitted over networks |
US20030200459A1 (en) * | 2002-04-18 | 2003-10-23 | Seeman El-Azar | Method and system for protecting documents while maintaining their editability |
Also Published As
Publication number | Publication date |
---|---|
WO2006077490A1 (en) | 2006-07-27 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP1688818B1 (en) | Process for the secure management of the execution of an application | |
US8650283B1 (en) | Content delivery technology | |
US8880651B2 (en) | Method and system for efficient download of data package | |
US8621028B2 (en) | Content-recommendation message | |
CN101645815B (en) | Video and audio file download prompt method | |
CN112165482B (en) | Data processing method, data processing device, computer equipment and medium | |
CN112153410B (en) | High-concurrency testing method and system for streaming media service | |
US20070050402A1 (en) | Linking DVDs to the internet | |
EP2124153A1 (en) | Methods and device for implementing multi-functional peripherals using a single standard driver | |
EP1293912A2 (en) | Method for issuing identification information | |
FR2881302A1 (en) | METHOD AND SYSTEM FOR PROTECTING COPIES OF TRANSIT-READED FILE DATA (STREAMING) | |
WO2009071779A1 (en) | Method and device for controlling the display of an information zone on the welcome screen of a mobile terminal | |
FR3116172A1 (en) | Method for managing access to digital content | |
CN113596600A (en) | Security management method, device, equipment and storage medium for live broadcast embedded program | |
KR100509162B1 (en) | System and method for sharing CODEC in peer-to-peer network | |
EP4096230A1 (en) | Method for managing the transmission of content protected against copying to a playback device | |
FR3052893A1 (en) | METHOD FOR RESTITUTING DIGITAL MULTIMEDIA CONTENT | |
FR3089372A1 (en) | Method and device for managing a home network. | |
WO2023208688A1 (en) | Management of the rendering of an item of multimedia content | |
WO2013044304A1 (en) | System and method for servicing a request | |
FR2964523A1 (en) | PROVIDING INFORMATION BY A MOBILE TERMINAL IN A NETWORK. | |
EP4250680A1 (en) | Methods relating to the uses of control codes and the association of terminals, first terminal, second terminal and device for managing control codes | |
JP2006210995A (en) | E-mail server | |
FR2911203A1 (en) | Runtime environment managing method for e.g. personal computer, involves detecting computing event related to insertion or withdrawal of media on thin client and server of network, before initialization of runtime environment of client | |
FR3134493A1 (en) | Method for activating a user profile in terminal equipment, device, system and corresponding computer program |