Client device information for controlling access to web applications

US12579247B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-12579247-B2
Application numberUS-202318452177-A
CountryUS
Kind codeB2
Filing dateAug 18, 2023
Priority dateSep 19, 2016
Publication dateMar 17, 2026
Grant dateMar 17, 2026

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

The described technology provides for plural application processes including at least one application in a browser to reliably acquire device information that can be used by other processes to accurately determine whether the plural applications are running on the same client device and/or are associated with aspects of the same client device. The more reliable determination of the devices associated with respective application processes can be used for various purposes such as, for example, user access management capabilities such as improved single sign-on (SSO) capability and/or improved multiple login prevention (MLP) capability.

First claim

Opening claim text (preview).

The invention claimed is: 1 . A system comprising: a client device comprising a first processing system having at least one processor, wherein the first processing system is configured to perform operations comprising: executing, on the client device, (1) a first client application in a web browser, the first client application providing a first client-side portion of a web application; (2) a second client application providing a second client-side portion of the web application; and (3) a service application configured to obtain, from an operating system of the first processing system, at least one piece of client identifying information that uniquely identifies the first processing system and to provide the obtained at least one piece of client identifying information to the first client application and to the second client application each of which is executing at a different privilege level than the service application, wherein the first client application and the second client application obtain the obtained at least one piece of client identifying information from the service application, at least one of the first client application or the second client application has insufficient access privileges to obtain the information unique to the first processing system directly from the operating system, wherein the first client application transmits a first request with the obtained at least one piece of client identifying information, and wherein the second client application transmits a second request with the obtained at least one piece of client identifying information; and at least one server device comprising a second processing system having at least one processor, wherein the second processing system is configured to execute a server-side process of the web application and to perform operations comprising: receiving the first request from the first client application and the second request from the second client application, the first request including a first client identifying information and the second request including second client identifying information; and performing a first action which includes enabling the first and second client applications to share a login session if the second client identifying information corresponds to the first client identifying information, and performing a second action which includes disabling a login session for at least one of the first and second client applications if the second client identifying information does not correspond to the first client identifying information. 2 . The system according to claim 1 , wherein the second processing system is further configured to provide for disabling a session represented by a session identifier provided by the first client application or the second client application if it is determined that the second client identifying information does not correspond to the first client identifying information. 3 . The system according to claim 1 , wherein the obtained at least one piece of identifying information is at least partly based upon a unique identifier of a hardware element or a software element in the first processing system. 4 . The system according to claim 1 , wherein the obtained at least one piece of client identifying information is at least partly based upon a unique identifier associated with a software element in the first processing system. 5 . The system according to claim 1 , wherein the service application includes a server process, and wherein communication between the service application and the first client application is based upon at least HTTP. 6 . The system according to claim 5 , wherein, upon startup, the service application automatically binds to a first available port by sequentially searching from a predetermined port. 7 . The system according to claim 5 , wherein the communication includes a HTTP query which includes a request portion having included therein a timestamp. 8 . The system according to claim 7 , wherein the first client application is further configured to, upon receiving a response to the HTTP query, compare a timestamp returned with the response against a current time and accept the response only if the time difference between the returned timestamp and the current time is less than a predetermined interval. 9 . The system according to claim 7 , wherein a request parameter of the HTTP query is encrypted, and a command identifier in the HTTP query is not encrypted. 10 . A method performed in a client device by a first processing system having at least one processor, the method comprising: running on the client device (A) a first client application in a web browser, the first client application providing a first client-side portion of a web application, (B) a second client application providing a second client-side portion of the web application, and (C) a service application configured to obtain, from an operating system of the first processing system, at least one piece of client identifying information that uniquely identifies the first processing system and to provide the obtained at least one piece of client identifying information to the first client application and to the second client application each of which is executing at a different privilege level than the service application, wherein the first client application, the second client application and the service application run on the client device; obtaining, by the first client application and the second client application, the obtained at least one piece of client identifying information from the service application, wherein at least one of the first client application or the second client application has insufficient access privileges to obtain the information unique to the first processing system directly from the operating system; transmitting to a server-side process of the web application, by the first client application and the second client application, respective requests including the obtained at least one piece of client identifying information; and responsive to a response received from the server-side process for the second request, determining further processing of at least one of the first client application or the second client application. 11 . The method according to claim 10 , wherein the obtained at least one piece of client identifying information comprises information unique to the first processing system. 12 . The method according to claim 11 , wherein the service application obtains the information unique to the first processing system from an operating system of the first processing system, and wherein at least one of the first client application or the second client application has insufficient access privileges to obtain the information unique to the first processing system directly from the operating system. 13 . The method according to claim 10 , further comprising: providing, by the second processing system, for disabling, by the second a session represented by a session identifier provided by the first client application or the second client application if it is determined that the second client identifying information does not correspond to the first client identifying information. 14 . The method according to claim 10 , wherein the service application is a server process, and wherein communication between the service application and the first client application is based upon at least HTTP. 15 . The method according to claim 14 , wherein, upon startup, the service application automatically binds to a first available port by sequentially searching from a predetermin

Assignees

Inventors

Classifications

  • Multiple levels of security · CPC title

  • wherein the data content is protected, e.g. by encrypting or encapsulating the payload · CPC title

  • Setup of application sessions (admission control or resource allocation in data switching networks H04L47/70) · CPC title

  • based on web technology, e.g. hypertext transfer protocol [HTTP] · CPC title

  • Migration or transfer of sessions · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US12579247B2 cover?
The described technology provides for plural application processes including at least one application in a browser to reliably acquire device information that can be used by other processes to accurately determine whether the plural applications are running on the same client device and/or are associated with aspects of the same client device. The more reliable determination of the devices asso…
Who is the assignee on this patent?
Nasdaq Inc
What technology area does this patent fall under?
Primary CPC classification G06F21/44. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Mar 17 2026 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 7 related publications on this page (citations in our corpus or others sharing the same primary CPC).