WO2002095697A1 - Deploiement d'application depuis une carte a puce - Google Patents

Deploiement d'application depuis une carte a puce Download PDF

Info

Publication number
WO2002095697A1
WO2002095697A1 PCT/FR2002/001635 FR0201635W WO02095697A1 WO 2002095697 A1 WO2002095697 A1 WO 2002095697A1 FR 0201635 W FR0201635 W FR 0201635W WO 02095697 A1 WO02095697 A1 WO 02095697A1
Authority
WO
WIPO (PCT)
Prior art keywords
application
elements
priority
execution
processing means
Prior art date
Application number
PCT/FR2002/001635
Other languages
English (en)
Inventor
Olivier Potonniee
Marie-Claude Pellegrini
Original Assignee
Gemplus
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Gemplus filed Critical Gemplus
Priority to DE60222410T priority Critical patent/DE60222410T2/de
Priority to US10/477,948 priority patent/US7387258B2/en
Priority to JP2002592080A priority patent/JP4645998B2/ja
Priority to EP02727708A priority patent/EP1395962B1/fr
Publication of WO2002095697A1 publication Critical patent/WO2002095697A1/fr

Links

Classifications

    • GPHYSICS
    • G07CHECKING-DEVICES
    • G07FCOIN-FREED OR LIKE APPARATUS
    • G07F7/00Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus
    • G07F7/08Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus by coded identity card or credit card or other personal identification means
    • G07F7/10Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus by coded identity card or credit card or other personal identification means together with a coded signal, e.g. in the form of personal identification information, like personal identification number [PIN] or biometric data
    • G07F7/1008Active credit-cards provided with means to personalise their use, e.g. with PIN-introduction/comparison system
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/30Payment architectures, schemes or protocols characterised by the use of specific devices or networks
    • G06Q20/34Payment architectures, schemes or protocols characterised by the use of specific devices or networks using cards, e.g. integrated circuit [IC] cards or magnetic cards
    • G06Q20/355Personalisation of cards for use
    • G06Q20/3552Downloading or loading of personalisation data

Definitions

  • the present invention relates to the deployment of an application from a first data processing means, such as a smart card, also called a microcontroller card or integrated circuit card, on a second data processing means, such as a smart card reception terminal, in a wide and heterogeneous context.
  • a first data processing means such as a smart card, also called a microcontroller card or integrated circuit card
  • a second data processing means such as a smart card reception terminal
  • the application is composed of software components dispersed in a telecommunications network and must be able to be executed from heterogeneous terminals having different hardware and software characteristics, such as a mobile radiotelephone terminal, a personal electronic assistant and a personal computer.
  • Heterogeneous terminals differ, for example, in their operating systems and their data coding and communication characteristics.
  • a given application has a complex window-based graphical interface in a personal computer, and simple text menus in a mobile radiotelephone, or establishes audio or video communication according to the speed offered by the network and the terminal.
  • an application in a smart card CP, or any other portable electronic object having a relatively low memory capacity, by a DAP descriptor of an AP application identifying essential elements of the application, such as the CA software components of the application and CX connections between these components in pairs.
  • an application comprises at least three components CA1, CA2 and CA3 and at least two connections CXI and CX2 interconnecting two by two the components CA1 to CA3.
  • a CA component is a software processing unit that encapsulates functionalities, small enough to be able to create and maintain it, and large enough to be able to install and support it.
  • the component is provided with communication interfaces so that it can cooperate with other components and thus present its behavior to these other components.
  • a software component can be installed on any site of an RT transmission network.
  • a connection defines the relationships between the communication interfaces of two components.
  • Application connection parameters are also adapted to the context of the execution platform.
  • a DAP application descriptor does not contain the element itself (CA software component or CX connection), but a DCA, DCX descriptor of the CA element, CX containing properties and parameters of the element defining it and allowing it to be found among a multitude of elements.
  • the properties of the descriptor of an element are fixed once and for all by the supplier of the application which specializes the element, component or connection, in order to satisfy the needs of the application and the user according to characteristics of subscription for example. They indicate the characteristics of the platform on which the element can be executed, as well as the system requirements necessary for its execution.
  • a property can consist of a type or an address of an element, which is associated with each element and used for searching for the code or layout of the element, or is intimately linked to the application or to an application type.
  • the "account number" property is associated with a bank account manager component.
  • parameters are preferably personalized by the user and can be modified at any time.
  • a parameter defines the display currency of an amount, or a range of colors for displaying pages on a screen, or even the value of the bit rate or of a transmission characteristic in a connection.
  • Each application descriptor is represented in the form of an object graph in object-oriented language, for example JAVA language (registered trademark) or XML language (Extensible Markup Language).
  • the application descriptors DAP1, DAP2, DAP3 in a multi-application smart card are associated with the deployment pilot PI (in English bootstrap) which constitutes within the smart card CP an application making it possible to select an application, to configure it and deploy it according to its descriptor, after insertion of the CP card in the TE reception terminal.
  • the deployment pilot By grouping the application descriptors and the deployment pilot in the card, the confidentiality of the descriptors is ensured, so that the reading of the descriptors by the deployment pilot does not require authentication.
  • the deployment pilot authenticates each client who interrogates it before being at its disposal all of the application descriptors stored in the card. The PI driver can thus process one or more application deployments.
  • an application element, component or connection is configured as a function of the context of the application, that is to say of the hardware and software properties of the platform where the application will be executed, and parameters chosen by the user and customizing the application. All this information is gathered in the descriptor of the application element so that the PI deployment driver filters the information contained in the descriptor of the element according to the context of the application and the user's personalization parameters. .
  • the deployment pilot PI located in the smart card CP transmits deployment commands to a deployment portal PO which is an application element implemented in the reception terminal TE.
  • the main role of the portal is to receive deployment commands and re-issue them to the execution platform in order to install the selected application.
  • the deployment portal mainly has a function of informing the smart card about the environment in which the installation and execution of the selected application must be done, and a function of communication with the card in order to receive various commands for deploying the selected application.
  • the deployment of an application is synchronous, that is to say the commands developed by the PI deployment pilot are transmitted sequentially, one after the other, respectively for the installation of the elements of the application, then for the configuration of the elements of the application, each command having to be acknowledged by the PO deployment portal on the terminal before the next command is issued by the PI pilot.
  • the application thus deployed is adapted to the TE terminal and can then be executed.
  • the application is started by an execution command (RUN) which contains the name of the component of the selected application determining the entry point of the application, generally a user interface component.
  • RUN execution command
  • the present invention aims to remedy the aforementioned drawbacks of the deployment of applications with distributed elements according to the prior art, and to further reduce the installation time.
  • This objective is achieved by providing a method for deploying an application composed of several remote distant elements, from a first data processing means containing descriptors of said elements, on a second data processing means connected to means of implantation of the elements, to execute the application once deployed, characterized in that it comprises at least the steps consisting in:
  • the waiting time of the user is considerably reduced, since the deployment carried out before the launch of the application concerns a reduced number of components.
  • the card does not present to the terminal the descriptors of the elements not installed, and the resources of the terminal are not overloaded with unnecessary elements.
  • the step of selecting at least one element of the application as a priority element consists in examining at least one priority indicator contained in the descriptor of said application.
  • the method further comprises a step of deploying the called element, then a step of continuing to execute the application.
  • the elements of the application not selected as priority elements are deployed on the second data processing means in parallel with the execution of the application.
  • the method further comprises a step of transmitting the execution context of the application from the second data processing means to the first data processing means, the deployment in parallel of the execution of the application, elements of the application not selected as priority elements, being produced according to the execution context transmitted.
  • the elements of the application not selected as priority elements are deployed on the second processing means in parallel with the execution of the application, in a synchronous manner.
  • the elements of the application not selected as priority elements are deployed on the second processing means in parallel with the execution of the application, in an asynchronous manner.
  • the method further comprises a step of selecting at least one element of the application as a non-priority element, the non-priority elements of the application being deployed on the second processing means only if they are called during the execution of the application.
  • the method according to the invention further comprises a step of updating the respective priority indicators of the elements of the application as a function of the elements which have been used during execution of the application.
  • the invention also relates to an electronic object comprising a description means for describing an application composed of several distributed remote elements, and a processing means for deploying the application with a view to its execution outside the electronic object, in function of the description means of the application, characterized in that the description means comprises at least one priority indicator for selecting at least one element as priority element of the application, and in that the means for deploying the application deploys only the priority elements before authorizing the execution of the application.
  • This object is for example of the microcontroller card type.
  • the invention also relates to an application deployment system comprising a portable electronic object of the microcontroller card type, a terminal connected to a data transmission network and comprising means for communicating with the object.
  • portable electronics the portable electronic object comprising a description means for describing an application composed of several distributed remote elements accessible to the terminal by the data transmission network, and a processing means for deploying the application on the terminal in order to its execution by the terminal, as a function of the means of description of the application, characterized in that the description means comprises at least one priority indicator for selecting at least one element as a priority element of the application, and in that the means for deploying the application deploys only the priority elements before triggering the execution of the application deployed on the terminal.
  • FIG. 1 schematically shows a modular application comprising six components
  • FIG. 2 is a schematic block diagram of the means used in a telecommunications network for the deployment of an application consisting of distributed remote elements
  • - Figure 3 is an algorithm for deploying and executing an application, according to the invention; and - Figures 4 and 5 are algorithms showing in more detail certain steps of the algorithm shown in Figure 3.
  • FIG. 1 represents an application of banking services accessible by a data transmission network such as the Internet.
  • This application includes a main component CAL grouping together all UI interface functions with the user, this component provides access' to an integrated bank accounts generic service management in a CA2 component and a generic service CA3 credit request.
  • the component CA1 is connected to the components CA2 and CA3 by the respective connections CXI and CX2.
  • the component CA2 for managing bank accounts is connected by the connections CX3 and CX4 respectively to the servers of two banking organizations Bl and B2 integrated into the components CA4 and CA5, which means that the user can access bank accounts managed only by the banking organizations Bl and B2.
  • the component CA3 is connected by the connections CX5 and CX6 respectively to the servers of two banking organizations B 1 and B3.
  • such an application descriptor is stored in a first processing means such as a smart card CP, which can store several application descriptors DAP1, DAP2, DAP3, if it is a question of 'a multi-application card.
  • a card is intended to be read by a card reader coupled to a second processing means such as a terminal TE in which it is desired to deploy an application.
  • the deployment of an application from such a card is managed by the PI deployment driver integrated in the smart card CP, which when the card is read by the reader of a TE terminal, communicates with software called a portal PO deployment planned on the terminal.
  • the deployment is therefore carried out by the PI deployment pilot from the DAP descriptor of the selected application, by establishing a dialogue with the deployment portal PO in the reception terminal TE.
  • the portal can contain an item search engine, or be linked to one or more MR item search engines, as shown in FIG. 2.
  • Each MR search engine has access to libraries of item items.
  • Each element in a library is memorized with its descriptor and managed by the designer of the element.
  • the RT transmission network can be a public or private network, of. wired or cellular telephone type, or even computer network type such as the Internet.
  • the deployment - proper of a selected application is preceded by an initialization phase 1 during which the user inserts the smart card CP into the reader slot of the TE reception terminal.
  • Authentication consists for example in verifying the identity of ruser by means of a confidential PIN code entered by the terminal.
  • the context external to the hardware environment of the smart card is defined by properties of the execution platform which are transmitted by the terminal TE to the smart card CP.
  • the properties of the execution context provided by the terminal are for example the type of reception terminal used TE, the name of the terminal, a certificate or key identifying the terminal, and the geographic location of the terminal in the telecommunications network. . These properties allow the PI deployment pilot to limit the amount of data that he transmits to the PO deployment portal and thus minimize the duration of the deployment. During a subsequent deployment, these references to the contextual properties are replaced by the values supplied by another TE reception terminal.
  • the user selects an AP application, conventionally for example in a menu for presenting various applications, the deployments of which can be controlled by the smart card CP.
  • the terminal TE After selecting the application AP, the terminal TE, depending on the context, and preferably the user, configure the application, that is to say, configure some or all of the descriptors DCA and DCX of the components and connections of the selected application which can be configured. Configuration by the user is classic using tree menus asking for parameter values.
  • the deployment of the selected application AP is executed as a function of the component descriptors CAi and of the connection descriptors CXi in the parameterized descriptor DAP of the selected application AP.
  • the application only certain elements of the application are defined as having priority and must be loaded before the start of the application, the other elements being able to be deployed after the start of the application.
  • these elements are constituted by the user interface component CAl.
  • the definition of the deployment priority of an element is defined in the form of a property associated with the element, called "deploymentUrgency" and having a value located between 0 and 100.
  • deploymentUrgency a property associated with the element
  • the elements defined as priority are therefore selected 2 as being elements to be deployed, then deployed 3.
  • the application After the deployment of the priority elements, the application is launched 4 and executed 5.
  • the component CAl which manages the dialogue with the user is deployed and activated.
  • the user can perceive on the TE terminal that the application is activated and offers him to choose between access to bank account managers and access to credit offers .
  • deployments of non-priority application elements are only carried out if they are requested by the user.
  • a category of elements of medium priority is defined which are deployed in the background as soon as the application is started and a category of elements of non-priority or of low priority which does not are deployed only if they are required by the execution of the current application.
  • the convention has been chosen that a priority level equal to 100 is assigned to priority elements, a priority level greater than 10 and less than 100 is assigned to priority elements medium, and a priority level of less than 10 is assigned to low priority items, that is, items that are rarely executed.
  • each time an element of an application is called during the execution of the application a message is transmitted to the smart card, to warn it.
  • the smart card upon receipt of such a message, updates the value field of the priority level in the descriptor of the element concerned in the application descriptor. In this way, the order in which the elements of an application are deployed can be adapted to the needs and habits of each user regarding the execution of an application.
  • the execution environment of the application of the terminal TE detects that the component is not deployed and requests the deployment of the component from the smart card CP (step 6) by supplying it with example the name of the element to deploy. This request triggers the deployment of the element (step 7).
  • the element deployment can be synchronous or asynchronous, that is to say whether the PI deployment pilot waits or not for the end of the deployment before returning to step 6 to launch any other deployment of item if other items are required.
  • step 9 If there are elements of medium priority to deploy, these are deployed in the background, also in a synchronous or, asynchronous manner (step 9). Provision may be made for this deployment of elements of medium priority to be carried out only if the performance or the capacities of the terminal are sufficient (step 8), or that these elements are deployed in order of priority until the resources available (by example in terms of memory capacity) of the terminal reach a predefined minimum threshold, or, in the case of an asynchronous deployment, that the number of deployments triggered in parallel is limited according to the available resources of the terminal, so as not to significantly slowing down the execution of the current application for the user.
  • FIG. 5 illustrates the manner in which the deployment 7 of an element Ei is carried out. During such a deployment, four types of command are issued by the PI deployment pilot to the PO deployment portal.
  • the PI driver orders the PO portal 61 to install the component Ei of the selected application.
  • the portal PO commands a search for the element designated Ei if it is a component, through at least one search engine MR in a library Bl of components, so to retrieve an instance of the component in the TE terminal, or a remote reference to it component.
  • ACK acknowledgment message
  • the PI pilot 63 then sends to the portal PO a second command [PARAMETER Ei], containing the configuration parameters of the element Ei, in order to configure the element installed.
  • the Ei element is configured according to certain parameters contained in the element descriptor and depends on the execution context of the application and possibly on user selections, defined during deployment.
  • the portal PO transmits 64 to the pilot PI an acknowledgment message [ACK (PARAMETER Ei)]. If in steps 62 and 64, the portal PO has not responded with an acknowledgment before the end of a predetermined time delay, an error message is transmitted 65 by the pilot PI to the terminal TE to signal that the deployment of the item could not be completed.
  • the user interface component CA1 has priority (priority equal to 100) and is deployed before the application is executed on the terminal. Then, in the background or because the user has requested it, the banking agent component CA2 which has the highest average priority (70) is installed, as well as the component CA4 which has the same priority.
  • the deployment of these two components can be performed asynchronously, that is to say substantially in parallel, these two elements being independent of one another and not dependent on other elements.
  • the deployment of the CA5 component can also be launched since it is independent of the other elements of the application, even if it has a priority level of 50 lower than that of other elements not yet deployed such as the CXI and CX3 connections.
  • this deployment may not be carried out if, for example, it is conditioned by the performance of the terminal.
  • the connections CXI between the user interface CAl and the agent CA2, and CX3 between the agent and the bank server Bl, which have the next highest average priority 69 can be deployed in parallel.
  • the CX4 connection between the CA2 and CA5 components can be installed following the CA5 component.
  • the other elements, that is to say CA3, CA6 and CX6 having a priority lower than 10, are installed only if the user requests them.
  • the elements used during the execution of the application are marked and at the end of execution of the application, the terminal TE transmits to the smart card the reference of the elements thus marked .
  • the smart card updates the priority indicators of all the elements of the application according to the elements which have thus been used.
  • the priority indicators of the elements of the application can thus be modified within certain limits. For example, the priority indicators of the elements used are increased, while the unused elements are decreased.

Landscapes

  • Engineering & Computer Science (AREA)
  • Business, Economics & Management (AREA)
  • General Physics & Mathematics (AREA)
  • Physics & Mathematics (AREA)
  • General Business, Economics & Management (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Accounting & Taxation (AREA)
  • Strategic Management (AREA)
  • Microelectronics & Electronic Packaging (AREA)
  • Theoretical Computer Science (AREA)
  • Stored Programmes (AREA)
  • Information Transfer Between Computers (AREA)
  • Sampling And Sample Adjustment (AREA)
  • Photoreceptors In Electrophotography (AREA)
  • Parts Printed On Printed Circuit Boards (AREA)
  • Credit Cards Or The Like (AREA)
  • Die Bonding (AREA)

Abstract

Pour déployer une application composée de plusieurs éléments distants répartis, depuis un premier moyen de traitement de données contenant des descripteurs desdits éléments, sur un second moyen de traitement de données relié à des moyens d'implantation des éléments, et exécuter l'application une fois déployée, le procédé comporte au moins les étapes consistant à: sélectionner (2) au moins un élément de l'application en tant qu'élément prioritaire; déployer (3) sur le second moyen de traitement le ou les éléments prioritaires; et exécuter (5) l'application par le second moyen de traitement dès que le ou les éléments prioritaires ont été déployés.

Description

DEPLOIEMENT D'APPLICATION DEPUIS UNE CARTE A PUCE
La présente invention concerne le déploiement d'une application depuis un premier moyen de traitement de données, tel qu'une carte à puce, dite également carte à microcontrôleur ou carte à circuit intégré, sur un deuxième moyen de traitement de données, tel qu'un terminal d'accueil de la carte à puce, dans un contexte étendu et hétérogène. Dans ce contexte, l'application est composée de composants logiciels dispersés dans un réseau de télécommunication et doit pouvoir être exécutée à partir de terminaux hétérogènes ayant des caractéristiques matérielles et logicielles différentes, tels qu'un terminal radiotéléphone mobile, un assistant électronique personnel et un ordinateur personnel. Les terminaux hétérogènes diffèrent par exemple par leurs systèmes d'exploitation et leurs caractéristiques de codage de données et de communication.
Actuellement, des utilisateurs accèdent à diverses applications à travers des réseaux de télécommunication, notamment le réseau Internet, quasiment à l'aide de n'importe quel terminal parmi divers terminaux hétérogènes, depuis leurs bureaux, leurs domiciles, ou des bornes d'accès publiques. Malheureusement, les applications ne sont pas capables de se configurer automatiquement en fonction de caractéristiques personnelles à l'utilisateur et il est nécessaire de reconfigurer le terminal de l'utilisateur en fonction de l'application choisie. Pour exécuter correctement les applications, le terminal doit disposer de données de service relatives à l'application à exécuter et aux serveurs distants offrant ces applications, et de données individuelles confidentielles, propres à chaque utilisateur et personnalisant l'accès à une ou plusieurs applications. Lorsque les utilisateurs sont sédentaires ces informations sont généralement statiques sur leurs terminaux. En revanche, lorsque les utilisateurs sont itinérants, la carte à puce offre un support autonome, sûr et portable pour fournir ces données aux terminaux que l'utilisateur est susceptible d'avoir besoin.
Par ailleurs, les fournisseurs d'applications ont intérêt à ce que leurs applications soient tilisables depuis un très grand nombre de types de terminaux. Une application doit donc être capable de s'adapter au terminal dans lequel elle est exécutée. Par exemple, une application donnée présente une interface graphique complexe à base de fenêtres dans un ordinateur personnel, et de simples menus textuels dans un radiotéléphone mobile, ou établit une communication audio ou vidéo en fonction du débit offert par le réseau et le terminal.
L'adaptabilité des applications distribuées à leur contexte d'exécution et aux besoins de l'utilisateur devient ainsi une nécessité (cf. article intitulé "Adaptabilité des applications pour des utilisateurs mobiles", Michel RINEILL et al., OCM'2000, Objets Composants Modèles, 8 Mai 2000). Il est donc nécessaire de déployer des applications de service en fonction du type du terminal et d'une personnalisation de configuration pour l'utilisateur. Cette souplesse requise est obtenue par une architecture modulaire de chaque application. Chaque application est conçue comme un graphe de composants interconnectés par des connexions. Le déploiement de l'application sur un terminal crée dans celui-ci des instances de ces composants en fonction du contexte d'exécution et de caractéristiques personnelles.
Comme montré aux figures 1 et 2, il est connu de définir une application dans une carte à puce CP, ou tout autre objet électronique portable présentant une capacité de mémoire relativement faible, par un descripteur DAP d'une application AP identifiant des éléments essentiels de l'application, tels que les composants logiciels CA de l'application et des connexions CX entre ces composants deux à deux. En général, une application comprend au moins trois composants CA1, CA2 et CA3 et au moins deux connexions CXI et CX2 interconnectant deux à deux les composants CA1 à CA3.
Un composant CA est une unité de traitement logiciel encapsulant des fonctionnalités, assez petite pour que l'on puisse la créer et la maintenir, et assez grande pour que l'on puisse l'installer et en assurer le support. Le composant est doté d'interfaces de communication pour qu'il puisse coopérer avec d'autres composants et ainsi présenter son comportement à ces autres composants. En pratique, un composant logiciel peut être implanté sur n'importe quel site d'un réseau de transmission RT.
Une connexion définit les relations entre les interfaces de communication de deux composants. Des paramètres des connexions de l'application sont également adaptés au contexte de la plate-forme d'exécution.
Au niveau de la carte à puce CP, un descripteur d'application DAP ne contient pas l'élément lui-même (composant logiciel CA ou connexion CX), mais un descripteur DCA, DCX de l'élément CA, CX contenant des propriétés et des paramètres de l'élément le définissant et permettant de le retrouver parmi une multitude d'éléments. Les propriétés du descripteur d'un élément sont fixées une fois pour toutes par le fournisseur de l'application qui spécialise l'élément, composant ou connexion, afin de satisfaire les besoins de l'application et de l'utilisateur selon des caractéristiques d'abonnement par exemple. Elles indiquent les caractéristiques de la plate-forme sur laquelle l'élément peut être exécuté, ainsi que les besoins systèmes nécessaires à son exécution. Une propriété peut consister en un type ou une adresse d'élément, qui est associé à chaque élément et utilisé pour la recherche du code ou de implantation de l'élément, ou est intimement liée à l'application ou à un type d'application. Par exemple, la propriété "numéro de compte" est associée à un composant gestionnaire de compte bancaire. Ces propriétés sont, selon la technique antérieure, figées lors de la souscription au service correspondant à l'application par l'utilisateur de la carte à puce, et ne sont accessibles qu'en lecture seule.
D'autres propriétés, dites paramètres, sont de préférence personnalisées par l'utilisateur et peuvent être modifiées à tout instant. Par exemple, un paramètre définit la monnaie d'affichage d'un montant, ou bien une panoplie de couleurs pour l'affichage de pages sur un écran, ou bien encore la valeur du débit ou d'une caractéristique de transmission dans une connexion. Chaque descripteur d'application est représenté sous la forme d'un graphe d'objet en langage orienté objet, par exemple le langage JAVA (marque déposée) ou le langage XML (Extensible Markup Langage).
Les descripteurs d'application DAP1, DAP2, DAP3 dans une carte à puce multi-applications sont associés au pilote de déploiement PI (en anglais bootstrap) qui constitue au sein de la carte à puce CP une application permettant de sélectionner une application, la configurer et la déployer en fonction de son descripteur, après introduction de la carte CP dans le terminal d'accueil TE. En groupant les descripteurs d'application et le pilote de déploiement dans la carte, la confidentialité des descripteurs est assurée, si bien que la lecture des descripteurs par le pilote de déploiement ne nécessite pas d'authentification. En revanche, le pilote de déploiement authentifie chaque client qui l'interroge avant de ettre à sa disposition l'ensemble des descripteurs d'application mémorisés dans la carte. Le pilote PI peut ainsi traiter un ou plusieurs déploiements d'application.
Comme déjà dit, un élément d'application, composant ou connexion, est configuré en fonction du contexte de l'application, c'est-à- dire des propriétés matérielles et logicielles de la plate-forme où sera exécutée l'application, et de paramètres choisis par l'utilisateur et personnalisant l'application. Toutes ces informations sont regroupées dans le descripteur de l'élément d'application afin que le pilote de déploiement PI filtre les informations contenues dans le descripteur de l'élément en fonction du contexte de l'application et des paramètres de personnalisation de l'utilisateur.
Le pilote de déploiement PI localisé dans la carte à puce CP transmet des commandes de déploiement à un portail de déploiement PO qui est un élément applicatif implémenté dans le terminal d'accueil TE. Le portail a pour principal rôle de recevoir les commandes de déploiement et de les ré-émettre vers la plate-forme d'exécution afin d'installer l'application sélectionnée. Ainsi le portail de déploiement a principalement une fonction d'information de la carte à puce sur l'environnement dans lequel l'installation et l'exécution de l'application sélectionnée doivent être faites, et une fonction de communication avec la carte afin de recevoir diverses commandes de déploiement de l'application sélectionnée.
Selon la technique antérieure, le déploiement d'une application est synchrone, c'est-à-dire les commandes élaborées par le pilote de déploiement PI sont transmises séquentiellement, les unes après les autres, respectivement pour l'installation des éléments de l'application, puis pour le paramétrage des éléments de l'application, chaque commande devant être acquittée par le portail de déploiement PO sur le terminal avant que la commande suivante soit émise par le pilote PI.
Finalement, lorsque tous les composants et les connexions de l'application sélectionnée AP sont installés et paramétrés, l'application ainsi déployée se trouve adaptée au terminal TE et peut alors être exécutée. Le démarrage de l'application est effectué par une commande d'exécution (RUN) qui contient le nom du composant de l'application sélectionnée déterminant le point d'entrée de l'application, généralement un composant d'interface d'utilisateur. II s'avère qu'un tel déploiement synchrone présente l'inconvénient de rendre l'installation d'une application longue, à cause de la succession de commandes qui doivent être acquittées selon un ordonnancement prédéterminé. Cette installation est d'autant plus longue que le nombre de composants à installer est élevé et que l'installation de ces derniers nécessite de faire appel aux ressources du réseau de transmission RT. Ce temps pendant lequel l'utilisateur attend peut être un facteur de rejet d'une application lorsqu'il est trop important.
Pour tenter de remédier à cet inconvénient, on a proposé d'effectuer le déploiement d'une application de manière asynchrone, c'est- à-dire que le pilote PI demande l'installation en parallèle de tous les composants de l'application, indépendants d'autres composants, sans attendre un acquittement du portail PO, puis commande en parallèle, l'installation d'éléments dépendants en réponse respectivement à l'acquittement de l'installation des éléments dont ils dépendent. Le paramétrage des éléments peut également être effectué de manière asynchrone. Dans le cas d'un système mono processeur, l'exécution en parallèle de plusieurs traitements signifie simplement que plusieurs traitements peuvent être en cours d'exécution simultanément, les ressources du processeur étant, bien entendu, attribuées à un seul traitement à un instant donné.
Cette solution permet d'optimiser l'utilisation de la puissance de traitement et le débit de transmission, offerts par le terminal et le réseau de transmission. Toutefois, en particulier lorsque l'application à installer comprend de nombreux composants et que le terminal de déploiement présente une faible capacité de traitement, le déploiement asynchrone ne permet pas de réduire de manière significative le temps d'attente de l'utilisateur, avant que l'application soit lancée. Dans les deux cas précédents, tous les composants de l'application sont installés, même ceux que l'utilisateur utilise rarement ou jamais, ce qui augmente inutilement le temps d'installation de l'application et surcharge inutilement les ressources du terminal.
La présente invention a pour objectif de remédier aux inconvénients précités du déploiement des applications à éléments répartis selon la technique antérieure, et à réduire encore le délai d'installation. Cet objectif est atteint par la prévision d'un procédé pour déployer une application composée de plusieurs éléments distants répartis, depuis un premier moyen de traitement de données contenant des descripteurs desdits éléments, sur un second moyen de traitement de données relié à des moyens d'implantation des éléments, pour exécuter l'application une fois déployée, caractérisé en ce qu'il comporte au moins les étapes consistant à :
- sélectionner au moins un élément de l'application en tant qu'élément prioritaire,
- déployer sur le second moyen de traitement le ou les éléments prioritaires, et
- exécuter l'application par le second moyen de traitement dès que le ou les éléments prioritaires ont été déployés.
Grâce à ces dispositions, le temps d'attente de l'utilisateur se trouve considérablement diminué, puisque le déploiement effectué avant le lancement de l'application concerne un nombre réduit de composants. En outre, si seuls les composants utilisés sont installés, la carte ne présente pas au terminal les descripteurs des éléments non installés, et les ressources du terminal ne sont pas surchargées par des éléments inutiles.
Avantageusement, l'étape de sélection d'au moins un élément de l'application en tant qu'élément prioritaire consiste à examiner au moins un indicateur de priorité contenu dans le descripteur de la dite application.
Selon une particularité de l'invention, si au cours de l'exécution de l'application par le second moyen de traitement de données, un élément non déployé est appelé, le procédé comprend en outre une étape de déploiement de l'élément appelé, puis une étape de poursuite de l'exécution de l'application.
Selon une autre particularité de l'invention, les éléments de l'application non sélectionnés en tant qu'éléments prioritaires sont déployés sur le second moyen de traitement de données en parallèle de l'exécution de l'application. Selon encore une autre particularité de l'invention, le procédé comprend en outre une étape de transmission du contexte d'exécution de l'application depuis le second moyen de traitement de données vers le premier moyen de traitement de données, le déploiement en parallèle de l'exécution de l'application, des éléments de l'application non sélectionnés en tant qu'éléments prioritaires, étant réalisé en fonction du contexte d'exécution transmis.
De préférence, les éléments de l'application non sélectionnés en tant qu'éléments prioritaires, sont déployés sur le second moyen de traitement en parallèle de l'exécution de l'application, d'une manière synchrone.
Alternativement, les éléments de l'application non sélectionnés en tant qu'éléments prioritaires, sont déployés sur le second moyen de traitement en parallèle de l'exécution de l'application, d'une manière asynchrone.
Selon encore une autre particularité de l'invention, le procédé comprend en outre une étape de sélection d'au moins un élément de l'application en tant qu'élément non prioritaire, les éléments non prioritaires de l'application étant déployés sur le second moyen de traitement uniquement s'ils sont appelés au cours de l'exécution de l'application.
Avantageusement, en fin d'exécution de l'application, le procédé selon l'invention comprend en outre une étape de mise à jour des indicateurs de priorité respectifs des éléments de l'application en fonction des éléments qui ont été utilisés durant l'exécution de l'application.
L'invention concerne également un objet électronique comprenant un moyen de description pour décrire une application composée de plusieurs éléments distants répartis, et un moyen de traitement pour déployer l'application en vue de son exécution à l'extérieur de l'objet électronique, en fonction du moyen de description de l'application, caractérisé en ce que le moyen de description comporte au moins un indicateur de priorité pour sélectionner au moins un élément en tant qu'élément prioritaire de l'application, et en ce que le moyen pour déployer l'application ne déploie que les éléments prioritaires avant d'autoriser l'exécution de l'application.
Cet objet est par exemple de type carte à microcontrôleur.
L'invention concerne aussi un système de déploiement d'application comprenant un objet électronique portable du type carte à microcontrôleur, un terminal connecté à un réseau de transmission de données et comportant un moyen pour communiquer avec l'objet électronique portable, l'objet électronique portable comprenant un moyen de description pour décrire une application composée de plusieurs éléments distants répartis accessibles au terminal par le réseau de transmission de données, et un moyen de traitement pour déployer l'application sur le terminal en vue de son exécution par le terminal, en fonction du moyen de description de l'application, caractérisé en ce que le moyen de description comporte au moins un indicateur de priorité pour sélectionner au moins un élément en tant qu'élément prioritaire de l'application, et en ce que le moyen pour déployer l'application ne déploie que les éléments prioritaires avant de déclencher l'exécution de l'application déployée sur le terminal.
D'autres caractéristiques et avantages de la présente invention apparaîtront plus clairement à la lecture de la description suivante de plusieurs réalisations préférées de l'invention en référence aux dessins annexés correspondants dans lesquels :
- la figure 1 représente schématiquement une application modulaire comprenant six composants ; - la figure 2 est un bloc-diagramme schématique des moyens mis en oeuvre dans un réseau de télécommunication pour le déploiement d'une application constituée d'éléments distants répartis ;
- la figure 3 est un algorithme de déploiement et d'exécution d'une application, selon l'invention ; et - les figures 4 et 5 sont des algorithmes montrant plus en détail certaines étapes de l'algorithme représenté sur la figure 3.
La figure 1 représente une application de services bancaires accessibles par un réseau de transmission de données tel quel le réseau Internet. Cette application comprend un composant principal CAl dans lequel sont rassemblées toutes les fonctions d'interface UI avec l'utilisateur, ce composant permet d'accéder' à un service générique de gestion de comptes bancaires intégré dans un composant CA2 et à un service générique de demande de crédit CA3. A cet effet, le composant CAl est relié aux composants CA2 et CA3 par les connexions respectives CXI et CX2. Dans l'application particulière mise à la disposition de l'utilisateur, représentée sur la figure 1, le composant CA2 de gestion de comptes bancaires est relié par les connexions CX3 et CX4 respectivement aux serveurs de deux organismes bancaires Bl et B2 intégrés dans les composants CA4 et CA5, ce qui signifie que l'utilisateur peut accéder à des comptes bancaires gérés uniquement par les organismes bancaires Bl et B2. D'une manière analogue, le composant CA3 est relié par les connexions CX5 et CX6 respectivement aux serveurs de deux organismes bancaires B 1 et B3.
Tous les éléments d'une telle application ne doivent pas nécessairement être installés sur le terminal d'exécution de l'application. Ainsi dans l'exemple présenté, les services offerts par les serveurs d'organismes bancaires, en-cours d'exécution sur des sites distants, sont interrogés à la demande par le terminal d'exécution de l'application. A cet effet, le lien entre les composants CA2 et CA3, d'une part et les composants CA4 à CA6 d'autre part est réalisé par les connecteurs CX3 à CX6 qui utilisent le réseau en implémentant un protocole de communication adéquat.
Une telle application peut être décrite par un descripteur d'application ayant la forme suivante, exprimée dans le langage XML :
<Application Name="Baιιkiiιg''> <Component Name="ui" Type=''barιking.AccountServiceUIObject''
Runnable="y">
<PropertyName="deploymentUrgency">
<Value Value="100"/> </Property>
</Component>
<Component Name="B 1" Type=''barιking.BankObject''> <PropertyName="deploymentUrgency"> <Value Value="70"/> </Property>
</Component>
<Component Name="B2" Type="banking.BankObject''> <PropertyName="deploymentUrgency"> <Value Value="50"/>
</Property>
</Component>
<Component Name="B3" Type="barιking.BankObject''> <Property Name="deploymentUrgency">
<Value Value="5"/> </Property>
</Component> <Component Name=" Agent" Type="bankiαg.AccountServiceObject">
<PropertyName="deploymentUrgency"> . <Value Value="70"/> </Property>
</Component> <Component Name="Credit" Type="barιldng.CreditServiceObject">
<Property Name="deploymentUrgency">
<Value Valùe="8"/> </Property> </Component>
<Connection Name="Agent_B 1 "
UserComponent=" Agent" Userrnterface="accounts" ProviderComponent="Bl" ProviderInterface="accounts"> <Property Name=deploymentUrgency"> <Value Value="69"/>
</Property>
</Connection>
<Connection Name="Agent_B2" UserComponent="Agent" UsèrInterface="accounts"
ProviderComponent="B2" Providerrnterface="accounts"> <Property Name=deploymentUrgency">
<Value Value="39"/> </Property>
</Connection>
<Connection Name="UI_Agent"
UserComponent="ui" UserInterface="accounts" ProviderComponent=" Agent" ProviderInterface="accounts"> <PropertyName=deploymentUrgency">
<Value Value="69"/> </Property>
</Connection> <ConnectionName="Credit_Bl"
UserComponent="Credit" Userlιιterface="accounts" ProviderComponent="B 1 " ProviderInterface="accounts"> <Property Name=deploymentUrgency"> <Value Value="2"/> </Property>
</Connection>
<Connection Name="Credit_B3"
UserComponent="Credit" Userlnterface="accounts" ProviderComponent="B3" Providerlnterface="accouιιts">
<Property Name=deploymentUrgency">
<Value Value="4"/> </Property> </Connection> </Aρplication> Cette syntaxe représente à l'aide de balises de début et de fin de champ "<XXX>" et "</XXX>" une structure hiérarchique d'éléments imbriqués les uns dans les autres. Elle donne en particulier la liste des descripteurs d'éléments (composants logiciels et connexions) faisant partie de l'application, chaque descripteur d'élément comprenant notamment une liste de propriétés.
Comme décrit ci-avant, un tel descripteur d'application est stocké dans un premier moyen de traitement tel qu'une carte à puce CP, laquelle peut stocker plusieurs descripteurs d'application DAP1, DAP2, DAP3, s'il s'agit d'une carte multi-applications. Une telle carte'est destinée à être lue par un lecteur de carte couplé à un second moyen de traitement tel qu'un terminal TE dans lequel on souhaite déployer une application. Le déploiement d'une application à partir d'une telle carte est géré par le pilote de déploiement PI intégré dans la carte à puce CP, qui lorsque la carte est lue par le lecteur d'un terminal TE, communique avec un logiciel appelé portail de déploiement PO prévu sur le terminal.
Lé déploiement est donc réalisé par le pilote PI de déploiement à partir du descripteur DAP de l'application sélectionnée, en établissant un dialogue avec le portail de déploiement PO dans le terminal d'accueil TE. Le portail peut contenir un moteur de recherche d'éléments, ou être en liaison avec un ou plusieurs moteurs de recherche d'éléments MR, comme montré à la figure 2. Chaque moteur de recherche MR a accès à des bibliothèques d'éléments d'application BU, BI2, BI3, à travers le réseau de transmission RT. Chaque élément dans une bibliothèque est mémorisé avec son descripteur et géré par le concepteur de l'élément. Le réseau de transmission RT peut être un réseau public ou privé, de. type téléphonique câblé ou cellulaire, ou encore de type réseau d'ordinateurs tel que le réseau Internet.
Tel que représenté sur les figures 3 et 4, le déploiement - proprement dit d'une application sélectionnée, est précédé d'une phase d'initialisation 1 au cours de laquelle l'utilisateur introduit la carte à puce CP dans la fente de lecteur du terminal d'accueil TE. Après l'introduction de la carte à puce, celle-ci dialogue 11 avec le terminal d'accueil pour authentifier 12 l'utilisateur, connaître 13 le contexte de la plate-forme d'exécution de l'application constituée essentiellement par le terminal TE, et l'application sélectionnée 14.
L'authentification consiste par exemple à vérifier l'identité de rutilisateur au moyen d'un code confidentiel PIN saisi par le terminal.
Le contexte extérieur à l'environnement matériel de la carte à puce est défini par des propriétés de la plate-forme d'exécution qui sont transmises par le terminal TE à la carte à puce CP. Les propriétés du contexte d'exécution fournies par le terminal sont par exemple le type du terminal d'accueil utilisé TE, le nom du terminal, un certificat ou clé d'identification du terminal, et la localisation géographique du terminal dans le réseau de télécommunication. Ces propriétés permettent au pilote de déploiement PI de limiter la quantité de données qu'il transmet au portail de déploiement PO et ainsi de minimiser la durée du déploiement. Lors d'un déploiement ultérieur, ces références aux propriétés contextuelles sont remplacées par les valeurs fournies par un autre terminal d'accueil TE.
L'utilisateur sélectionne une application AP, classiquement par exemple dans un menu de présentation de diverses applications dont les déploiements peuvent être commandés par la carte à puce CP. Après la sélection de l'application AP, le terminal TE, selon le contexte, et de préférence l'utilisateur paramétrent 15 l'application, c'est-à-dire paramétrent certains des ou éventuellement tous les descripteurs DCA et DCX des composants et des connexions de l'application sélectionnée qui sont susceptibles d'être paramétrés. Le paramétrage par l'utilisateur est classique à l'aide de menus arborescents demandant des valeurs de paramètre.
A la suite de ces étapes d'initialisation 1, le déploiement de l'application sélectionnée AP est exécuté en fonction des descripteurs de composant CAi et des descripteurs de connexion CXi dans le descripteur paramétré DAP de l'application sélectionnée AP.
Selon l'invention, seuls certains éléments de l'application sont définis comme étant prioritaires et doivent être chargés avant le démarrage de l'application, les autres éléments pouvant être déployés après le démarrage de l'application. Dans l'exemple de la figure 1, ces éléments sont constitués par le composant d'interface utilisateur CAl. Dans le descripteur d'application exprimé en langage XML, présenté ci- avant, la définition de la priorité de déploiement d'un élément est définie sous la forme d'une propriété associée à l'élément, appelée "deploymentUrgency" et ayant une valeur située entre 0 et 100. Par convention, on peut choisir que la valeur 100 est attribuée aux éléments prioritaires, c'est-à-dire devant être déployés avant le démarrage de l'application.
Les éléments définis comme prioritaires sont donc sélectionnés 2 comme étant des éléments à déployer, puis déployés 3.
Après le déploiement des éléments prioritaires, l'application est lancée 4 et exécutée 5. Dans l'exemple de la figure 1, seul le composant CAl qui gère le dialogue avec l'utilisateur est déployé et activé. Il en résulte qu'après le déploiement d'un unique composant, l'utilisateur peut percevoir sur le terminal TE que l'application est activée et lui propose de choisir entre un accès aux gestionnaires de comptes bancaires et un accès à des offres de crédit.
Le déploiement des éléments prioritaires peut se dérouler de manière synchrone ou asynchrone. Toutefois, en général une application possède un unique point d'entrée contenu dans un seul composant. Par conséquent, si l'on souhaite que l'application soit activée le plus rapidement possible, seul le composant contenant le point d'entrée de l'application doit être configuré comme prioritaire pour être déployé seul avant le démarrage de l'application.
Selon un premier mode de réalisation de l'invention, les déploiements des éléments d'application non prioritaires ne sont effectués que s'ils sont demandés par l'utilisateur.
Selon un second mode de réalisation de l'invention alternatif, on définit une catégorie d'éléments de priorité moyenne qui sont déployés en tâche de fond dès que l'application est démarrée et une catégorie d'éléments non prioritaires ou de priorité basse qui ne sont déployés que s'ils sont requis par l'exécution de l'application en cours. Dans"" le descripteur d'application donné ci-avant, on a choisi comme convention qu'un niveau de priorité égal à 100 est attribué aux éléments prioritaires, un niveau de priorité supérieur à 10 et inférieur à 100 est attribué aux éléments de priorité moyenne, et un niveau de priorité inférieur à 10 est attribué aux éléments de priorité basse, c'est-à-dire aux éléments qui sont rarement exécutés.
Avantageusement, chaque fois qu'un élément d'une application est appelé au cours de l'exécution de l'application, un message est transmis à la carte à puce, pour l'en avertir. De son côté la carte à puce, à la réception d'un tel message, met à jour le champ valeur du niveau de priorité dans le descripteur de l'élément concerné dans le descripteur d'application. De cette manière, l'ordre dans lequel les éléments d'une application sont déployés peut être adapté aux besoins et habitudes de chaque utilisateur concernant l'exécution d'une application.
Lorsque l'utilisateur sélectionne une option de l'application en cours d'exécution, par exemple dans un menu, soit le composant réalisant la fonction choisie est déjà déployé et dans ce cas, il peut être exécuté immédiatement, soit il ne l'est pas. Dans ce dernier cas, l'environnement d'exécution de l'application du terminal TE détecte que le composant n'est pas déployé et fait une demande de déploiement du composant auprès de la carte à puce CP (étape 6) en lui fournissant par exemple le nom de l'élément à déployer. Cette demande déclenche le déploiement de l'élément (étape 7). Ici encore, le déploiement d'élément peut être synchrone ou asynchrone, c'est-à-dire que le pilote de déploiement PI attend ou non la fin du déploiement avant de retourner à l'étape 6 pour lancer un éventuel autre déploiement d'élément si d'autres éléments sont requis. S'il existe des éléments de priorité moyenne à déployer, ceux-ci sont déployés en tâche de fond, également d'une manière synchrone ou , asynchrone (étape 9). On peut prévoir que ce déploiement d'éléments de priorité moyenne soit effectué uniquement si les performances ou les capacités du terminal sont suffisantes (étape 8), ou que ces éléments soient déployés par ordre de priorité jusqu'à ce que les ressources disponibles (par exemple en terme de capacité mémoire) du terminal atteignent un seuil minimum prédéfini, ou encore, dans le cas d'un déploiement asynchrone, que le nombre de déploiement déclenchés en parallèle soit limité en fonction des ressources disponibles du terminal, de manière à ne pas ralentir d'une manière notable pour l'utilisateur l'exécution de l'application en cours.
La figure 5 illustre la manière dont le déploiement 7 d'un élément Ei est effectué. Au cours d'un tel déploiement quatre types de commandes sont émis par le pilote de déploiement PI à destination du portail de déploiement PO.
Par une première commande d'installation [INSTALLER Ei] contenant les propriétés du descripteur de l'élément, le pilote PI ordonne 61 au portail PO l'installation du composant Ei de l'application sélectionnée. En réponse à la commande d'installation, le portail PO commande une recherche de l'élément désigné Ei s'il s'agit d'un composant, à travers au moins un moteur de recherche MR dans une bibliothèque Bl de composants, de manière à récupérer une instance du composant dans le terminal TE, ou une référence distante de ce composant. Après complète exécution de la commande d'installation, l'installation de l'élément est confirmée 62 par un message d'acquittement [ACK (INSTALLER Ei)] transmis par le portail PO au pilote PI. Le pilote PI émet 63 ensuite au portail PO une seconde commande [PARAMETRER Ei], contenant les paramètres de configuration de l'élément Ei, pour paramétrer l'élément installé. Le paramétrage de l'élément Ei est effectué en fonction de certains paramètres contenus dans le descripteur de l'élément et dépend du contexte d'exécution de l'application et éventuellement de sélections de l'utilisateur, définis durant le déploiement. Une fois le paramétrage de l'élément effectué par le portail PO, ce dernier transmet 64 au pilote PI un message d'acquittement [ACK(PARAMETRER Ei)]. Si aux étapes 62 et 64, le portail PO n'a pas répondu par un acquittement avant la fin d'une temporisation prédéterminée, un message d'erreur est transmis 65 par le pilote PI au terminal TE pour signaler que le déploiement de l'élément n'a pas pu être effectué.
Dans le cas où plusieurs éléments sont déployés de manière asynchrone, ils doivent bien entendu être indépendants les uns des autres, sachant qu'un élément dépendant d'autres éléments ne peut pas être déployé tant que les éléments dont il dépend ne sont pas déployés sur le terminal.
Dans l'exemple de la figure 1 et selon le descripteur d'application correspondant donné ci-avant, seul le composant d'interface utilisateur CAl est prioritaire (priorité égale à 100) et est déployé avant l'exécution de l'application sur le terminal. Ensuite, en tâche de fond ou parce que l'utilisateur l'a demandé, le composant d'agent bancaire CA2 qui a la priorité moyenne la plus élevée (70) est installé, ainsi que le composant CA4 qui a la même priorité. Le déploiement de ces deux composants peut être effectué de manière asynchrone, c'est-à-dire sensiblement en parallèle, ces deux éléments étant indépendants l'un de l'autre et ne dépendant pas d'autres éléments. Le déploiement du composant CA5 peut également être lancé puisqu'il est indépendant des autres éléments de l'application, même s'il possède un niveau de priorité de 50 inférieure à celui d'autres éléments non encore déployés comme les connexions CXI et CX3. Toutefois, ce déploiement peut ne pas être effectué si par exemple il est conditionné par les performances du terminal. Ensuite, une fois que les composants CA2 et CA4 sont déployés, les connexions CXI entre l'interface utilisateur CAl et l'agent CA2, et CX3 entre l'agent et le serveur bancaire Bl, lesquels ont la priorité moyenne la plus élevée suivante 69, peuvent être déployés en parallèle. La connexion CX4 entre les composants CA2 et CA5 peut être installée à la suite du composant CA5. Les autres éléments, c'est-à-dire CA3, CA6 et CX6 ayant une priorité inférieure à 10 ne sont installés que si l'utilisateur les demande.
, Selon une variante préférée de l'invention, les éléments utilisés durant l'exécution de l'application sont marqués et à la fin d'exécution de l'application, le terminal TE transmet à la carte à puce la référence des éléments ainsi marqués. A la suite de cette transmission, la carte à puce met à jour les indicateurs de priorité de tous les éléments de l'application en fonction des éléments qui ont ainsi été utilisés. Les indicateurs de priorité des éléments de l'application peuvent ainsi être modifiés dans certaines limites. Par exemple, les indicateurs de priorité des éléments utilisés sont augmentés, tandis que les éléments non utilisés sont diminués.

Claims

RENENDICATIONS
1. Procédé pour déployer une application composée de plusieurs éléments distants répartis (CA, CX), depuis un premier moyen de traitement de données (CP, PI) contenant des descripteurs desdits éléments, sur un second moyen de traitement de données (TE) relié à des moyens d'implantation (MR, Bl) des éléments, et exécuter l'application une fois déployée, caractérisé en ce qu'il comporte au moins les étapes consistant à : - sélectionner (2) au moins un élément (CAl) de l'application en tant qu'élément prioritaire,
- déployer (3) sur le second moyen de traitement (TE) le ou les éléments prioritaires (CAl), et
- exécuter (5) l'application par le second moyen de traitement (TE) dès que le ou les éléments prioritaires ont été déployés.
2. Procédé selon la revendication 1, caractérisé en ce que l'étape de sélection (2) d'au moins un élément > (CAl) de l'application en tant qu'élément prioritaire consiste à examiner au moins un indicateur de priorité contenu dans le descripteur (DAP) de ladite application.
3. Procédé selon la revendication 1 ou 2, caractérisé en ce que si au cours de l'exécution de l'application par le second moyen de traitement de données (TE), un élément (CA2, CA3) non déployé est appelé, il comprend une étape (7) de déploiement de l'élément appelé, puis une étape (5) de poursuite de l'exécution de. l'application.
4. Procédé selon l'une quelconque des revendications 1 à 3, caractérisé en ce que les éléments (CA2, CA4) de l'application non sélectionnés en tant qu'éléments prioritaires sont déployés (9) sur le second moyen de traitement de données (TE) en parallèle de l'exécution (5) de l'application.
5. Procédé selon la revendication 4, caractérisé en ce qu'il comprend en outre une étape (13) de transmission du contexte d'exécution de l'application depuis le second moyen de traitement (TE) de données vers le premier moyen de traitement de données (CP), et en ce que le déploiement (9) en parallèle de l'exécution de l'application, des éléments (CA2, CA4) de l'application non sélectionnés en tant qu'éléments prioritaires, est réalisé en fonction du contexte d'exécution transmis.
6. Procédé selon l'une quelconque des revendications 1 à 5, caractérisé en ce que les éléments (CA2, CA4) de l'application non sélectionnés en tant qu'éléments prioritaires, sont déployés (9) sur le second moyen de traitement (TE) en parallèle de l'exécution (5) de l'application, d'une manière synchrone.
7. Procédé selon l'une quelconque des revendications 1 à 5, caractérisé en ce que les éléments (CA2, CA4) de l'application non sélectionnés en tant qu'éléments prioritaires, sont déployés (9) sur le second moyen de traitement (TE) en parallèle de l'exécution (5) de l'application, d'une manière asynchrone.
8. Procédé selon l'une quelconque des revendications 1 à 7, caractérisé en ce qu'il comprend en outre une étape de sélection d'au moins un élément (CA3, CA6) de l'application en tant qu'élément non prioritaire, les éléments non prioritaires de l'application étant déployés (7) sur le second moyen de traitement (TE) uniquement s'ils sont appelés au cours de l'exécution (5) de l'application.
9. Procédé selon l'une quelconque des revendications 2 à 8, caractérisé en ce qu'en fin d'exécution (5) de l'application, il comprend en outre une étape de mise à jour des indicateurs de priorité respectifs des éléments (CA) de l'application en fonction des éléments (CA) qui ont été utilisés durant l'exécution de l'application.
10. Objet électronique (CP) comprenant un moyen de description (DAP) pour décrire une application (AP) composée de plusieurs éléments distants répartis (CA, CX), et un moyen de traitement (PI) pour déployer l'application en vue de son exécution à l'extérieur (TE) de l'objet électronique, en fonction du moyen de description de l'application, caractérisé en ce que le moyen de description (DAP) comporte au moins un indicateur de priorité pour sélectionner au moins un élément (CAl) en tant qu'élément prioritaire de l'application, et en ce que le moyen pour déployer l'application ne déploie que les éléments prioritaires avant d'autoriser l'exécution de l'application.
11. Objet électronique selon la revendication 10, caractérisé en ce qu'il est de type carte à microcontrôleur.
12. Système de déploiement d'application comprenant un objet électronique portable (CP) du type carte à microcontrôleur, un terminal (TE) connecté à un réseau de transmission de données (RT) et comportant un moyen pour communiquer avec l'objet électronique portable (CP), l'objet électronique portable comprenant un moyen de description (DAP) pour décrire une application (AP) composée de plusieurs éléments distants répartis (CA, CX) accessibles au terminal par le réseau de transmission de données (RT), et un moyen de traitement (PI) pour déployer l'application sur le terminal (TE) en vue de son exécution par le terminal, en fonction du moyen de description de l'application, caractérisé en ce que le moyen de description (DAP) comporte au moins un indicateur de priorité pour sélectionner au moins un élément en tant qu'élément prioritaire de l'application, et en ce que le moyen pour déployer l'application ne déploie que les éléments prioritaires avant de déclencher l'exécution de l'application déployée sur le terminal (TE).
PCT/FR2002/001635 2001-05-18 2002-05-15 Deploiement d'application depuis une carte a puce WO2002095697A1 (fr)

Priority Applications (4)

Application Number Priority Date Filing Date Title
DE60222410T DE60222410T2 (de) 2001-05-18 2002-05-15 Auslösung einer anwendung auf einer chipkarte
US10/477,948 US7387258B2 (en) 2001-05-18 2002-05-15 Application deployment from a smart card
JP2002592080A JP4645998B2 (ja) 2001-05-18 2002-05-15 スマート・カードからアプリケーションを展開する方法
EP02727708A EP1395962B1 (fr) 2001-05-18 2002-05-15 Deploiement d'application depuis une carte a puce

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
FR01/06606 2001-05-18
FR0106606A FR2824929B1 (fr) 2001-05-18 2001-05-18 Deploiement d'application depuis une carte a puce

Publications (1)

Publication Number Publication Date
WO2002095697A1 true WO2002095697A1 (fr) 2002-11-28

Family

ID=8863455

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/FR2002/001635 WO2002095697A1 (fr) 2001-05-18 2002-05-15 Deploiement d'application depuis une carte a puce

Country Status (8)

Country Link
US (1) US7387258B2 (fr)
EP (1) EP1395962B1 (fr)
JP (1) JP4645998B2 (fr)
CN (1) CN1269084C (fr)
AT (1) ATE373292T1 (fr)
DE (1) DE60222410T2 (fr)
FR (1) FR2824929B1 (fr)
WO (1) WO2002095697A1 (fr)

Families Citing this family (22)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7035595B1 (en) * 2002-01-10 2006-04-25 Berkana Wireless, Inc. Configurable wireless interface
JP4209789B2 (ja) * 2003-03-19 2009-01-14 株式会社リコー ファイル作成方法、サーバ、記録媒体及びプログラム追加システム
JP4597568B2 (ja) * 2003-07-15 2010-12-15 パナソニック株式会社 セキュアデバイス、情報処理端末、及び情報処理システム
US8095179B2 (en) * 2004-10-14 2012-01-10 Nokia Corporation Proxy smart card applications
US8700729B2 (en) 2005-01-21 2014-04-15 Robin Dua Method and apparatus for managing credentials through a wireless network
US8763081B2 (en) * 2006-04-03 2014-06-24 Bridgeport Networks, Inc. Network based authentication
JP5998702B2 (ja) * 2012-07-24 2016-09-28 富士通株式会社 情報処理システム、サーバ、携帯端末装置および制御プログラム
CA2801730C (fr) 2013-01-11 2021-03-02 Ibm Canada Limited - Ibm Canada Limitee Agent logiciel itinerant mobile comportant un itineraire et des donnees
US9805070B2 (en) 2013-07-09 2017-10-31 Oracle International Corporation Dynamic migration script management
US9996562B2 (en) 2013-07-09 2018-06-12 Oracle International Corporation Automated database migration architecture
US11157664B2 (en) 2013-07-09 2021-10-26 Oracle International Corporation Database modeling and analysis
US9747311B2 (en) 2013-07-09 2017-08-29 Oracle International Corporation Solution to generate a scriptset for an automated database migration
US9491072B2 (en) 2013-07-09 2016-11-08 Oracle International Corporation Cloud services load testing and analysis
US10776244B2 (en) 2013-07-09 2020-09-15 Oracle International Corporation Consolidation planning services for systems migration
US9967154B2 (en) 2013-07-09 2018-05-08 Oracle International Corporation Advanced customer support services—advanced support cloud portal
US9792321B2 (en) 2013-07-09 2017-10-17 Oracle International Corporation Online database migration
US9762461B2 (en) 2013-07-09 2017-09-12 Oracle International Corporation Cloud services performance tuning and benchmarking
FR3037685B1 (fr) * 2015-06-22 2018-11-02 Idemia France Procede et systeme ameliores de selection implicite d'une application dans un element securise, a partir d'un message recu
DE112015007179T5 (de) * 2015-12-10 2018-08-23 Mitsubishi Electric Corporation Informationsverarbeitungsvorrichtung, Informationsverarbeitungsverfahren und Informationsverarbeitungsprogramm
US11036696B2 (en) 2016-06-07 2021-06-15 Oracle International Corporation Resource allocation for database provisioning
CN109840148B (zh) * 2019-01-22 2020-10-13 飞天诚信科技股份有限公司 一种多应用智能卡操作系统及其更新应用优先级的方法
US11256671B2 (en) 2019-09-13 2022-02-22 Oracle International Corporation Integrated transition control center

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5212369A (en) * 1990-01-25 1993-05-18 Gemplus Card International Method of loading applications programs into a memory card reader having a microprocessor, and a system for implementing the method
US5659735A (en) * 1994-12-09 1997-08-19 Object Technology Licensing Corp. Object-oriented system for program version and history database management system for various program components
EP0866612A1 (fr) * 1996-09-11 1998-09-23 Matsushita Electronics Corporation Appareil de reception/d'execution de programme pouvant commencer l'execution d'un programme meme lorsque seulement une partie du programme est re ue, et emetteur de programme destine a cet appareil
WO1999007007A2 (fr) * 1997-07-29 1999-02-11 Catharon Productions, Inc. Systeme informatise et procede associe pour le controle optimal de la mise en memoire et du transfert de programmes informatiques sur reseau informatique
WO2000034891A2 (fr) * 1998-12-04 2000-06-15 Koninklijke Philips Electronics N.V. Systeme de prise en charge d'activites
EP1039719A2 (fr) * 1999-03-19 2000-09-27 Citicorp Development Center, Inc. Procédé et installation permettant le developpement d'application avec carte à puces dans les réseaux de données

Family Cites Families (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0520085A (ja) 1991-07-15 1993-01-29 Nippon Sofuto Kk プログラム実行方法及びそのシステム
JPH0554205A (ja) 1991-08-21 1993-03-05 Sharp Corp Icカードシステム
FR2752071B1 (fr) 1996-07-30 1998-12-18 Thomson Csf Lecteur pour cartes a puce a interface homme-machine amelioree
JPH10171662A (ja) 1996-12-05 1998-06-26 Hitachi Ltd アプリケーション実行方法
JPH10240538A (ja) 1997-02-25 1998-09-11 Nec Corp プログラムロード方式
JPH11282686A (ja) 1998-03-30 1999-10-15 Hitachi Ltd ネットワークコンピュータシステム
JP2000010786A (ja) 1998-06-22 2000-01-14 Nec Corp サーバ・クライアント通信装置と同装置を用いたプログラムダウンロード方法
US6604157B1 (en) * 1999-02-19 2003-08-05 Hewlett-Packard Development Company System and method for allowing a user to select and scan from a peripheral to a target application on a host system
US6529992B1 (en) 1999-07-26 2003-03-04 Iomega Corporation Self-contained application disk for automatically launching application software or starting devices and peripherals
JP3671759B2 (ja) * 1999-08-26 2005-07-13 株式会社日立製作所 ソフトウェア配布方法およびシステム

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5212369A (en) * 1990-01-25 1993-05-18 Gemplus Card International Method of loading applications programs into a memory card reader having a microprocessor, and a system for implementing the method
US5659735A (en) * 1994-12-09 1997-08-19 Object Technology Licensing Corp. Object-oriented system for program version and history database management system for various program components
EP0866612A1 (fr) * 1996-09-11 1998-09-23 Matsushita Electronics Corporation Appareil de reception/d'execution de programme pouvant commencer l'execution d'un programme meme lorsque seulement une partie du programme est re ue, et emetteur de programme destine a cet appareil
WO1999007007A2 (fr) * 1997-07-29 1999-02-11 Catharon Productions, Inc. Systeme informatise et procede associe pour le controle optimal de la mise en memoire et du transfert de programmes informatiques sur reseau informatique
WO2000034891A2 (fr) * 1998-12-04 2000-06-15 Koninklijke Philips Electronics N.V. Systeme de prise en charge d'activites
EP1039719A2 (fr) * 1999-03-19 2000-09-27 Citicorp Development Center, Inc. Procédé et installation permettant le developpement d'application avec carte à puces dans les réseaux de données

Also Published As

Publication number Publication date
FR2824929A1 (fr) 2002-11-22
ATE373292T1 (de) 2007-09-15
JP4645998B2 (ja) 2011-03-09
EP1395962B1 (fr) 2007-09-12
DE60222410D1 (de) 2007-10-25
CN1533555A (zh) 2004-09-29
CN1269084C (zh) 2006-08-09
DE60222410T2 (de) 2008-06-05
US20040178261A1 (en) 2004-09-16
US7387258B2 (en) 2008-06-17
JP2004531826A (ja) 2004-10-14
EP1395962A1 (fr) 2004-03-10
FR2824929B1 (fr) 2003-08-08

Similar Documents

Publication Publication Date Title
EP1395962B1 (fr) Deploiement d&#39;application depuis une carte a puce
FR2711026A1 (fr) Système de gestion de la consommation de consultations de données sur un réseau de télécommunications.
CA2309293A1 (fr) Procede, carte a puce et terminaux pour effectuer des transactions a travers un reseau de telecommunication
WO2004068809A1 (fr) Procede de presentation d’etat d’un utilisateur utilisant plusieurs equipements de communication
EP1817890A1 (fr) Procede, systeme et carte a microcontroleur pour la communication de services d&#39;application depuis une carte a microcontroleur vers un terminal
FR2832233A1 (fr) Reconfiguration de composants programmables dans un appareil electronique
EP2327236B1 (fr) Centre ussd générique d&#39;applications et de services réseaux
FR2815801A1 (fr) Protocole de transmission d&#39;une pluralite de flux logiques d&#39;echange multiple de couples de commande/reponse sur un canal physique unique d&#39;echange entre maitre et esclave et systeme de suivi et de controle d&#39;execution d&#39;appliquettes
WO2007144509A2 (fr) Dispositif de memorisation amovible et appareil electronique aptes a l &#39; autre et procede de sauvegarde de donnees d &#39; environnement
EP1337979B1 (fr) Deploiement d&#39;application depuis une carte a puce
EP1402487A1 (fr) Procede et dispositif de traitement de donnees pour la personnalisation d&#39;une application sur un dispositif communicant portatif, par exemple une carte a puce
EP3987390A1 (fr) Système d&#39;applications de service pour terminaux de paiement
EP1569489B1 (fr) Procédé de génération automatique de profils actifs pour terminal de télécommunications
EP1337980A1 (fr) Carte a puce avec descripteur d&#39;application
FR2819072A1 (fr) Procede de synchronisation de donnees sur une liaison serie
EP1065866A1 (fr) Méthode et dispositif de contrôle d&#39;accès à des services disponibles depuis un terminal de télécommunications
WO2002008897A1 (fr) Protocole d&#39;echange de messages entre applications implantees sur un systeme embarque, et systeme embarque correspondant
EP1233383A1 (fr) Procédé et dispositif de gestion d&#39;applications de cartes à puce
WO2003073273A1 (fr) Procede et dispositif de gestion decentralisee et personnalisee de services
Melazzi et al. The Simplicity Project: easing the burden of using complex and heterogeneous ICT devices and services Part II: State of the Art of Related Tecnologies
WO2001020565A1 (fr) Systeme et methode de chargement de donnees dans une carte a puce a travers un reseau de telecommunication au moyen de mels
WO2005059847A1 (fr) Carte a microcircuit multi-compte permettant la restriction d’une fonctionnalite a un compte et procede de communication correspondant
WO2001057699A2 (fr) Microcontroleur et procede pour la gestion d&#39;applications interactives
EP1358638A1 (fr) Systeme de paiement electronique a travers un reseau de telecommunication

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NO NZ OM PH PL PT RO RU SD SE SG SI SK SL TJ TM TN TR TT TZ UA UG US UZ VN YU ZA ZM ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW MZ SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
WWE Wipo information: entry into national phase

Ref document number: 2002727708

Country of ref document: EP

Ref document number: 2002592080

Country of ref document: JP

WWE Wipo information: entry into national phase

Ref document number: 20028144244

Country of ref document: CN

WWP Wipo information: published in national office

Ref document number: 2002727708

Country of ref document: EP

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

WWE Wipo information: entry into national phase

Ref document number: 10477948

Country of ref document: US

WWG Wipo information: grant in national office

Ref document number: 2002727708

Country of ref document: EP