KR102566262B1 - Service server and operating method thereof - Google Patents

Service server and operating method thereof Download PDF

Info

Publication number
KR102566262B1
KR102566262B1 KR1020210045821A KR20210045821A KR102566262B1 KR 102566262 B1 KR102566262 B1 KR 102566262B1 KR 1020210045821 A KR1020210045821 A KR 1020210045821A KR 20210045821 A KR20210045821 A KR 20210045821A KR 102566262 B1 KR102566262 B1 KR 102566262B1
Authority
KR
South Korea
Prior art keywords
user terminal
screen
service server
app
key input
Prior art date
Application number
KR1020210045821A
Other languages
Korean (ko)
Other versions
KR20220139632A (en
Inventor
강민용
임준순
조다영
강경훈
이은정
한정안
이민홍
Original Assignee
주식회사 엘지유플러스
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 주식회사 엘지유플러스 filed Critical 주식회사 엘지유플러스
Priority to KR1020210045821A priority Critical patent/KR102566262B1/en
Publication of KR20220139632A publication Critical patent/KR20220139632A/en
Application granted granted Critical
Publication of KR102566262B1 publication Critical patent/KR102566262B1/en

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/1066Session management
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/10Architectures or entities
    • H04L65/1063Application servers providing network services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/80Responding to QoS
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/21Server components or server architectures
    • H04N21/222Secondary servers, e.g. proxy server, cable television Head-end
    • H04N21/2223Secondary servers, e.g. proxy server, cable television Head-end being a public access point, e.g. for downloading to or uploading from clients
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/47End-user applications
    • H04N21/478Supplemental services, e.g. displaying phone caller identification, shopping application
    • H04N21/4782Web browsing, e.g. WebTV
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/80Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
    • H04N21/81Monomedia components thereof
    • H04N21/8166Monomedia components thereof involving executable data, e.g. software
    • H04N21/8173End-user applications, e.g. Web browser, game

Abstract

일 실시 예에 따른 서비스 서버의 동작 방법은, 사용자 단말로부터 웹 앱(Web app)의 실행 요청을 수신하는 동작; 상기 실행 요청 및 상기 사용자 단말에 대응하는 액세스 정보에 기초하여 상기 사용자 단말로 화면을 제공하는 동작; 및 상기 사용자 단말로 화면 제공 중 상기 사용자 단말로부터 수신된 키 입력 신호의 유형에 대응하는 정보를 상기 사용자 단말로 전송하고, 상기 키 입력 신호의 유형에 기초하여 상기 사용자 단말과의 세션(session) 연결을 유지할지 결정하는 동작을 포함할 수 있다. 그 외에도 다양한 실시 예들이 가능할 수 있다.An operating method of a service server according to an embodiment includes receiving an execution request of a web app from a user terminal; providing a screen to the user terminal based on the execution request and access information corresponding to the user terminal; and transmitting information corresponding to the type of key input signal received from the user terminal to the user terminal while providing the screen to the user terminal, and establishing a session connection with the user terminal based on the type of the key input signal. It may include an operation of determining whether to keep . In addition, various embodiments may be possible.

Description

서비스 서버 및 그 동작 방법{SERVICE SERVER AND OPERATING METHOD THEREOF}Service server and its operating method {SERVICE SERVER AND OPERATING METHOD THEREOF}

본 개시의 다양한 실시 예들은 서비스 서버 및 그의 동작 방법에 관한 것으로, 보다 상세하게는 사용자 단말로 화면을 제공하는 서비스 서버 및 그의 동작 방법에 관한 것이다.Various embodiments of the present disclosure relate to a service server and an operating method thereof, and more particularly, to a service server providing a screen to a user terminal and an operating method thereof.

최근 클라우드 스트리밍(Cloud streaming) 기술의 발전으로 저사양의 사용자 단말로 고사양의 어플리케이션을 구동할 수 있는 가상화 기술이 게임 서비스를 중심으로 많이 제안되고 있다.Recently, with the development of cloud streaming technology, virtualization technology capable of driving high-specification applications with low-specification user terminals has been proposed mainly for game services.

관련 선행기술로, 한국 등록특허공보 10-1795537호(발명의 명칭: 네트워크 환경 적응형 클라우드 스트리밍 서비스 제공 시스템 및 그 방법, 출원인: 경북대학교 산학협력단)가 있다. 해당 등록특허공보에는 클라우드 서버에서 비디오 서버와 클라우드 서버 간의 네트워크 상태 및 클라우드 서버와 사용자 단말 간의 네트워크 상태를 모두 고려하여 사용자 단말로 전송할 비디오 품질을 설정함으로써, 사용자 단말을 통해 출력되는 비디오의 재생 품질을 향상시키는 네트워크 환경 적응형 클라우드 스트리밍 시스템 및 그 방법이 개시된다.As a related prior art, there is Korean Patent Registration No. 10-1795537 (title of invention: network environment adaptive cloud streaming service providing system and method, applicant: Kyungpook National University Industry-University Cooperation Foundation). According to the registered patent publication, the reproduction quality of the video output through the user terminal is improved by setting the video quality to be transmitted to the user terminal by considering both the network status between the video server and the cloud server and the network status between the cloud server and the user terminal in the cloud server. A network environment adaptive cloud streaming system and method for improving are disclosed.

클라우드 스트리밍 기반 서비스의 경우 다수의 사용자에게 서비스를 제공하므로, 접속하고 있는 사용자들의 세션(session)을 관리하는 것이 서비스 품질에 중요한 영향을 미칠 수 있다.In the case of a cloud streaming-based service, since a service is provided to a large number of users, managing sessions of connected users may have a significant impact on service quality.

사용자가 클라우드 서버와 세션 연결을 유지할 필요가 없는 경우에도 연결이 유지된다면 서버에서 리소스의 낭비가 발생하고, 보다 많은 사람들에게 서비스가 제공되지 못할 수 있다.Even if the user does not need to maintain a session connection with the cloud server, if the connection is maintained, a waste of resources occurs in the server and the service may not be provided to more people.

다만, 기술적 과제는 상술한 기술적 과제들로 한정되는 것은 아니며, 또 다른 기술적 과제들이 존재할 수 있다.However, the technical challenges are not limited to the above-described technical challenges, and other technical challenges may exist.

일 실시 예에 따르면, 서비스 서버는 사용자 단말 각각에 대한 액세스(access) 정보를 저장하는 데이터베이스; 상기 사용자 단말로부터 수신된 키 입력 신호의 유형을 결정하고, 웹 앱(Web app)을 실행하는 브라우저; 및 프로세서를 포함하고, 상기 프로세서는, 상기 사용자 단말로부터 웹 앱(Web app)의 실행 요청을 수신하는 동작; 상기 실행 요청 및 상기 사용자 단말에 대응하는 상기 액세스 정보에 기초하여 상기 사용자 단말로 화면을 제공하는 동작; 및 상기 사용자 단말로 화면 제공 중 상기 사용자 단말로부터 수신된 키 입력 신호의 유형에 대응하는 정보를 상기 사용자 단말로 전송하고, 상기 키 입력 신호의 유형에 기초하여 상기 사용자 단말과의 세션(session) 연결을 유지할지 결정하는 동작을 수행할 수 있다.According to one embodiment, the service server includes a database for storing access information for each user terminal; a browser that determines the type of key input signal received from the user terminal and executes a web app; and a processor, wherein the processor receives an execution request of a web app from the user terminal; providing a screen to the user terminal based on the execution request and the access information corresponding to the user terminal; and transmitting information corresponding to the type of key input signal received from the user terminal to the user terminal while providing the screen to the user terminal, and establishing a session connection with the user terminal based on the type of the key input signal. It is possible to perform an operation to determine whether to keep .

일 실시 예에 따르면, 상기 프로세서는, 상기 키 입력 신호가 상기 웹 앱 내 포커싱(focusing) 이동 신호인 경우, 상기 사용자 단말로 상기 포커싱 이동에 따른 화면을 전송하고, 상기 사용자 단말과의 세션 연결을 유지하는 동작을 수행할 수 있다.According to an embodiment, when the key input signal is a focusing movement signal within the web app, the processor transmits a screen according to the focusing movement to the user terminal and establishes a session connection with the user terminal. maintenance can be performed.

일 실시 예에 따르면, 상기 프로세서는, 상기 키 입력 신호가 네이티브 앱(native app) 실행 요청인 경우, 상기 사용자 단말에 대응하는 액세스 정보를 저장하는 동작; 및 상기 사용자 단말로 상기 네이티브 앱 실행 신호를 전송하고, 상기 사용자 단말과의 세션 연결을 중단하는 동작을 수행할 수 있다.According to an embodiment, the processor may further include: storing access information corresponding to the user terminal when the key input signal is a native app execution request; and transmitting the native app execution signal to the user terminal and stopping the session connection with the user terminal.

일 실시 예에 따르면, 상기 프로세서는, 상기 사용자 단말에서 상기 네이티브 앱 실행이 종료되고 상기 사용자 단말로부터 세션 연결 요청을 수신한 경우, 상기 사용자 단말과 세션을 연결하는 동작; 및 상기 사용자 단말에 대응하는 상기 액세스 정보에 기초하여 상기 사용자 단말로 화면을 제공하는 동작을 더 수행할 수 있다.According to an embodiment, the processor may include: connecting a session with the user terminal when the execution of the native app is terminated in the user terminal and a session connection request is received from the user terminal; and providing a screen to the user terminal based on the access information corresponding to the user terminal.

일 실시 예에 따르면, 상기 프로세서는, 상기 키 입력 신호가 상기 웹 앱과 다른 웹 앱(Web app) 실행 요청인 경우, 상기 사용자 단말에 대응하는 액세스 정보를 저장하는 동작; 및 상기 사용자 단말로 상기 다른 웹 앱에 대한 실행 신호를 전송하고, 상기 사용자 단말과의 세션 연결을 중단하는 동작을 수행할 수 있다.According to one embodiment, the processor, when the key input signal is a web app execution request different from the web app, storing access information corresponding to the user terminal; and transmitting an execution signal for the other web app to the user terminal and stopping the session connection with the user terminal.

일 실시 예에 따르면, 상기 프로세서는, 상기 사용자 단말로부터 상기 다른 웹 앱 실행 요청을 수신하는 경우, 상기 사용자 단말과 세션을 연결하는 동작; 및 상기 실행 요청 및 상기 사용자 단말에 대응하는 상기 액세스 정보에 기초하여 상기 사용자 단말로 화면을 제공하는 동작을 더 수행할 수 있다.According to one embodiment, the processor, when receiving the other web app execution request from the user terminal, the operation of connecting the session with the user terminal; and providing a screen to the user terminal based on the execution request and the access information corresponding to the user terminal.

일 실시 예에 따르면, 상기 액세스 정보는, 사용자 단말 정보, 상기 사용자 단말로 이전에 제공된 웹 앱(Web app)에 대한 정보, 상기 사용자 단말로 제공된 상기 앱 각각의 최종 화면에 대한 화면 정보 및 상기 최종 화면 내 포인터의 위치에 대한 포커싱 정보를 포함하고, 상기 화면 정보는 초기 화면, 상기 초기 화면에서의 입력에 따른 1차 화면 및 상기 1차 화면에서의 입력에 따른 2차 화면 중 어느 하나에 대한 식별정보일 수 있다.According to an embodiment, the access information includes user terminal information, information about a web app previously provided to the user terminal, screen information about the final screen of each of the apps provided to the user terminal, and the final screen information. Includes focusing information on a location of a pointer on a screen, and the screen information identifies any one of an initial screen, a primary screen according to an input on the initial screen, and a secondary screen according to an input on the primary screen. may be information.

일 실시 예에 따르면, 상기 프로세서는, 상기 브라우저에서 실행된 상기 웹 앱의 렌더링된 이미지 중, 이전 화면에서 변경된 영역의 이미지를 캡쳐(capture)하여 상기 사용자 단말로 화면을 제공할 수 있다.According to an embodiment, the processor may capture an image of a region changed from a previous screen among rendered images of the web app executed in the browser and provide the screen to the user terminal.

일 실시 예에 따르면, 서비스 서버의 동작 방법은, 사용자 단말로부터 웹 앱(Web app)의 실행 요청을 수신하는 동작; 상기 실행 요청 및 상기 사용자 단말에 대응하는 액세스 정보에 기초하여 상기 사용자 단말로 화면을 제공하는 동작; 및 상기 사용자 단말로 화면 제공 중 상기 사용자 단말로부터 수신된 키 입력 신호의 유형에 대응하는 정보를 상기 사용자 단말로 전송하고, 상기 키 입력 신호의 유형에 기초하여 상기 사용자 단말과의 세션(session) 연결을 유지할지 결정하는 동작을 포함할 수 있다.According to an embodiment, a method of operating a service server may include receiving an execution request of a web app from a user terminal; providing a screen to the user terminal based on the execution request and access information corresponding to the user terminal; and transmitting information corresponding to the type of key input signal received from the user terminal to the user terminal while providing the screen to the user terminal, and establishing a session connection with the user terminal based on the type of the key input signal. It may include an operation of determining whether to keep .

일 실시 예에 따르면, 상기 서비스 서버의 동작 방법은, 상기 키 입력 신호가 상기 웹 앱 내 포커싱(focusing) 이동 신호인 경우, 상기 사용자 단말로 상기 포커싱 이동에 따른 화면을 전송하고, 상기 사용자 단말과의 세션 연결을 유지하는 동작을 포함할 수 있다.According to an embodiment, the operating method of the service server may include, when the key input signal is a focusing movement signal in the web app, transmits a screen according to the focusing movement to the user terminal, and transmits a screen corresponding to the focusing movement to the user terminal and It may include an operation to maintain the session connection of.

일 실시 예에 따르면, 상기 서비스 서버의 동작 방법은, 상기 키 입력 신호가 네이티브 앱(native app) 실행 요청인 경우, 상기 사용자 단말에 대응하는 액세스 정보를 저장하는 동작; 및 상기 사용자 단말로 상기 네이티브 앱 실행 신호를 전송하고, 상기 사용자 단말과의 세션 연결을 중단하는 동작을 포함할 수 있다.According to one embodiment, the operating method of the service server may include: storing access information corresponding to the user terminal when the key input signal is a native app execution request; and transmitting the native app execution signal to the user terminal and stopping the session connection with the user terminal.

일 실시 예에 따르면, 상기 서비스 서버의 동작 방법은, 상기 사용자 단말에서 상기 네이티브 앱 실행이 종료되고 상기 사용자 단말로부터 세션 연결 요청을 수신한 경우, 상기 사용자 단말과 세션을 연결하는 동작; 및 상기 사용자 단말에 대응하는 액세스 정보에 기초하여 상기 사용자 단말로 화면을 제공하는 동작을 더 포함할 수 있다.According to an embodiment, the operating method of the service server may include: connecting a session with the user terminal when execution of the native app is terminated in the user terminal and a session connection request is received from the user terminal; and providing a screen to the user terminal based on the access information corresponding to the user terminal.

일 실시 예에 따르면, 상기 서비스 서버의 동작 방법은, 상기 키 입력 신호가 상기 웹 앱과 다른 웹 앱(Web app) 실행 요청인 경우, 상기 사용자 단말에 대응하는 액세스 정보를 저장하는 동작; 및 상기 사용자 단말로 상기 다른 웹 앱에 대한 실행 신호를 전송하고, 상기 사용자 단말과의 세션 연결을 중단하는 동작을 포함할 수 있다.According to one embodiment, the operating method of the service server may include, when the key input signal is a request to execute a web app different from the web app, storing access information corresponding to the user terminal; and transmitting an execution signal for the other web app to the user terminal and stopping the session connection with the user terminal.

일 실시 예에 따르면, 상기 서비스 서버의 동작 방법은, 상기 사용자 단말로부터 상기 다른 웹 앱 실행 요청을 수신하는 경우, 상기 사용자 단말과 세션을 연결하는 동작; 및 상기 실행 요청 및 상기 사용자 단말에 대응하는 액세스 정보에 기초하여 상기 사용자 단말로 화면을 제공하는 동작을 더 포함할 수 있다.According to an embodiment, the operating method of the service server may include: connecting a session with the user terminal when receiving a request to run another web app from the user terminal; and providing a screen to the user terminal based on the execution request and the access information corresponding to the user terminal.

일 실시 예에 따르면, 상기 액세스 정보는, 사용자 단말 정보, 상기 사용자 단말로 이전에 제공된 웹 앱(Web app)에 대한 정보, 상기 사용자 단말로 제공된 상기 앱 각각의 최종 화면에 대한 화면 정보 및 상기 최종 화면 내 포인터의 위치에 대한 포커싱 정보를 포함하고, 상기 화면 정보는 초기 화면, 상기 초기 화면에서의 입력에 따른 1차 화면 및 상기 1차 화면에서의 입력에 따른 2차 화면 중 어느 하나에 대한 식별정보일 수 있다.According to an embodiment, the access information includes user terminal information, information about a web app previously provided to the user terminal, screen information about the final screen of each of the apps provided to the user terminal, and the final screen information. Includes focusing information on a location of a pointer on a screen, and the screen information identifies any one of an initial screen, a primary screen according to an input on the initial screen, and a secondary screen according to an input on the primary screen. may be information.

일 실시 예에 따르면, 상기 실행 요청 및 상기 사용자 단말에 대응하는 상기 액세스 정보에 기초하여 상기 사용자 단말로 화면을 제공하는 동작은, 브라우저에서 실행된 상기 웹 앱의 렌더링된 이미지 중, 이전 화면에서 변경된 영역의 이미지를 캡쳐(capture)하여 상기 사용자 단말로 화면을 제공하는 동작을 포함할 수 있다.According to an embodiment, the operation of providing a screen to the user terminal based on the execution request and the access information corresponding to the user terminal is a change from a previous screen among rendered images of the web app executed in the browser. An operation of capturing an image of an area and providing a screen to the user terminal may be included.

다양한 실시 예에 따르면, 서비스 서버는 사용자 단말로 화면을 제공함에 있어 액세스(access) 정보를 활용하여 보다 빠르게 사용자 단말의 이전 접속 화면을 제공할 수 있다.According to various embodiments, the service server may provide a previous access screen of the user terminal more quickly by utilizing access information in providing the screen to the user terminal.

다양한 실시 예에 따르면, 서비스 서버는 화면 가상화를 통해 사용자 단말로 화면 제공 중 수신된 사용자의 키 입력 신호의 유형을 결정하고, 유형에 따라 사용자 단말과의 세션 연결을 유지할지 결정하여 다수 사용자의 동시 접속 환경을 고려한 서비스를 제공할 수 있다.According to various embodiments, the service server determines the type of a user's key input signal received while providing a screen to a user terminal through screen virtualization, and determines whether or not to maintain a session connection with the user terminal according to the type, so that multiple users can simultaneously A service considering the connection environment can be provided.

이 외에, 본 문서를 통해 직접적 또는 간접적으로 파악되는 다양한 효과들이 제공될 수 있다.In addition to this, various effects identified directly or indirectly through this document may be provided.

도 1은 다양한 실시 예들에 따른 서비스 서버의 구성도이다.
도 2는 다양한 실시 예들에 따른 세션 서버를 통해 사용자 단말과 서비스 서버 간 세션이 연결되는 동작을 설명하기 위한 도면이다.
도 3a 및 도 3b는 다양한 실시 예들에 따른 액세스 정보 데이터베이스에 포함된 화면 정보를 설명하기 위한 도면이다.
도 4a 및 도 4b는 다양한 실시 예들에 따른 키 입력 신호의 유형을 설명하기 위한 도면이다.
도 5는 다양한 실시 예들에 따른 키 입력 신호가 포커싱 이동 신호인 경우 화면이 제공되는 방법을 설명하기 위한 흐름도이다.
도 6은 다양한 실시 예들에 따른 키 입력 신호가 네이티브 앱(native app) 실행 요청인 경우 화면이 제공되는 방법을 설명하기 위한 흐름도이다.
도 7은 다양한 실시 예들에 따른 키 입력 신호가 다른 웹 앱(web app) 실행 요청인 경우 화면이 제공되는 방법을 설명하기 위한 흐름도이다.
도 8은 다양한 실시 예들에 따른 서비스 서버가 사용자 단말과의 세션 연결을 유지할지 결정하는 방법을 설명하기 위한 흐름도이다.
도 9는 다양한 실시 예들에 따른 키 입력 신호가 포커싱 이동 신호인 경우 서비스 서버의 동작 방법을 설명하기 위한 흐름도이다.
도 10은 다양한 실시 예들에 따른 키 입력 신호가 네이티브 앱(native app) 실행 요청인 경우 서비스 서버의 동작 방법을 설명하기 위한 흐름도이다.
도 11은 다양한 실시 예들에 따른 키 입력 신호가 다른 웹 앱(web app) 실행 요청인 경우 서비스 서버의 동작 방법을 설명하기 위한 흐름도이다.
1 is a configuration diagram of a service server according to various embodiments.
2 is a diagram for explaining an operation of connecting a session between a user terminal and a service server through a session server according to various embodiments.
3A and 3B are diagrams for explaining screen information included in an access information database according to various embodiments.
4A and 4B are diagrams for explaining types of key input signals according to various embodiments.
5 is a flowchart illustrating a method of providing a screen when a key input signal is a focusing movement signal according to various embodiments of the present disclosure.
6 is a flowchart illustrating a method of providing a screen when a key input signal is a request to execute a native app, according to various embodiments.
7 is a flowchart illustrating a method of providing a screen when a key input signal is a request to execute another web app according to various embodiments.
8 is a flowchart illustrating a method of determining whether a service server maintains a session connection with a user terminal according to various embodiments.
9 is a flowchart illustrating an operation method of a service server when a key input signal is a focusing movement signal according to various embodiments.
10 is a flowchart illustrating a method of operating a service server when a key input signal is a native app execution request according to various embodiments.
11 is a flowchart illustrating an operation method of a service server when a key input signal is a request to execute another web app according to various embodiments.

실시예들에 대한 특정한 구조적 또는 기능적 설명들은 단지 예시를 위한 목적으로 개시된 것으로서, 다양한 형태로 변경되어 구현될 수 있다. 따라서, 실제 구현되는 형태는 개시된 특정 실시예로만 한정되는 것이 아니며, 본 명세서의 범위는 실시예들로 설명한 기술적 사상에 포함되는 변경, 균등물, 또는 대체물을 포함한다.Specific structural or functional descriptions of the embodiments are disclosed for illustrative purposes only, and may be changed and implemented in various forms. Therefore, the form actually implemented is not limited only to the specific embodiments disclosed, and the scope of the present specification includes changes, equivalents, or substitutes included in the technical idea described in the embodiments.

제1 또는 제2 등의 용어를 다양한 구성요소들을 설명하는데 사용될 수 있지만, 이런 용어들은 하나의 구성요소를 다른 구성요소로부터 구별하는 목적으로만 해석되어야 한다. 예를 들어, 제1 구성요소는 제2 구성요소로 명명될 수 있고, 유사하게 제2 구성요소는 제1 구성요소로도 명명될 수 있다.Although terms such as first or second may be used to describe various components, such terms should only be construed for the purpose of distinguishing one component from another. For example, a first element may be termed a second element, and similarly, a second element may be termed a first element.

어떤 구성요소가 다른 구성요소에 "연결되어" 있다고 언급된 때에는, 그 다른 구성요소에 직접적으로 연결되어 있거나 또는 접속되어 있을 수도 있지만, 중간에 다른 구성요소가 존재할 수도 있다고 이해되어야 할 것이다.It should be understood that when an element is referred to as being “connected” to another element, it may be directly connected or connected to the other element, but other elements may exist in the middle.

단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다. 본 명세서에서, "포함하다" 또는 "가지다" 등의 용어는 설명된 특징, 숫자, 단계, 동작, 구성요소, 부분품 또는 이들을 조합한 것이 존재함으로 지정하려는 것이지, 하나 또는 그 이상의 다른 특징들이나 숫자, 단계, 동작, 구성요소, 부분품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.Singular expressions include plural expressions unless the context clearly dictates otherwise. In this specification, terms such as "comprise" or "have" are intended to designate that the described feature, number, step, operation, component, part, or combination thereof exists, but one or more other features or numbers, It should be understood that the presence or addition of steps, operations, components, parts, or combinations thereof is not precluded.

다르게 정의되지 않는 한, 기술적이거나 과학적인 용어를 포함해서 여기서 사용되는 모든 용어들은 해당 기술 분야에서 통상의 지식을 가진 자에 의해 일반적으로 이해되는 것과 동일한 의미를 가진다. 일반적으로 사용되는 사전에 정의되어 있는 것과 같은 용어들은 관련 기술의 문맥상 가지는 의미와 일치하는 의미를 갖는 것으로 해석되어야 하며, 본 명세서에서 명백하게 정의하지 않는 한, 이상적이거나 과도하게 형식적인 의미로 해석되지 않는다.Unless defined otherwise, all terms used herein, including technical or scientific terms, have the same meaning as commonly understood by one of ordinary skill in the art. Terms such as those defined in commonly used dictionaries should be interpreted as having a meaning consistent with the meaning in the context of the related art, and unless explicitly defined in this specification, it should not be interpreted in an ideal or excessively formal meaning. don't

이하, 실시예들을 첨부된 도면들을 참조하여 상세하게 설명한다. 첨부 도면을 참조하여 설명함에 있어, 도면 부호에 관계없이 동일한 구성 요소는 동일한 참조 부호를 부여하고, 이에 대한 중복되는 설명은 생략하기로 한다.Hereinafter, embodiments will be described in detail with reference to the accompanying drawings. In the description with reference to the accompanying drawings, the same reference numerals are given to the same components regardless of reference numerals, and overlapping descriptions thereof will be omitted.

<서비스 서버><service server>

도 1은 다양한 실시 예들에 따른 서비스 서버의 구성도이다.1 is a configuration diagram of a service server according to various embodiments.

도 1을 참조하면, 네트워크를 통해 서비스를 제공하는 서비스 서버(100)의 구성도가 도시된다. 일 실시 예에 따르면, 서비스 서버(100)는 네트워크를 통해 사용자 단말(180)로 사용자 인터페이스(UI: user interface)를 가상화한 화면을 제공할 수 있다. 일 실시 예에 따르면, 서비스 서버(100)는 사용자 단말 각각에 대한 액세스(access) 정보를 저장하는 액세스 정보 데이터베이스(130), 사용자 단말(180)로부터 수신된 키 입력 신호의 유형을 결정하고, 웹 앱(web app)을 실행하는 브라우저(browser) 및 프로세서(120)를 포함할 수 있다.Referring to FIG. 1 , a configuration diagram of a service server 100 providing services through a network is shown. According to an embodiment, the service server 100 may provide a virtualized user interface (UI) screen to the user terminal 180 through a network. According to an embodiment, the service server 100 determines the type of key input signal received from the access information database 130 that stores access information for each user terminal, the user terminal 180, and the web It may include a browser and a processor 120 that executes an app (web app).

일 실시 예에 따르면, 서비스 서버(100)는 클라우드 스트리밍(cloud streaming) 방식으로 사용자 단말(180)로 화면을 제공하고, 사용자 단말(180)에서는 입력 및 출력만 이뤄지게 함으로써 사용자 단말(180)의 성능에 관계없이 고사양의 서비스를 제공할 수 있다. 구체적으로, 사용자 단말(180)과 네트워크를 통해 연결된 서비스 서버(100)에서 실행 화면을 구현하여 사용자 단말(180)에서 실행된 것과 같은 사용자 경험이 제공될 수 있다. 일 실시 예에 따르면, 서비스 서버(100)는 사용자 인터페이스(UI) 어플리케이션, 게임 어플리케이션 등 다양한 어플리케이션을 실행하고, 그 실행 화면을 캡쳐(capture)하여 캡쳐 이미지를 생성한 후, 이를 인코딩하여 스트리밍 방식으로 사용자 단말(180)로 전송할 수 있다. 서비스 서버(100)는 사용자 단말(180)로부터 전송되는 사용자 입력에 따라 어플리케이션을 구동시키며, 변경된 실행 화면을 캡쳐하여 스트리밍 방식으로 사용자 단말(180)로 전송할 수 있다.According to an embodiment, the service server 100 provides a screen to the user terminal 180 in a cloud streaming method, and allows only input and output to be performed in the user terminal 180, thereby performing the performance of the user terminal 180. Regardless, high-end services can be provided. Specifically, the same user experience as executed in the user terminal 180 may be provided by implementing an execution screen in the service server 100 connected to the user terminal 180 through a network. According to an embodiment, the service server 100 executes various applications such as a user interface (UI) application and a game application, captures the execution screen, generates a captured image, encodes it, and converts it into a streaming method. It can be transmitted to the user terminal 180. The service server 100 may drive an application according to a user input transmitted from the user terminal 180 and may capture and transmit the changed execution screen to the user terminal 180 in a streaming manner.

도 1에 도시되지는 않았지만, 서비스 서버(100)는 미디어 플랫폼과 연동하여 사용자 단말(180)로 컨텐츠를 제공할 수 있다. 미디어 플랫폼은 서비스 서버(100)와는 별도로 소정의 컨텐츠를 스트리밍 방식으로 제공할 수 있다. 예를 들어, 실시간 방송 혹은 VOD와 같은 동영상으로 이루어진 컨텐츠가 제공될 수 있고, 이러한 미디어 플랫폼은 서비스 서버(100)와는 다른 서비스 제공자에 의해 운영될 수 있다.Although not shown in FIG. 1 , the service server 100 may provide content to the user terminal 180 in conjunction with a media platform. The media platform may provide predetermined content in a streaming method separately from the service server 100 . For example, real-time broadcasting or video content such as VOD may be provided, and this media platform may be operated by a service provider different from the service server 100 .

일 실시 예에 따르면, 사용자 단말(180)과 서비스 서버(100)의 연동을 통해, 미디어 플랫폼(미도시)에서 제공되는 컨텐츠가 서비스 서버(100)에서 제공하는 컨텐츠와 융합되어 사용자 단말(180)로 제공될 수 있다. 예를 들어, 미디어 플랫폼에서 제공되는 실시간 방송 또는 VOD의 비디오 영상에, 서비스 서버(100)가 제공하는 사용자 인터페이스 화면이 융합될 수 있다. 다만 이에 제한되는 것은 아니며, 다양한 실시 예들에 따른 서비스 서버(100)에 따르면 다양한 종류의 서로 다른 컨텐츠가 융합될 수 있다.According to an embodiment, content provided by a media platform (not shown) is fused with content provided by the service server 100 through interworking between the user terminal 180 and the service server 100, and thus the user terminal 180 can be provided as For example, a user interface screen provided by the service server 100 may be fused with video images of real-time broadcasting or VOD provided by a media platform. However, it is not limited thereto, and according to the service server 100 according to various embodiments, various types of different contents may be converged.

다양한 실시 예들에 따르면, 사용자 단말(180)로부터 전송된 사용자 입력에 따라 서비스 서버(100)가 구동시키는 어플리케이션에는 웹 앱(web app) 및 네이티브 앱(native app)이 포함될 수 있다. 웹 앱(web app)은 브라우저(150)를 통해 실행되고, 네이티브 앱(native app)은 사용자 단말(180)에 최적화된 언어로 개발되어 사용자 단말(180)에서 실행된다는 점에 차이가 있을 수 있다.According to various embodiments, applications driven by the service server 100 according to user input transmitted from the user terminal 180 may include web apps and native apps. There may be a difference in that a web app is executed through the browser 150 and a native app is developed in a language optimized for the user terminal 180 and executed in the user terminal 180. .

일 실시 예에 따르면, 사용자 단말(180)로부터 웹 앱 실행 요청이 수신되는 경우 프로세서(120)는 브라우저(150)로 웹 앱 실행을 요청하고, 브라우저(150)에서 렌더링된 이미지에 대해 프로세서(120)가 캡쳐하고, 캡쳐 이미지를 사용자 단말(180)로 스트리밍 방식으로 제공할 수 있다.According to an embodiment, when a web app execution request is received from the user terminal 180, the processor 120 requests the browser 150 to execute the web app, and the processor 120 requests the browser 150 to execute the web app. ) may capture and provide the captured image to the user terminal 180 in a streaming manner.

일 실시 예에 따르면, 사용자 단말(180)로부터 네이티브 앱의 실행 요청이 수신되는 경우 프로세서(120)는 네이티브 앱 실행과 관련된 정보를 사용자 단말(180)로 전송하고, 사용자 단말(180)에서 네이티브 앱이 실행될 수 있다. 예를 들어, 사용자 단말(180)로부터 VOD 컨텐츠 재생 요청이 수신된 경우, 프로세서(120)는 해당 VOD 컨텐츠 정보를 미디어 플랫폼(미도시) 등으로부터 수신하여 사용자 단말(180)로 전송하고, 사용자 단말(180)에서 네이티브 앱인 VOD 플레이어를 통해 해당 VOD 컨텐츠가 재생될 수 있다.According to an embodiment, when a request to run a native app is received from the user terminal 180, the processor 120 transmits information related to running the native app to the user terminal 180, and the user terminal 180 transmits the native app execution request. this can be executed. For example, when a request for playing VOD content is received from the user terminal 180, the processor 120 receives corresponding VOD content information from a media platform (not shown) and transmits it to the user terminal 180, and In 180, the corresponding VOD content can be played through the VOD player, which is a native app.

일 실시 예에 따른 네트워크는 사용자 단말(180)과 서비스 서버(100) 간 연결하여 데이터를 전달하기 위한 구성으로, 다양한 형태의 통신망으로 구현될 수 있다. 예컨대, WLAN(Wireless LAN), 와이파이(Wi-Fi), 와이브로(Wibro), 와이맥스(Wimax), HSDPA(High Speed Downlink Packet Access) 등의 무선 통신 방식 또는 이더넷(Ethernet), xDSL(ADSL, VDSL), HFC(Hybrid Fiber Coaxial Cable), FTTC(Fiber to The Curb), FTTH(Fiber To The Home) 등의 유선 통신 방식이 이용될 수 있다. 또한, 상술한 통신 방식 이외에도 기타 널리 공지되었거나 향후 개발될 모든 형태의 통신 방식을 포함할 수 있다.The network according to an embodiment is a configuration for transferring data by connecting the user terminal 180 and the service server 100, and may be implemented as various types of communication networks. For example, a wireless communication method such as WLAN (Wireless LAN), Wi-Fi, Wibro, Wimax, HSDPA (High Speed Downlink Packet Access) or Ethernet, xDSL (ADSL, VDSL) , HFC (Hybrid Fiber Coaxial Cable), FTTC (Fiber to The Curb), FTTH (Fiber To The Home), etc. may be used. In addition, in addition to the above-described communication methods, all types of communication methods that are widely known or will be developed in the future may be included.

일 실시 예에 따르면, 사용자 단말(180)은 네트워크를 통해 서비스 서버(100)와 다양한 정보를 송수신할 수 있는 장치를 의미하며, 정보 송수신을 위한 클라우드 UI 클라이언트(cloud UI client), 프로그램 및 프로토콜을 저장하는 메모리(미도시), 프로그램을 실행하기 위한 프로세서(미도시) 등을 포함할 수 있다. 일 실시 예에 따르면, 사용자 단말(180)은 서비스 서버(100) 또는 미디어 플랫폼(미도시)와 통신하기 위한 통신 모듈, 사용자로부터 정보를 입력 받기 위한 입력 모듈, 서비스 서버(100) 또는 미디어 플랫폼으로부터 제공받은 화면 또는 컨텐츠를 디스플레이하기 위한 디스플레이 모듈 등을 더 포함할 수 있다. According to an embodiment, the user terminal 180 refers to a device capable of transmitting and receiving various information to and from the service server 100 over a network, and includes a cloud UI client, program, and protocol for transmitting and receiving information. It may include a memory (not shown) for storing, a processor (not shown) for executing a program, and the like. According to an embodiment, the user terminal 180 includes a communication module for communicating with the service server 100 or a media platform (not shown), an input module for receiving information from a user, and a service server 100 or a media platform. A display module for displaying the provided screen or content may be further included.

일 실시 예에 따르면, 사용자 단말(180)이 스마트 tv의 셋톱박스인 경우, 리모콘을 통해 입력된 사용자 입력을 수신하여 서비스 서버(100)로 전송할 수 있다. 사용자 단말(180)은 사용자 입력을 통해 서비스 서버(100)로 요청을 전송하고, 이에 대응하여 서비스 서버(100)로부터 스트리밍 데이터를 수신하고 재생할 수 있다. 사용자 단말(100)은 인코딩된 스트리밍 데이터를 수신하여 디코딩할 수 있고, 디코딩된 데이터를 렌더링하여 출력할 수 있다. 사용자 단말(100)은 다양한 형태로 구현될 수 있으며, 예를 들어 스마트폰(smart phone), 태블릿(tablet), PDA(personal digital assistants), PMP(portable multimedia player), 스마트 TV(smart tv)의 셋톱박스(set-top box), 데스크탑 컴퓨터, 랩탑 컴퓨터 등일 수 있다.According to an embodiment, when the user terminal 180 is a set-top box of a smart TV, a user input input through a remote control may be received and transmitted to the service server 100 . The user terminal 180 may transmit a request to the service server 100 through a user input, and receive and reproduce streaming data from the service server 100 in response thereto. The user terminal 100 may receive and decode the encoded streaming data, and render and output the decoded data. The user terminal 100 may be implemented in various forms, for example, smart phone (smart phone), tablet (tablet), PDA (personal digital assistants), PMP (portable multimedia player), smart TV (smart tv) It may be a set-top box, desktop computer, laptop computer, or the like.

일 실시 예에 따르면, 프로세서(120)는 사용자 단말(180)로부터 수신한 요청에 기초하여 브라우저(150)로 웹 앱 실행을 요청할 수 있고, 브라우저(150)는 프로세서(120)로부터의 웹 앱(web app)실행 요청에 따라 웹 앱을 실행할 수 있다. 일 실시 예에 따르면, 브라우저(150)는 웹 어플리케이션의 데이터, 예를 들어 HTML 기반의 웹 코드를 렌더링 및 파싱할 수 있고, 프로세서(120)는 브라우저(150)가 렌더링한 이미지를 실시간으로 캡쳐(capture)하고, 캡쳐 이미지를 인코딩하여 스트리밍 방식으로 사용자 단말(180)로 제공할 수 있다.According to an embodiment, the processor 120 may request the browser 150 to execute a web app based on a request received from the user terminal 180, and the browser 150 may request the execution of a web app from the processor 120 ( web app) The web app can be executed according to the execution request. According to one embodiment, the browser 150 may render and parse data of a web application, for example, HTML-based web code, and the processor 120 may capture an image rendered by the browser 150 in real time ( capture), and encoding the captured image to provide it to the user terminal 180 in a streaming manner.

일 실시 예에 따르면, 서비스 서버(100)는 사용자 단말(180) 각각에 대한 액세스(access) 정보를 저장하는 액세스 정보 데이터베이스(130)를 포함할 수 있다. 액세스 정보 데이터베이스(130)는 도 1에서 서비스 서버(100)에 포함되는 것으로 도시되었지만, 이에 제한되는 것은 아니며 서비스 서버(100)와 별도의 서버에 포함되도록 구현될 수 있다.According to one embodiment, the service server 100 may include an access information database 130 that stores access information for each user terminal 180 . The access information database 130 is illustrated as being included in the service server 100 in FIG. 1 , but is not limited thereto and may be implemented to be included in a separate server from the service server 100 .

일 실시 예에 따르면, 프로세서(120)는 사용자 단말(180)로부터 웹 앱(web app) 실행 요청을 수신하는 경우 액세스 정보 데이터베이스(130)를 참조하여 사용자 단말(180)로 화면을 제공할 수 있다. 일 실시 예에 따르면, 액세스 정보 데이터베이스(130)에는 사용자 단말 정보(132), 사용자 단말로 이전에 제공되었던 웹 앱에 대한 정보(134), 사용자 단말로 제공되었던 앱 각각에서의 최종 화면에 대한 화면 정보(또는 ID)(136), 최종 화면 내 포인터의 위치에 대한 포커싱 정보(또는 ID)(138)가 포함될 수 있다. 다양한 실시 예에 따른 화면 정보(136)에 대해 도 3a 및 도 3b에서 상세히 설명된다.According to an embodiment, when receiving a web app execution request from the user terminal 180, the processor 120 may provide a screen to the user terminal 180 by referring to the access information database 130. . According to an embodiment, the access information database 130 includes user terminal information 132, information on web apps previously provided to the user terminal 134, and screens for final screens in each of the apps provided to the user terminal. Information (or ID) 136 and focusing information (or ID) 138 about the position of the pointer in the final screen may be included. Screen information 136 according to various embodiments will be described in detail with reference to FIGS. 3A and 3B.

일 실시 예에 따르면, 사용자 단말 정보(132), 앱 정보(134), 화면 정보(136) 및 포커싱 정보(138)는 각각에 대해 연동되어 저장될 수 있다. 즉, 사용자 단말 하나에 대해 이전에 접속했던 웹 앱 목록이 맵핑(mapping)되고, 각 웹 앱에 대한 최종 화면 정보가 맵핑되고, 각 최종 화면에 대한 포커싱 정보가 맵핑되어 저장될 수 있다.According to an embodiment, the user terminal information 132, app information 134, screen information 136, and focusing information 138 may be interlocked and stored. That is, a list of web apps accessed previously for one user terminal may be mapped, final screen information for each web app may be mapped, and focusing information for each final screen may be mapped and stored.

예를 들어, 사용자 단말(180)로부터 홈 앱 실행 요청이 수신된 경우, 프로세서(120)는 사용자 단말 정보(132)를 참조하여 사용자 단말(180)로 이전에 제공되었던 앱 정보(134)를 확인할 수 있고, 사용자 단말(180)로 이전에 홈 앱이 제공된 바 있다면 홈 앱 내 화면 중 제공되었던 최종 화면(예: 홈 앱의 메인화면)에 대한 정보(136) 및 최종 화면 내 포인터의 위치(예: 홈 앱의 메인화면 내 화살표의 좌표)에 대한 포커싱 정보(138)를 확인할 수 있다. 프로세서(120)는 이에 기초하여 브라우저(150)로 홈 앱의 메인화면을 실행하라고 요청할 수 있고, 브라우저(150)에서 렌더링된 이미지를 캡쳐하여 사용자 단말(180)로 화면을 제공할 수 있다. For example, when a home app execution request is received from the user terminal 180, the processor 120 refers to the user terminal information 132 to determine app information 134 previously provided to the user terminal 180. If the home app has been previously provided to the user terminal 180, information 136 on the final screen (eg, the main screen of the home app) provided among the screens in the home app and the position of the pointer in the final screen (eg : The focusing information 138 for the coordinates of the arrow in the main screen of the home app) can be checked. Based on this, the processor 120 may request the browser 150 to execute the main screen of the home app, and may capture an image rendered in the browser 150 and provide the screen to the user terminal 180 .

다양한 실시 예들에 따른 액세스 정보에 기초한 화면 제공으로 사용자는 보다 다이렉트하게 이전에 접속했던 화면에 액세스할 수 있고, 서비스 서버(100)는 리소스를 줄일 수 있다. By providing a screen based on access information according to various embodiments, a user can access a previously accessed screen more directly, and the service server 100 can reduce resources.

일 실시 예에 따르면, 프로세서(120)는 브라우저(150)에서 실행된 웹 앱의 렌더링된 이미지 전부가 아닌, 변경된 영역에 대해서만 캡쳐하여 전송할 수 있다. 구체적으로, 프로세서(120)는 브라우저(150)에서 렌더링된 이미지에 대해 이전 화면과 현재 화면을 분할(예를 들어, 40개의 타일로 분할)하여 비교하고, 변경된 영역의 이미지만 전송할 수 있다.According to one embodiment, the processor 120 may capture and transmit only the changed area, not all of the rendered images of the web app executed in the browser 150. Specifically, the processor 120 may divide the previous screen and the current screen with respect to the image rendered by the browser 150 (for example, divide into 40 tiles), compare them, and transmit only the image of the changed area.

일 실시 예에 따르면, 프로세서(120)는 사용자 단말(180)로 가상화 화면 제공 중 사용자 단말(180)로부터 수신된 키 입력 신호의 유형에 따라 다르게 동작할 수 있다. 일 실시 예에 따르면, 키 입력 신호의 유형에는 현재 제공 중인 웹 앱 내 포커싱 이동 신호, 네이티브 앱 실행 요청 및 다른 웹 앱 실행 요청이 포함될 수 있다. 사용자 단말(180)로부터 수신된 키 입력 신호의 유형은 브라우저(150)에 의해 결정될 수 있다. 다양한 실시 예들에 따른 서비스 서버(100)는 키 입력 신호의 유형에 따라 사용자 단말과의 세션 연결 유지 여부를 결정하여 다수 사용자의 동시 접속 환경을 고려한 서비스를 제공할 수 있다. 다양한 실시 예에 따른 키 입력 신호의 유형은 도 4a 및 도 4b에서 상세히 설명된다.According to an embodiment, the processor 120 may operate differently according to the type of key input signal received from the user terminal 180 while providing a virtualized screen to the user terminal 180 . According to an embodiment, the type of key input signal may include a focusing movement signal within a currently provided web app, a request to execute a native app, and a request to execute another web app. The type of key input signal received from the user terminal 180 may be determined by the browser 150 . The service server 100 according to various embodiments may determine whether or not to maintain a session connection with a user terminal according to the type of a key input signal to provide a service considering a simultaneous access environment of multiple users. Types of key input signals according to various embodiments are described in detail with reference to FIGS. 4A and 4B.

일 실시 예에 따르면, 키 입력 신호가 제공 중인 웹 앱 내 포커싱(focusing) 이동 신호인 경우 프로세서(120)는 포커싱 이동에 따른 화면을 전송하고, 사용자 단말(180)과의 세션(session) 연결을 유지할 수 있다. 다양한 실시 예에 따른 키 입력 신호가 제공 중인 웹 앱 내 포커싱 이동인 경우 화면이 제공되는 흐름도는 도 5에서 상세히 설명된다.According to an embodiment, when the key input signal is a focusing movement signal within the web app being provided, the processor 120 transmits a screen according to the focusing movement and establishes a session connection with the user terminal 180. can keep A flowchart in which a screen is provided when a key input signal is a focusing movement within a web app being provided according to various embodiments will be described in detail with reference to FIG. 5 .

일 실시 예에 따르면, 키 입력 신호가 네이티브 앱(native app) 실행 요청인 경우 프로세서(120)는 사용자 단말(180)에 대응하는 액세스(access) 정보를 액세스 정보 데이터베이스(130)에 저장하고, 사용자 단말로 네이티브 앱 실행 신호를 전송하고, 사용자 단말(180)과의 세션(session) 연결을 중단할 수 있다. 사용자 단말(180)에서 네이티브 앱 실행이 종료되고 다시 서비스 서버(100)로 세션 연결 요청이 전송되면, 프로세서(120)는 사용자 단말과 세션을 연결하고, 사용자 단말(180)에 대응하는 액세스 정보에 기초하여 사용자 단말(180)로 화면을 제공할 수 있다. 다양한 실시 예에 따른 키 입력 신호가 네이티브 앱 실행 요청인 경우 화면이 제공되는 흐름도는 도 6에서 상세히 설명된다.According to an embodiment, when the key input signal is a native app execution request, the processor 120 stores access information corresponding to the user terminal 180 in the access information database 130, and the user A native app execution signal may be transmitted to the terminal, and a session connection with the user terminal 180 may be stopped. When the execution of the native app is terminated in the user terminal 180 and a session connection request is transmitted to the service server 100 again, the processor 120 connects the user terminal and the session, and provides access information corresponding to the user terminal 180. Based on this, a screen may be provided to the user terminal 180 . A flowchart of providing a screen when a key input signal is a native app execution request according to various embodiments will be described in detail with reference to FIG. 6 .

일 실시 예에 따르면, 키 입력 신호가 제공 중인 웹 앱과 다른 웹 앱(web app)에 대한 실행 요청인 경우 프로세서(120)는 사용자 단말(180)에 대응하는 액세스(access) 정보를 저장하고, 사용자 단말로 다른 웹 앱 실행 신호를 전송하고, 사용자 단말(180)과의 세션(session) 연결을 중단할 수 있다. 세션 연결 중단 후 사용자 단말(180)로부터 다시 서비스 서버(100)로 해당 다른 웹 앱의 실행 요청이 수신되면, 프로세서(120)는 사용자 단말과 세션을 연결하고, 사용자 단말(180)에 대응하는 액세스 정보에 기초하여 사용자 단말(180)로 화면을 제공할 수 있다. 다양한 실시 예에 따른 키 입력 신호가 다른 웹 앱 실행 요청인 경우 화면이 제공되는 흐름도는 도 7에서 상세히 설명된다.According to an embodiment, when the key input signal is an execution request for a web app different from the web app being provided, the processor 120 stores access information corresponding to the user terminal 180, Another web app execution signal may be transmitted to the user terminal, and a session connection with the user terminal 180 may be stopped. When a request to execute another web app is received from the user terminal 180 to the service server 100 again after the session connection is interrupted, the processor 120 connects the session with the user terminal and accesses the user terminal 180 A screen may be provided to the user terminal 180 based on the information. A flowchart of providing a screen when a key input signal is a request to execute another web app according to various embodiments will be described in detail with reference to FIG. 7 .

도 2는 다양한 실시 예들에 따른 세션 서버를 통해 사용자 단말과 서비스 서버 간 세션이 연결되는 동작을 설명하기 위한 도면이다.2 is a diagram for explaining an operation of connecting a session between a user terminal and a service server through a session server according to various embodiments.

도 2를 참조하면, 도 1에서 설명한 서비스 서버(100)가 사용자 단말(180)과 세션 서버(200)를 통해 연결될 수 있다. 일 실시 예에 따르면, 세션 서버(200)는 서비스 서버(100)에 대한 노드와 관련된 정책을 수시로 또는 주기적으로 업데이트할 수 있고, 정책에 기초하여 서비스 서버를 결정할 수 있다. 일 실시 예에 따르면, 사용자 단말(180)로부터 서버 할당 요청이 수신되면, 세션 서버(200)는 정책에 기초하여 결정된 서비스 서버(100)를 복수 개(예를 들어, 3개) 선정하고, 서비스 서버(100)의 IP를 사용자 단말(180)로 전송할 수 있다. 사용자 단말(180)은 수신한 복수 개의 서비스 서버(100) IP 중 하나의 서비스 서버(100)로 세션 연결을 요청할 수 있고, 연결된 서비스 서버(100)로부터 스트리밍 방식으로 화면을 제공받을 수 있다. Referring to FIG. 2 , the service server 100 described in FIG. 1 may be connected to a user terminal 180 through a session server 200 . According to an embodiment, the session server 200 may frequently or periodically update a policy related to a node of the service server 100, and may determine a service server based on the policy. According to an embodiment, when a server allocation request is received from the user terminal 180, the session server 200 selects a plurality of (eg, three) service servers 100 determined based on the policy, and The IP of the server 100 may be transmitted to the user terminal 180 . The user terminal 180 may request a session connection to one service server 100 among the plurality of service server 100 IPs received, and may receive a screen from the connected service server 100 in a streaming manner.

다시 말하면, 도 2에서 서비스 서버들(100)은 세션 서버(200)와 연결되고, 세션 서버(200)는 사용자 단말(180)과 연결되는 것으로만 도시되었지만, 사용자 단말(180)이 세션 서버(200)로부터 서비스 서버들의 IP를 수신하고 하나의 서비스 서버로 세션 연결을 요청하면, 사용자 단말(180)과 해당 서비스 서버가 연결될 수 있다.In other words, although the service servers 100 in FIG. 2 are shown to be connected to the session server 200 and the session server 200 is only connected to the user terminal 180, the user terminal 180 is connected to the session server ( When IPs of service servers are received from 200) and session connection is requested to one service server, the user terminal 180 and the corresponding service server can be connected.

일 실시 예에 따르면, 복수의 서비스 서버(100)들은 각각 사용자 단말 각각에 대한 액세스 정보 데이터베이스(130)를 포함하거나, 액세스 정보 데이터베이스(130)가 포함된 별도의 서버를 통해 액세스 정보를 확인할 수 있다. 일 실시 예에 따르면, 액세스 정보는 복수의 서비스 서버들 간에 공통으로 업데이트되고 관리될 수 있다.According to an embodiment, each of the plurality of service servers 100 may include an access information database 130 for each user terminal or check access information through a separate server including the access information database 130. . According to an embodiment, access information may be commonly updated and managed among a plurality of service servers.

일 실시 예에 따르면, 사용자 단말(180)과 서비스 서버(100)와의 세션 연결이 중단된 후 다시 세션이 연결되는 경우, 세션 서버(200)에서 제공하는 서비스 서버의 IP가 정책에 따라 이전 서비스 서버의 IP와 달라질 수 있고, 사용자 단말(180)은 기존에 연결된 바 없는 서비스 서버와 연결될 수 있다. 기존에 연결된 바 없는 새로운 서비스 서버로 세션이 연결되어도, 모든 서비스 서버(100)는 공통으로 관리하는 사용자 단말 각각에 대한 액세스 정보를 확인할 수 있으므로 도 1에서 설명한 바와 같이 사용자 단말(180)은 액세스 정보에 기초하여 화면을 제공받을 수 있다.According to an embodiment, when the session connection between the user terminal 180 and the service server 100 is interrupted and then the session is reconnected, the IP of the service server provided by the session server 200 is changed to the previous service server according to the policy. may be different from the IP of, and the user terminal 180 may be connected to a service server that has not previously been connected. Even if a session is connected to a new service server that has not been previously connected, all service servers 100 can check access information for each user terminal that is commonly managed. As described in FIG. Based on this, a screen may be provided.

예를 들어, 사용자 단말(180)로부터 수신된 키 입력 신호의 유형이 네이티브 앱 실행 요청 또는 제공 중인 웹 앱이 아닌 다른 웹 앱의 실행 요청으로 결정된 경우, 서비스 서버(100)의 프로세서(120)는 사용자 단말(180)에 대응하는 액세스 정보를 저장하고 사용자 단말(180)과의 세션 연결을 중단한다. 사용자 단말(180)이 다시 서버 할당을 요청하여 세션 서버(200)로부터 기존 연결되었던 서비스 서버와 다른 서비스 서버의 IP를 수신해도, 다른 서비스 서버는 액세스 정보를 참조하여 사용자 단말(180)로 화면을 제공할 수 있다.For example, when the type of key input signal received from the user terminal 180 is determined to be a native app execution request or a web app execution request other than the web app being provided, the processor 120 of the service server 100 Access information corresponding to the user terminal 180 is stored and session connection with the user terminal 180 is terminated. Even if the user terminal 180 requests server allocation again and receives the IP of a service server different from the previously connected service server from the session server 200, the other service server refers to the access information and displays the screen to the user terminal 180. can provide

이하 설명되는 사용자 단말(180)과 서비스 서버(100)의 연결에는 간명한 설명을 위해 세션 서버(200)의 동작이 생략될 수 있으나, 사용자 단말(180)은 다시 서비스 서버와 연결되는 경우 세션 서버(200)의 노드 정책에 기초하여 기존 서비스 서버와 다른 서비스 서버로 연결될 수 있다.Although the operation of the session server 200 may be omitted for concise description in the connection between the user terminal 180 and the service server 100 described below, when the user terminal 180 is connected to the service server again, the session server Based on the node policy of (200), a service server different from the existing service server may be connected.

도 3a 및 도 3b는 다양한 실시 예들에 따른 액세스 정보 데이터베이스에 포함된 화면 정보를 설명하기 위한 도면이다.3A and 3B are diagrams for explaining screen information included in an access information database according to various embodiments.

도 3a를 참조하면, 액세스 정보 데이터베이스(130)에 포함된 화면 정보(136)를 설명하기 위해, 화면 간 계층이 도시되어 있다. 일 실시 예에 따르면, 사용자 단말(180)로부터 웹 앱 실행 요청을 수신하여 브라우저(150)를 통해 실행된 웹 앱 어플리케이션에는 화면 간 계층이 구분될 수 있다.Referring to FIG. 3A , to explain the screen information 136 included in the access information database 130, the hierarchy between screens is shown. According to an embodiment, a web app execution request received from the user terminal 180 and executed through the browser 150 may have hierarchies between screens.

일 실시 예에 따르면, 어플리케이션의 초기 화면(310)에서 다음 화면으로의 사용자 입력(예: 선택)에 의해 1차 화면(330)이 제공될 수 있다. According to an embodiment, the first screen 330 may be provided by a user's input (eg, selection) from the initial screen 310 of the application to the next screen.

일 실시 예에 따르면, 1차 화면(330)에서 이전 화면으로 돌아가는 사용자 입력(예: 상위 화면으로, 뒤로, 이전 화면으로 등에 대한 입력)으로 초기 화면(310)이 제공될 수 있고, 다음 화면으로의 사용자 입력(예: 선택)에 의해 2차 화면이 제공될 수 있다. According to an embodiment, the initial screen 310 may be provided as a user input to return to the previous screen from the primary screen 330 (eg, input to a higher screen, back, to a previous screen, etc.), and to the next screen. A second screen may be provided by a user's input (eg, selection).

일 실시 예에 따르면, 2차 화면(350)에서 이전 화면으로 돌아가는 사용자 입력(예: 상위 화면으로, 뒤로, 이전 화면으로 등에 대한 입력)으로 1차 화면(330)이 제공될 수 있고, 초기 화면으로 돌아가는 사용자 입력(예: 최상위 화면으로, 초기 화면으로, 처음으로 등에 대한 입력)으로 초기 화면(310)이 제공될 수 있다.According to an embodiment, the first screen 330 may be provided as a user input (eg, an input to a higher screen, back, to a previous screen, etc.) to return to the previous screen from the second screen 350, and the initial screen The initial screen 310 may be provided as a user input (eg, input to the top screen, to the initial screen, to the beginning, etc.) to return to .

도 3b를 참조하면, 사용자 단말(180)을 통해 디스플레이되는 초기 화면, 1차 화면, 2차 화면이 도시되어 있다. 일 실시 예에 따르면, 사용자 단말(180)(예: 스마트 tv의 셋톱박스)로부터 홈 앱(home app) 실행 요청(예: 리모콘을 통한 홈 앱 실행 요청)이 수신된 경우, 서비스 서버(100)의 프로세서(120)는 사용자 단말(180)로 초기 화면(360)을 제공할 수 있다. 일 실시 예에 따르면, 초기 화면(360)에서 영화 탭(365)에 대한 사용자 입력이 수신된 경우, 프로세서(120)는 사용자 단말(180)로 1차 화면(370)을 제공할 수 있다. 일 실시 예에 따르면, 1차 화면(370)에서 특정 영화 컨텐츠(375)에 대한 사용자 입력이 수신된 경우, 프로세서(120)는 사용자 단말(180)로 2차 화면(380)을 제공할 수 있다.Referring to FIG. 3B , an initial screen, a first screen, and a second screen displayed through the user terminal 180 are illustrated. According to an embodiment, when a home app execution request (eg, a home app execution request through a remote control) is received from the user terminal 180 (eg, a set-top box of a smart TV), the service server 100 The processor 120 of may provide the initial screen 360 to the user terminal 180 . According to an embodiment, when a user input for the movie tab 365 is received on the initial screen 360, the processor 120 may provide the first screen 370 to the user terminal 180. According to an embodiment, when a user input for a specific movie content 375 is received on the primary screen 370, the processor 120 may provide the secondary screen 380 to the user terminal 180. .

일 실시 예에 따르면, 도 3a 및 도 3b에서 1차 화면 및 2차 화면까지 도시되었지만, 이에 제한되지 않고 더 많은 계층의 화면이 존재할 수 있다. 액세스 정보 데이터베이스(130)에 포함된 화면 정보(136)에는 각 계층의 화면들(도 3a의 310, 330, 350 또는 도 3b의 360, 370, 380)에 대한 식별 정보가 포함될 수 있고, 구체적으로 액세스 정보 데이터베이스(130)에는 사용자 단말(180) 각각에 대해 이전에 접속한 웹 앱에 대한 정보 및 해당 앱 내에서의 최종 화면에 대한 식별 정보가 맵핑되어 저장될 수 있다.According to an embodiment, although the first screen and the second screen are illustrated in FIGS. 3A and 3B , more hierarchical screens may exist without being limited thereto. The screen information 136 included in the access information database 130 may include identification information for screens of each layer (310, 330, 350 in FIG. 3A or 360, 370, and 380 in FIG. 3B), and specifically In the access information database 130 , information on a web app previously accessed for each user terminal 180 and identification information on a final screen within the app may be mapped and stored.

도 4a 및 도 4b는 다양한 실시 예들에 따른 키 입력 신호의 유형을 설명하기 위한 도면이다.4A and 4B are diagrams for explaining types of key input signals according to various embodiments.

도 4a및 도 4b를 참조하면, 서비스 서버(100)에서 브라우저(150)를 통해 실행하고, 렌더링되어 사용자 단말(180)로 제공되는 웹 앱의 화면이 도시되어 있다. 일 실시 예에 따르면 도 1에서 설명한 바와 같이, 프로세서(120)는 사용자 단말(180)로 스트리밍 방식으로 도 4a 및 도 4b와 같은 화면 제공 중 사용자 단말(180)로부터 키 입력 신호를 수신하고, 브라우저(150)는 키 입력 신호의 유형을 결정할 수 있다.Referring to FIGS. 4A and 4B , a screen of a web app executed in the service server 100 through the browser 150 and rendered and provided to the user terminal 180 is shown. According to an embodiment, as described in FIG. 1, the processor 120 receives a key input signal from the user terminal 180 while providing the screen as shown in FIGS. 4A and 4B to the user terminal 180 in a streaming manner, and browser 150 may determine the type of key input signal.

일 실시 예에 따르면, 수신된 키 입력 신호는 제공 중인 웹 앱 내 포인터(410)의 포커싱(focusing) 이동 신호일 수 있다. 예를 들어, 사용자 단말(180)이 스마트 tv의 셋톱박스인 경우, 리모콘의 방향키 입력이 수신되면 브라우저(150)는 키 입력 신호의 유형을 포커싱 이동 신호라고 결정할 수 있다. 도 4a를 참조하면, 브라우저(150)는 제공 중인 웹 앱의 화면 내에서 기준점(예: 화면의 왼쪽 위 모서리)을 기준으로 방향키 입력에 따라 화면 내 포인터(410)의 포커싱을 이동할 수 있다.According to an embodiment, the received key input signal may be a focusing movement signal of the pointer 410 within the web app being provided. For example, when the user terminal 180 is a set-top box of a smart TV, upon receiving a direction key input from a remote control, the browser 150 may determine the type of the key input signal as a focusing movement signal. Referring to FIG. 4A , the browser 150 may move the focus of the pointer 410 within the screen according to a direction key input based on a reference point (eg, the upper left corner of the screen) within the screen of the web app being provided.

일 실시 예에 따르면, 수신된 키 입력 신호는 제공 중인 웹 앱이 아닌 다른 웹 앱(web app)에 대한 실행 요청일 수 있다. 예를 들어, 사용자 단말(180)이 스마트 tv의 셋톱박스인 경우, 브라우저(150)는 홈 앱 화면 제공 중 리모콘을 통해 키즈 앱에 대한 바로가기 버튼 입력이 수신되거나, 도 4a와 같이 홈 앱 초기 화면 내 키즈 앱 실행 위치(430)에서 포인터(410)를 통한 입력(예: '확인' 버튼 입력)이 수신되면 키 입력 신호의 유형을 제공 중인 웹 앱인 홈 앱과 다른 웹 앱, 즉 키즈 앱에 대한 실행 요청이라고 결정할 수 있다.According to an embodiment, the received key input signal may be an execution request for a web app other than the web app being provided. For example, when the user terminal 180 is a set-top box of a smart TV, the browser 150 receives a shortcut button input for a kids app through a remote control while providing a home app screen, or the initial home app as shown in FIG. 4a. When an input through the pointer 410 (for example, an 'OK' button input) is received at the kids app execution position 430 on the screen, the type of key input signal is provided to the home app, which is a web app, and the other web app, that is, the kids app. It can be decided that it is an execution request for

일 실시 예에 따르면, 수신된 키 입력 신호는 네이티브 앱에 대한 실행 요청일 수 있다. 일 실시 예에 따르면, 도 1에서 설명한 바와 같이, 서비스 서버(100)에서 전송된 컨텐츠 정보에 기초하여 사용자 단말(180)에서 네이티브 앱인 VOD 플레이어가 실행될 수 있다. 예를 들어 도 4b를 참조하면, 사용자 단말(180)이 스마트 tv의 셋톱박스인 경우, 브라우저(150)는 영화 재생하기 버튼(450) 위치에서 포인터를 통한 입력(예: '확인' 버튼 입력)이 수신되면 키 입력 신호의 유형을 네이티브 앱 실행 요청이라고 결정하고, 프로세서(120)는 미디어 플랫폼으로부터 컨텐츠 정보를 수신하여 해당 컨텐츠 정보와 VOD 플레이어의 실행 요청을 사용자 단말(180)로 전송할 수 있다. 사용자 단말(180)에서는 해당 컨텐츠 정보에 기초하여 네이티브 앱인 VOD 플레이어가 실행될 수 있다.According to an embodiment, the received key input signal may be an execution request for a native app. According to an embodiment, as described in FIG. 1 , a VOD player, which is a native app, may be executed in the user terminal 180 based on content information transmitted from the service server 100 . For example, referring to FIG. 4B , when the user terminal 180 is a set-top box of a smart TV, the browser 150 inputs through a pointer at the position of the play movie button 450 (eg, inputting the 'confirm' button). When this is received, the type of key input signal is determined as a native app execution request, and the processor 120 may receive content information from the media platform and transmit the corresponding content information and the VOD player execution request to the user terminal 180 . In the user terminal 180, a VOD player, which is a native app, may be executed based on corresponding content information.

도 5는 다양한 실시 예들에 따른 키 입력 신호가 포커싱 이동 신호인 경우 화면이 제공되는 방법을 설명하기 위한 흐름도이다.5 is a flowchart illustrating a method of providing a screen when a key input signal is a focusing movement signal according to various embodiments of the present disclosure.

도 2에서 설명한 바와 같이, 사용자 단말(180)이 세션 서버(200)를 통해 서비스 서버(100)와 연결되는 동작이 참조번호 510에서 설명된다. 사용자 단말(180)은 세션 서버(200)로 서비스 서버 할당을 요청할 수 있고(515), 세션 서버(200)는 노드 정책에 기초하여 복수 개(예를 들어, 3개)의 서비스 서버를 선정(520)하여 사용자 단말(180)로 서버의 IP를 전송할 수 있다(525).As described with reference to FIG. 2 , an operation in which the user terminal 180 is connected to the service server 100 through the session server 200 is described at reference number 510 . The user terminal 180 may request allocation of a service server to the session server 200 (515), and the session server 200 selects a plurality of (eg, three) service servers based on a node policy. 520) to transmit the IP of the server to the user terminal 180 (525).

도 5를 참조하면, 참조번호 530 내지 570을 참조하여 도 1에서 설명한 바와 같이 서비스 서버(100)에서 사용자 단말(180)로 스트리밍 방식으로 이미지를 전송하는 동작이 설명된다.Referring to FIG. 5 , an operation of transmitting an image from the service server 100 to the user terminal 180 in a streaming manner as described in FIG. 1 with reference to reference numerals 530 to 570 will be described.

일 실시 예에 따르면, 사용자 단말(180)은 수신한 서비스 서버의 IP를 기초로 서비스 서버(100)로 웹 앱(web app) 실행을 요청할 수 있다(530). 서비스 서버(100)의 프로세서(120)는 사용자 단말(180)에 대응하는 액세스 정보를 확인하고(535), 수신한 웹 앱 실행 요청 및 액세스 정보에 기초하여 브라우저(150)로 웹 앱 실행을 요청할 수 있다(540).According to an embodiment, the user terminal 180 may request execution of a web app to the service server 100 based on the received IP of the service server (530). The processor 120 of the service server 100 checks access information corresponding to the user terminal 180 (535), and requests the browser 150 to execute the web app based on the received web app execution request and access information. can (540).

예를 들어, 사용자 단말(180)은 이전에 홈 앱(home app)의 초기 화면(예: 도 3b의 참조번호 360)에서 영화 탭(예: 도 3b의 참조번호 365)을 선택하여 홈 앱의 1차 화면(예: 도 3b의 참조번호 370)까지 제공받던 중 세션 연결이 중단되었을 수 있다. 프로세서(120)는 참조번호 530에서 사용자 단말(180)로부터 홈 앱 실행 요청을 수신한 경우, 사용자 단말(180)에 대한 정보와 홈 앱에 대한 정보를 기초로 참조번호 535에서 액세스 정보를 확인할 수 있다. 액세스 정보 데이터베이스(130)와 관련하여 도 1에서 설명한 바와 같이, 프로세서(120)는 단말정보(132), 앱 정보(134), 화면 정보(136) 및 포커싱 정보(138)에 기초하여 사용자 단말(180)에 이전에 제공된 바 있는 홈 앱의 최종 화면인 1차 화면(예: 도 3b의 참조번호 370)을 실행할 것을 브라우저(150)로 요청할 수 있다.For example, the user terminal 180 previously selects a movie tab (eg, reference number 365 in FIG. 3B) on the initial screen (eg, reference number 360 of FIG. 3B) of the home app to view the home app. Session connection may be interrupted while being provided to the first screen (eg, reference numeral 370 in FIG. 3B). When receiving a home app execution request from the user terminal 180 at reference number 530, the processor 120 may check access information at reference number 535 based on the information on the user terminal 180 and the home app. there is. As described in FIG. 1 in relation to the access information database 130, the processor 120 is a user terminal based on the terminal information 132, the app information 134, the screen information 136, and the focusing information 138 ( 180), the browser 150 may be requested to execute the first screen (eg, reference numeral 370 in FIG. 3B), which is the final screen of the home app that has been previously provided.

도 2에서 세션 서버(200)의 동작에 대해 설명한 바와 같이, 사용자 단말(180)이 이전에 연결되었던 서비스 서버와 참조번호 530에서 실행 요청을 수신한 서비스 서버(100)의 IP는 다를 수 있으나, 액세스 정보 데이터베이스(130)는 복수의 서비스 서버들 간 공통으로 관리되기 때문에 새로 연결된 서비스 서버에서 이전에 연결되었던 서비스 서버에서 저장한 액세스 정보에 접근할 수 있다.As described for the operation of the session server 200 in FIG. 2, the IP of the service server 100 receiving the execution request at reference number 530 may be different from the service server to which the user terminal 180 was previously connected. Since the access information database 130 is commonly managed among a plurality of service servers, a newly connected service server can access access information stored in a previously connected service server.

일 실시 예에 따르면 브라우저(150)는 액세스 정보에 기초하여 웹 앱을 실행하고, 이미지를 렌더링할 수 있고(550), 프로세서(120)는 브라우저(150)에서 렌더링한 결과를 캡쳐하여(560) 사용자 단말(180)로 이미지를 전송할 수 있다(570). 도 1에서 설명한 바와 같이, 프로세서(120)는 브라우저(150)에서 렌더링된 이미지에 대해 이전 화면과 현재 화면을 분할(예를 들어, 40개의 타일로 분할)하여 비교하고, 변경된 영역의 이미지만 전송할 수 있다. 다양한 실시 예들에 따른 액세스 정보에 기초한 화면 제공으로 사용자는 보다 다이렉트하게 이전 접속 화면에 액세스할 수 있고, 서비스 서버(100)는 리소스를 줄일 수 있다.According to an embodiment, the browser 150 may execute a web app based on the access information and render an image (550), and the processor 120 may capture a result rendered by the browser 150 (560) An image may be transmitted to the user terminal 180 (570). As described in FIG. 1, the processor 120 compares the image rendered by the browser 150 by dividing the previous screen and the current screen (for example, into 40 tiles), and transmits only the image of the changed area. can By providing a screen based on access information according to various embodiments, a user can access a previous access screen more directly, and the service server 100 can reduce resources.

일 실시 예에 따르면, 서비스 서버(100)에서 사용자 단말(180)로 화면 제공(570) 중, 사용자 단말(180)로부터 키 입력 신호가 수신될 수 있다. 도 5의 참조번호 575 및 585는 키 입력 신호가 제공 중인 웹 앱 내 포커싱 이동인 경우이고, 도 6은 키 입력 신호가 네이티브 앱 실행 요청인 경우, 도 7은 키 입력 신호가 다른 웹 앱 실행 요청인 경우의 흐름도이다.According to an embodiment, a key input signal may be received from the user terminal 180 while providing a screen 570 from the service server 100 to the user terminal 180 . Reference numerals 575 and 585 in FIG. 5 indicate a case in which a key input signal is a focusing movement within a web app being provided, in FIG. 6 a case in which a key input signal is a request to execute a native app, and in FIG. It is a flow chart in the case of

일 실시 예에 따르면, 사용자 단말(180)로부터 앱 내 포커싱 이동 신호가 수신될 수 있다(575). 도 4a에서 설명한 바와 같이, 사용자 단말(180)이 스마트 tv의 셋톱박스이고 리모콘을 통한 방향키 입력이 수신되면, 브라우저(150)는 수신된 키 입력 신호가 제공 중인 웹 앱 화면 내 포커싱 이동 신호라고 결정할 수 있다. 도 5에서는 간명한 설명을 위해 생략되었지만, 브라우저(150)에서 포커싱 이동에 따른 화면을 렌더링하고, 프로세서(120)는 이전 화면과 비교하여 변경된 영역의 이미지만 사용자 단말(180)로 제공할 수 있다(585). According to an embodiment, an in-app focusing movement signal may be received from the user terminal 180 (575). As described in FIG. 4A, when the user terminal 180 is a set-top box of a smart TV and receives a direction key input through a remote control, the browser 150 determines that the received key input signal is a focusing movement signal within the web app screen being provided. can Although omitted for brevity in FIG. 5 , the browser 150 renders the screen according to the focusing movement, and the processor 120 compares it with the previous screen and provides only the image of the changed area to the user terminal 180. (585).

도 6은 다양한 실시 예들에 따른 키 입력 신호가 네이티브 앱(native app) 실행 요청인 경우 화면이 제공되는 방법을 설명하기 위한 흐름도이다.6 is a flowchart illustrating a method of providing a screen when a key input signal is a request to execute a native app, according to various embodiments.

도 6을 참조하면, 도 5에서 설명한 바와 같이 서비스 서버(100)에서 사용자 단말(180)로 화면 제공 중, 사용자 단말(180)로부터 네이티브 앱(예: VOD 플레이어) 실행 요청이 수신될 수 있다(615). 예를 들어, 도 4b에서 설명한 바와 같이, 사용자 단말(180)이 스마트 tv의 셋톱박스이고 영화 재생하기 버튼(예: 도 4b의 참조번호 450) 위치에서 포인터를 통한 입력(예: '확인' 버튼 입력)이 수신되면, 브라우저(150)는 수신된 키 입력 신호의 유형을 네이티브 앱 실행 요청이라고 결정할 수 있다. 도 6에서는 간명한 설명을 위해 생략되었지만, 키 입력 신호가 수신되고(615) 브라우저(150)가 키 입력 신호를 네이티브 앱 실행 요청이라고 결정할 수 있다. Referring to FIG. 6 , while a screen is provided from the service server 100 to the user terminal 180 as described in FIG. 5 , a request to execute a native app (eg, a VOD player) may be received from the user terminal 180 ( 615). For example, as described in FIG. 4B, the user terminal 180 is a set-top box of a smart TV, and an input through a pointer (eg, an 'OK' button) at a location of a movie play button (eg, reference numeral 450 in FIG. 4B) input) is received, the browser 150 may determine the type of the received key input signal as a native app execution request. Although omitted for brevity in FIG. 6 , the key input signal is received ( 615 ) and the browser 150 may determine that the key input signal is a native app execution request.

일 실시 예에 따르면, 수신된 키 입력 신호가 네이티브 앱 실행 요청인 경우 프로세서(120)는 사용자 단말(180)의 액세스 정보를 저장(620)할 수 있다. 일 실시 예에 따르면, 네이티브 앱 실행 요청(615)이 도 3b의 2차화면(380) 및 도 4b에서 설명한 바와 같이 홈 앱의 화면을 통한 컨텐츠 재생 요청인 경우, 프로세서(120)는 사용자 단말(180)에 대한 액세스 정보를 액세스 정보 데이터베이스(130)에 연동하여 저장할 수 있다. 예를 들어, 프로세서(120)는 사용자 단말(180)의 단말 식별 정보를 단말 정보(132)에, 사용자 단말(180)에 제공하던 웹 앱인 홈 앱이라는 정보를 앱 정보(134)에, 해당 홈 앱 내에서 제공하던 화면이 2차 화면(예: 도 3b의 2차화면(380))이라는 화면 식별 정보를 화면 정보(136)에, 그리고 2차 화면 내에서의 포인터의 위치를 포커싱 정보(138)에 연동하여 저장할 수 있다.According to an embodiment, when the received key input signal is a native app execution request, the processor 120 may store access information of the user terminal 180 (620). According to an embodiment, when the native app execution request 615 is a content playback request through the home app screen as described in the second screen 380 of FIG. 3B and FIG. 180) may be stored in association with the access information database 130. For example, the processor 120 transmits terminal identification information of the user terminal 180 to terminal information 132 and information about a home app, which is a web app that has been provided to the user terminal 180, to app information 134 and the corresponding home screen. Screen identification information indicating that the screen provided within the app is a secondary screen (eg, the secondary screen 380 in FIG. ) can be stored in conjunction with.

일 실시 예에 따르면, 프로세서(120)는 사용자 단말(180)에 대한 액세스 정보를 저장하고(620), 사용자 단말(180)로 네이티브 앱 실행 신호를 전송(625)한 후, 사용자 단말(180)과의 세션 연결을 중단할 수 있다(630). 프로세서(120)는 네이티브 앱 실행 신호를 전송(625)할 때 해당 컨텐츠 정보를 사용자 단말(180)로 함께 전송할 수 있고, 프로세서(120)는 사용자 단말과의 세션 연결을 중단할 수 있다(630). 일 실시 예에 따르면, 컨텐츠 정보는 도 1에서 설명한 바와 같이 외부 미디어 플랫폼으로부터 전송받은 것일 수 있다.According to an embodiment, the processor 120 stores access information on the user terminal 180 (620), transmits a native app execution signal to the user terminal 180 (625), and then the user terminal 180 A session connection with may be terminated (630). When the processor 120 transmits the native app execution signal (625), the corresponding content information may be transmitted together with the user terminal 180, and the processor 120 may terminate the session connection with the user terminal (630). . According to an embodiment, content information may be transmitted from an external media platform as described in FIG. 1 .

일 실시 예에 따르면, 사용자 단말(180)은 수신한 신호에 기초하여 네이티브 앱을 실행할 수 있다(635). 예를 들어, 사용자 단말(180)에서 영화 등 컨텐츠 재생을 위해 VOD 플레이어의 실행을 요청(615)한 경우, 사용자 단말(180)은 해당 컨텐츠 정보와 함께 VOD 플레이어 실행 신호를 수신(625)하고 컨텐츠 정보에 기초하여 네이티브 앱인 VOD 플레이어를 실행할 수 있다(635).According to an embodiment, the user terminal 180 may execute a native app based on the received signal (635). For example, when the user terminal 180 requests (615) the execution of a VOD player to play content such as a movie, the user terminal 180 receives (625) a VOD player execution signal together with corresponding content information and Based on the information, a VOD player, which is a native app, may be executed (635).

서비스 서버(100)는 네이티브 앱 실행 신호를 전송(625)한 후 사용자 단말(180)과의 세션 연결을 중단(630)하므로, 사용자 단말(180)에서 네이티브 앱이 실행(635)되는 동안 서비스 서버(100)는 사용자 단말(180)이 점유하던 세션을 다수의 동시 접속 사용자들에게 제공할 수 있다. 네이티브 앱은 도 1에서 설명한 바와 같이 사용자 단말에서 실행되는 어플로 서비스 서버(100)에 연결되어 있을 필요가 없기 때문에, 서비스 서버(100)는 사용자 단말(180)에 일률적으로 세션을 연결하는 경우보다 동적으로 리소스를 할당할 수 있어 효율적인 다중 동시 접속 환경을 제공할 수 있다.Since the service server 100 stops (630) the session connection with the user terminal 180 after transmitting the native app execution signal (625), while the native app is running (635) on the user terminal 180, the service server 100 may provide a session occupied by the user terminal 180 to a plurality of concurrently connected users. As described in FIG. 1, since the native app is an application running on a user terminal and does not need to be connected to the service server 100, the service server 100 is more than a case where the session is uniformly connected to the user terminal 180. Since resources can be allocated dynamically, an efficient multi-simultaneous access environment can be provided.

일 실시 예에 따르면, 사용자 단말(180)에서 네이티브 앱 실행(635)이 종료되면, 사용자 단말은 서비스 서버(100)로 다시 세션 연결을 요청할 수 있다(660). 이 경우 참조번호 640에서 세션 서버(200)의 동작으로 기존 서비스 서버와 다른 IP의 서비스 서버에 연결될 수 있다. 세션 서버(200)의 동작 및 다른 서비스 서버와의 연결에 대한 설명은 도 2 및 도 5의 참조번호 510에서 설명한 바와 중복되므로, 상세한 설명은 생략한다.According to an embodiment, when the execution of the native app 635 in the user terminal 180 is terminated, the user terminal may request session connection again to the service server 100 (660). In this case, the operation of the session server 200 at reference number 640 may connect to a service server having an IP different from that of the existing service server. A description of the operation of the session server 200 and connection to other service servers is duplicated with that described at reference numeral 510 in FIGS. 2 and 5 , so detailed descriptions are omitted.

일 실시 예에 따르면, 사용자 단말(180)로부터 세션 연결 요청이 수신되고(660) 프로세서(120)는 액세스 정보를 확인(665)하여 이전 서비스 서버에서 액세스 정보를 저장(620)했던 정보를 참조할 수 있고, 이에 기초하여 이전에 사용자 단말(180)로 제공되었던 웹 앱의 최종 화면을 전송할 수 있다(670). According to an embodiment, a session connection request is received from the user terminal 180 (660), and the processor 120 checks (665) access information to refer to information stored in (620) the access information in the previous service server. The final screen of the web app previously provided to the user terminal 180 may be transmitted based on this (670).

예를 들어, 참조번호 670에서, 참조번호 620에서 저장한 액세스 정보에 기초하여 네이티브 앱(예: VOD 플레이어) 실행 요청(615) 전 사용자 단말(180)로 제공되던 홈 앱 내 2차 화면(예: 도 3b의 2차화면(380))이 사용자 단말(180)에 제공될 수 있다. 일 실시 예에 따르면, 화면 내 포인터 좌표 또한 포커싱 정보에 저장되어 있으므로, 포인터의 위치도 이전 접속 화면과 동일하게 전송될 수 있다.For example, in reference number 670, based on the access information stored in reference number 620, a second screen in the home app provided to the user terminal 180 prior to the execution request 615 of a native app (eg, a VOD player) (eg, : The secondary screen 380 of FIG. 3B) may be provided to the user terminal 180. According to an embodiment, since the coordinates of the pointer within the screen are also stored in the focusing information, the location of the pointer can also be transmitted identically to that of the previous access screen.

도 7은 다양한 실시 예들에 따른 키 입력 신호가 다른 웹 앱(web app) 실행 요청인 경우 화면이 제공되는 방법을 설명하기 위한 흐름도이다.7 is a flowchart illustrating a method of providing a screen when a key input signal is a request to execute another web app according to various embodiments.

도 7을 참조하면, 도 5에서 설명한 바와 같이 서비스 서버(100)에서 사용자 단말(180)로 웹 앱(예: 홈 앱) 화면 제공 중, 사용자 단말(180)로부터 다른 웹 앱(예: 키즈 앱) 실행 요청이 수신될 수 있다(715). 예를 들어, 도 4a를 참조하여 설명한 바와 같이, 사용자 단말(180)이 스마트 tv의 셋톱박스이고 키즈 앱 실행 위치(예: 도 4a의 참조번호 430)에서 포인터를 통한 입력(예: '확인' 버튼 입력) 또는 리모콘의 키즈 앱 바로가기 버튼 입력이 수신되면, 브라우저(150)는 수신된 키 입력 신호의 유형을 다른 웹 앱인 키즈 앱에 대한 실행 요청이라고 결정할 수 있다. 도 7에서는 간명한 설명을 위해 생략되었지만, 키 입력 신호가 수신되고(715) 브라우저(150)가 키 입력 신호를 다른 웹 앱 실행 요청이라고 결정할 수 있다. Referring to FIG. 7 , while the service server 100 is providing a web app (eg, home app) screen from the service server 100 to the user terminal 180, another web app (eg, kids app) is provided from the user terminal 180. ) execution request may be received (715). For example, as described with reference to FIG. 4A , the user terminal 180 is a set-top box of a smart TV and an input through a pointer (eg, 'confirm' at the Kids App execution location (eg, reference number 430 in FIG. 4A) button input) or Kids App shortcut button input on the remote controller is received, the browser 150 may determine the type of the received key input signal as an execution request for another web app, Kids App. Although omitted for brevity in FIG. 7 , the key input signal is received (715) and the browser 150 may determine that the key input signal is another web app execution request.

일 실시 예에 따르면, 수신된 키 입력 신호가 다른 웹 앱 실행 요청인 경우 프로세서(120)는 사용자 단말(180)의 액세스 정보를 저장(720)할 수 있다. 일 실시 예에 따르면, 다른 웹 앱 실행 요청(715)이 도 4a에서 설명한 바와 같이 홈 앱의 초기화면을 통한 키즈 앱 실행 요청인 경우, 프로세서(120)는 사용자 단말(180)에 대한 액세스 정보를 액세스 정보 데이터베이스(130)에 저장할 수 있다. 예를 들어, 프로세서(120)는 사용자 단말(180)의 단말 식별 정보를 단말 정보(132)에, 사용자 단말(180)에 제공하던 웹 앱인 홈 앱이라는 정보를 앱 정보(134)에, 해당 홈 앱 내에서 제공하던 화면이 초기 화면(예: 도 3b의 초기화면(360))이라는 화면 식별 정보를 화면 정보(136)에, 그리고 초기 화면 내에서의 포인터의 위치를 포커싱 정보(138)에 연동하여 저장할 수 있다.According to an embodiment, when the received key input signal is another web app execution request, the processor 120 may store access information of the user terminal 180 (720). According to one embodiment, when the other web app execution request 715 is a request to execute the kids app through the initial screen of the home app as described in FIG. It can be stored in the access information database 130. For example, the processor 120 transmits terminal identification information of the user terminal 180 to terminal information 132 and information about a home app, which is a web app that has been provided to the user terminal 180, to app information 134 and the corresponding home screen. Screen identification information indicating that the screen provided within the app is the initial screen (e.g., initial screen 360 in FIG. 3B) is linked to screen information 136, and the location of the pointer within the initial screen is linked to focusing information 138. and can be saved.

일 실시 예에 따르면, 프로세서(120)는 사용자 단말(180)에 대한 액세스 정보를 저장하고(720), 사용자 단말(180)로 다른 웹 앱 실행 신호를 전송(725)한 후 사용자 단말(180)과의 세션 연결을 중단할 수 있다(730). According to an embodiment, the processor 120 stores access information on the user terminal 180 (720), transmits another web app execution signal to the user terminal 180 (725), and then returns the user terminal 180 The connection with the session may be terminated (730).

일 실시 예에 따르면, 사용자 단말(180)은 수신한 신호에 기초하여 다시 다른 웹 앱 실행을 요청할 수 있다(760). 예를 들어 사용자 단말(180)에서 키즈 앱의 실행 신호를 수신(725)한 경우, 다시 서비스 서버(100)로 키즈 앱 실행을 요청할 수 있다(760).According to an embodiment, the user terminal 180 may request execution of another web app again based on the received signal (760). For example, when the user terminal 180 receives a signal to execute the kids app (725), the service server 100 may be requested to run the kids app again (760).

서비스 서버(100)에서 사용자 단말(180)로부터 다른 웹 앱 실행 요청을 수신하는 경우(715) 사용자 단말과의 세션 연결을 중단하고(730) 다시 사용자 단말(180)로부터 해당 다른 웹 앱 실행 요청을 수신하는 이유는, 서비스 서버(100)의 웹 앱을 실행하는 브라우저(150)에서 한 번에 하나의 웹 앱만을 실행할 수 있기 때문이다. 또한, 일 실시 예에 따르면, 서비스 서버(100)는 사용자 단말(180)과의 세션을 중단(730)하고 다시 다른 웹 실행 요청을 수신함으로써 동일한 사용자 단말(180)이 여러 세션을 사용하는 것을 방지하여 리소스를 절약할 수 있고, 보다 많은 사람들의 다중 동시 접속 환경을 제공할 수 있다.When the service server 100 receives another web app execution request from the user terminal 180 (715), the session connection with the user terminal is terminated (730), and the corresponding other web app execution request is again sent from the user terminal 180. The reason for receiving is that only one web app can be executed at a time in the browser 150 that executes the web app of the service server 100 . Further, according to an embodiment, the service server 100 stops the session with the user terminal 180 (730) and receives another web execution request again, thereby preventing the same user terminal 180 from using multiple sessions. By doing so, resources can be saved, and a multi-simultaneous access environment for more people can be provided.

일 실시 예에 따르면, 사용자 단말(180)에서 서비스 서버(100)로 다시 다른 웹 앱 실행을 요청한 경우, 참조번호 740에서 세션 서버(200)의 동작으로 기존 서비스 서버와 다른 IP의 서비스 서버에 연결될 수 있다. 세션 서버(200)의 동작 및 다른 서비스 서버와의 연결에 대한 설명은 도 2 및 도 5의 참조번호 510에서 설명한 바와 중복되므로, 상세한 설명은 생략한다.According to an embodiment, when the user terminal 180 requests the service server 100 to run another web app, the session server 200 operates at reference number 740 to connect to a service server having an IP different from that of the existing service server. can A description of the operation of the session server 200 and connection to other service servers is duplicated with that described at reference numeral 510 in FIGS. 2 and 5 , so detailed descriptions are omitted.

일 실시 예에 따르면, 사용자 단말(180)로부터 다른 웹 앱 실행 요청이 수신되고(760) 프로세서(120)는 액세스 정보를 확인(765)하여 이전 서비스 서버에서 액세스 정보를 저장했던 정보를 참조할 수 있고, 이에 기초하여 이전에 사용자 단말(180)로 제공되었던 해당 다른 웹 앱의 최종 화면을 전송할 수 있다(770). According to an embodiment, another web app execution request is received from the user terminal 180 (760), and the processor 120 checks the access information (765) to refer to information that stored the access information in the previous service server. and, based on this, the final screen of the corresponding other web app previously provided to the user terminal 180 may be transmitted (770).

예를 들어, 참조번호 770에서, 사용자 단말(180)이 이전에 키즈 앱에 접속했다가 세션 연결이 중단되어 저장했던 액세스 정보에 기초하여 이전에 사용자 단말(180)이 접속했던 키즈 앱의 최종 화면 및 포인터의 위치가 제공될 수 있다.For example, in reference number 770, the user terminal 180 previously accessed the Kids App, but the session connection was interrupted, and based on the stored access information, the final screen of the Kids App previously accessed by the user terminal 180. and the location of the pointer may be provided.

<서비스 서버의 동작 방법><How to operate the service server>

도 8 내지 도 11은 다양한 실시 예들에 따른 서비스 서버의 동작 방법을 설명하기 위한 흐름도로, 도 1 내지 도 7에서 설명한 화면 제공 방법을 서비스 서버 측면에서 설명하기 위한 도면이다. 서비스 서버를 중심으로 동작 방법을 설명하되, 간명한 설명을 위해 도 1 내지 도 7에서 설명한 부분과 중복되는 부분은 생략한다.8 to 11 are flowcharts for explaining an operation method of a service server according to various embodiments, and are diagrams for explaining the screen providing method described in FIGS. 1 to 7 from the side of the service server. The operating method is described centering on the service server, but parts overlapping those described in FIGS. 1 to 7 are omitted for concise description.

도 8은 다양한 실시 예들에 따른 서비스 서버가 사용자 단말과의 세션 연결을 유지할지 결정하는 방법을 설명하기 위한 흐름도이다.8 is a flowchart illustrating a method of determining whether a service server maintains a session connection with a user terminal according to various embodiments.

동작 810 내지 850은 도 1을 참조하여 전술된 서비스 서버(100)의 프로세서(120)에 의해 수행될 수 있다. Operations 810 to 850 may be performed by the processor 120 of the service server 100 described above with reference to FIG. 1 .

도 8을 참조하면, 동작 810에서 프로세서(120)는 사용자 단말(180)로부터 웹 앱의 실행 요청을 수신하고, 동작 820에서 실행 요청 및 사용자 단말(180)에 대응하는 액세스 정보에 기초하여 사용자 단말로 화면을 제공할 수 있다. 동작 810 이전에 사용자 단말은 도 5의 참조번호 510에서 설명한 바와 같이 세션 서버(200)를 통해 서비스 서버의 IP를 전송받아 서비스 서버(100)로 세션 연결을 요청함으로써 서비스 서버(100)와 연결된 것일 수 있다.Referring to FIG. 8 , in operation 810, the processor 120 receives a web app execution request from the user terminal 180, and in operation 820, the user terminal based on the execution request and access information corresponding to the user terminal 180. screen can be provided. Before operation 810, the user terminal receives the IP of the service server through the session server 200 as described in reference numeral 510 of FIG. 5 and requests a session connection to the service server 100 to be connected to the service server 100. can

일 실시 예에 따르면, 도 5의 참조번호 530 내지 570에서 설명한 바와 같이, 동작 820에서 프로세서(120)는 액세스 정보 데이터베이스(130)를 참조하여 사용자 단말(180)로부터 실행 요청받은 웹 앱에 대해, 사용자 단말(180)이 이전에 제공받았던 최종 화면을 사용자 단말(180)로 제공할 수 있다. 일 실시 예에 따르면, 서비스 서버(100)는 브라우저(150)에서 액세스 정보에 기초하여 웹 앱을 실행하고, 이미지를 렌더링하고, 프로세서(120)가 렌더링 결과에 대해 이전 화면과 현재 화면을 분할(예를 들어, 40개의 타일로 분할)하여 비교하고, 변경된 영역의 이미지만 전송할 수 있다. 동작 820에서 액세스 정보에 기초한 화면 제공으로 사용자는 보다 다이렉트하게 이전에 접속했던 화면에 액세스할 수 있고, 서비스 서버(100)는 리소스를 줄일 수 있다.According to one embodiment, as described in reference numerals 530 to 570 of FIG. 5, in operation 820, the processor 120 refers to the access information database 130 for the web app requested to be executed from the user terminal 180, The user terminal 180 may provide the previously provided final screen to the user terminal 180 . According to one embodiment, the service server 100 executes a web app based on the access information in the browser 150, renders an image, and the processor 120 divides the previous screen and the current screen for the rendering result ( For example, 40 tiles may be divided into 40 tiles) for comparison, and only the image of the changed area may be transmitted. By providing a screen based on the access information in operation 820, the user can more directly access a previously accessed screen, and the service server 100 can reduce resources.

일 실시 예에 따르면 동작 830에서, 프로세서(120)는 사용자 단말로부터 키 입력 신호를 수신하고, 동작 840에서 키 입력 신호의 유형을 결정할 수 있다. 일 실시 예에 따르면, 키 입력 신호의 유형에는 현재 제공 중인 웹 앱 내 포커싱 이동 신호, 네이티브 앱 실행 요청 및 다른 웹 앱 실행 요청이 포함될 수 있고, 도 4a 및 도 4b에서 설명한 바와 같이 서비스 서버(100)의 브라우저(150)에 의해 키 입력 신호의 유형이 결정될 수 있다.According to an embodiment, in operation 830, the processor 120 may receive a key input signal from the user terminal and determine the type of the key input signal in operation 840. According to an embodiment, the type of key input signal may include a focusing movement signal within a currently provided web app, a native app execution request, and another web app execution request, and as described in FIGS. 4A and 4B , the service server 100 The type of key input signal may be determined by the browser 150 of ).

일 실시 예에 따르면 동작 850에서, 프로세서(120)는 키 입력 신호의 유형에 대응하는 정보를 사용자 단말(180)로 전송하고, 사용자 단말(180)과 세션을 유지할지 결정할 수 있다. According to an embodiment, in operation 850, the processor 120 may transmit information corresponding to the type of the key input signal to the user terminal 180 and determine whether to maintain a session with the user terminal 180.

다양한 실시 예들에 따르면, 동작 840에서 결정된 키 입력 신호의 유형에 따라 동작 850에서 세션 연결을 유지할지 여부가 달라질 수 있고, 세션 연결이 중단되는 경우 다른 동작이 더 포함될 수 있다. 도 9 내지 도 11에서 키 입력 신호의 유형에 따른 동작이 상세히 설명된다.According to various embodiments, whether to maintain the session connection may be changed in operation 850 according to the type of the key input signal determined in operation 840, and other operations may be further included when the session connection is stopped. 9 to 11, operations according to the type of key input signals are described in detail.

도 9는 다양한 실시 예들에 따른 키 입력 신호가 포커싱 이동 신호인 경우 서비스 서버의 동작 방법을 설명하기 위한 흐름도이다.9 is a flowchart illustrating an operation method of a service server when a key input signal is a focusing movement signal according to various embodiments.

동작 910 내지 940은 도 1을 참조하여 전술된 서비스 서버(100)의 프로세서(120)에 의해 수행될 수 있다. 일 실시 예에 따르면, 동작 910 내지 940은 도 8을 참조하여 설명한 키 입력 신호의 유형에 대응하는 정보를 전송하고, 사용자 단말과 세션 연결을 유지할지 결정하는 동작(예: 도 8의 동작 850)에 대응할 수 있다.Operations 910 to 940 may be performed by the processor 120 of the service server 100 described above with reference to FIG. 1 . According to an embodiment, operations 910 to 940 transmit information corresponding to the type of key input signal described with reference to FIG. 8 and determine whether to maintain a session connection with a user terminal (eg, operation 850 of FIG. 8 ) can respond to

도 9를 참조하면, 동작 840에서 결정된 키 입력 신호가 제공 중인 웹 앱 내 포커싱 이동 신호인 경우 동작 910에서 브라우저(150)는 포커싱 이동 후의 웹 앱 이미지를 렌더링할 수 있다. 일 실시 예에 따르면, 동작 920에서 프로세서(120)는 렌더링된 이미지 중 이전 화면에서 변경된 영역을 캡쳐하고, 동작 930에서 캡쳐된 이미지를 사용자 단말(180)로 제공할 수 있다. 구체적으로, 도 5의 참조번호 550 내지 570에서 설명한 바와 같이, 이전 화면과 현재 화면을 분할하여 비교하고 변경된 영역의 이미지만 전송할 수 있다.Referring to FIG. 9 , when the key input signal determined in operation 840 is a focusing movement signal within the web app being provided, the browser 150 may render the web app image after the focusing movement in operation 910 . According to an embodiment, in operation 920, the processor 120 may capture a region changed from a previous screen among the rendered images, and may provide the image captured in operation 930 to the user terminal 180. Specifically, as described in reference numerals 550 to 570 of FIG. 5 , the previous screen and the current screen may be divided and compared, and only images of the changed area may be transmitted.

일 실시 예에 따르면, 동작 940에서 프로세서(120)는 사용자 단말(180)과의 세션 연결을 유지하도록 결정하고, 계속해서 사용자 단말(180)로 화면을 제공할 수 있다.According to an embodiment, in operation 940, the processor 120 may determine to maintain a session connection with the user terminal 180 and continuously provide a screen to the user terminal 180.

도 10은 다양한 실시 예들에 따른 키 입력 신호가 네이티브 앱(native app) 실행 요청인 경우 서비스 서버의 동작 방법을 설명하기 위한 흐름도이다.10 is a flowchart illustrating a method of operating a service server when a key input signal is a native app execution request according to various embodiments.

동작 1010 내지 1060은 도 1을 참조하여 전술된 서비스 서버(100)의 프로세서(120)에 의해 수행될 수 있다. 일 실시 예에 따르면, 동작 1010 내지 1030은 도 8을 참조하여 설명한 키 입력 신호의 유형에 대응하는 정보를 전송하고, 사용자 단말과 세션 연결을 유지할지 결정하는 동작(예: 도 8의 동작 850)에 대응할 수 있다.Operations 1010 to 1060 may be performed by the processor 120 of the service server 100 described above with reference to FIG. 1 . According to an embodiment, operations 1010 to 1030 transmit information corresponding to the type of key input signal described with reference to FIG. 8 and determine whether to maintain a session connection with a user terminal (eg, operation 850 of FIG. 8 ) can respond to

도 10을 참조하면, 동작 840에서 결정된 키 입력 신호가 네이티브 앱 실행 요청인 경우 동작 1010에서 프로세서(120)는 사용자 단말(180)에 대응하는 액세스 정보를 액세스 정보 데이터베이스(130)에 저장할 수 있다. Referring to FIG. 10 , when the key input signal determined in operation 840 is a native app execution request, in operation 1010, the processor 120 may store access information corresponding to the user terminal 180 in the access information database 130.

일 실시 예에 따르면 동작 1020에서, 프로세서(120)는 사용자 단말(180)로 네이티브 앱 실행 신호를 전송할 수 있다. 일 실시 예에 따르면, 네이티브 앱 실행 요청이 VOD 플레이어 실행 요청인 경우, 도 6의 참조번호 625에서 설명한 바와 같이 프로세서(120)는 동작 1020에서 외부 미디어 플랫폼으로부터 수신한 컨텐츠 정보를 VOD 플레이어 실행 신호와 함께 사용자 단말(180)로 전송할 수 있다. According to an embodiment, in operation 1020, the processor 120 may transmit a native app execution signal to the user terminal 180. According to one embodiment, when the native app execution request is a VOD player execution request, as described at reference number 625 of FIG. 6 , the processor 120 transmits the content information received from the external media platform in operation 1020 to the VOD player execution signal and It can be transmitted to the user terminal 180 together.

일 실시 예에 따르면 동작 1030에서, 프로세서(120)는 사용자 단말(180)과의 세션 연결을 중단할 수 있다.According to an embodiment, in operation 1030, the processor 120 may terminate the session connection with the user terminal 180.

일 실시 예에 따르면 동작 1040에서, 프로세서(120)는 네이티브 앱 실행이 종료된 사용자 단말(180)로부터 세션 연결 요청을 수신하고, 동작 1050에서 사용자 단말(180)과 다시 세션을 연결할 수 있다. 도 6의 참조번호 640 및 도 5의 참조번호 510에서 설명한 바와 같이, 동작 1040에서 연결 요청을 수신한 서비스 서버는 이전 동작을 수행하던 서비스 서버와 다를 수 있으나, 간명한 설명을 위해 동일한 서비스 서버인 경우에 대해 설명한다. According to an embodiment, in operation 1040, the processor 120 may receive a session connection request from the user terminal 180 in which execution of the native app is terminated, and in operation 1050 may connect the session with the user terminal 180 again. As described in reference numeral 640 of FIG. 6 and reference numeral 510 of FIG. 5 , the service server receiving the connection request in operation 1040 may be different from the service server performing the previous operation, but for the sake of simplicity, the service server is the same. explain the case.

일 실시 예에 따르면 동작 1060에서, 다시 연결된 서비스 서버(100)의 프로세서(120)는 액세스 정보 데이터베이스(130)를 참조하여 동작 1010에서 저장한 사용자 단말의 액세스 정보에 기초하여 동작 1030에서 세션 연결이 중단되기 전의 화면을 사용자 단말(180)로 제공할 수 있다. According to an embodiment, in operation 1060, the processor 120 of the service server 100 connected again refers to the access information database 130 and establishes a session connection in operation 1030 based on the access information of the user terminal stored in operation 1010. A screen before interruption may be provided to the user terminal 180 .

예를 들어, 홈 앱 실행 중 네이티브 앱인 VOD 플레이어의 실행을 요청한 사용자 단말(180)의 경우, 동작 1010에서 저장한 액세스 정보에 기초하여 VOD 플레이어 실행 요청 전 사용자 단말(180)로 제공되던 홈 앱 내 2차 화면(예: 도 3b의 2차화면(380))을 제공받을 수 있다. 일 실시 예에 따르면, 화면 내 포인터 좌표 또한 포커싱 정보(138)에 저장되어 있으므로, 포인터의 위치도 이전 접속 화면과 동일하게 제공될 수 있다.For example, in the case of the user terminal 180 requesting execution of a VOD player, which is a native app, while the home app is running, based on the access information stored in operation 1010, within the home app provided to the user terminal 180 prior to the VOD player execution request. A secondary screen (eg, the secondary screen 380 of FIG. 3B) may be provided. According to an embodiment, since the coordinates of the pointer in the screen are also stored in the focusing information 138, the position of the pointer can be provided the same as that of the previous access screen.

도 11은 다양한 실시 예들에 따른 키 입력 신호가 다른 웹 앱(web app) 실행 요청인 경우 서비스 서버의 동작 방법을 설명하기 위한 흐름도이다.11 is a flowchart illustrating an operation method of a service server when a key input signal is a request to execute another web app according to various embodiments.

동작 1110 내지 1160은 도 1을 참조하여 전술된 서비스 서버(100)의 프로세서(120)에 의해 수행될 수 있다. 일 실시 예에 따르면, 동작 1110 내지 1130은 도 8을 참조하여 설명한 키 입력 신호의 유형에 대응하는 정보를 전송하고, 사용자 단말과 세션 연결을 유지할지 결정하는 동작(예: 도 8의 동작 850)에 대응할 수 있다.Operations 1110 to 1160 may be performed by the processor 120 of the service server 100 described above with reference to FIG. 1 . According to an embodiment, operations 1110 to 1130 transmit information corresponding to the type of key input signal described with reference to FIG. 8 and determine whether to maintain a session connection with a user terminal (eg, operation 850 of FIG. 8 ) can respond to

도 11을 참조하면, 동작 840에서 결정된 키 입력 신호가 제공 중인 웹 앱과 다른 웹 앱 실행 요청인 경우 동작 1110에서 프로세서(120)는 사용자 단말(180)에 대응하는 액세스 정보를 액세스 정보 데이터베이스(130)에 저장할 수 있다.Referring to FIG. 11 , when the key input signal determined in operation 840 is a web app execution request different from the web app being provided, in operation 1110, the processor 120 transfers access information corresponding to the user terminal 180 to the access information database 130. ) can be stored.

일 실시 예에 따르면 동작 1120에서 프로세서(120)는 사용자 단말(180)로 다른 웹 앱 실행 신호를 전송할 수 있고, 동작 1130에서 사용자 단말(180)과의 세션 연결을 중단할 수 있다.According to an embodiment, in operation 1120, the processor 120 may transmit another web app execution signal to the user terminal 180, and in operation 1130, the session connection with the user terminal 180 may be terminated.

일 실시 예에 따르면 동작 1140에서, 프로세서(120)는 사용자 단말(180)로부터 다시 다른 웹 앱의 실행 요청을 수신하고, 동작 1150에서 사용자 단말(180)과 세션을 연결할 수 있다. 도 7의 참조번호 740 및 도 5의 참조번호 510에서 설명한 바와 같이, 동작 1140에서 연결 요청을 수신한 서비스 서버는 이전 동작을 수행하던 서비스 서버와 다를 수 있으나, 간명한 설명을 위해 동일한 서비스 서버인 경우에 대해 설명한다. According to an embodiment, in operation 1140, the processor 120 receives another web app execution request from the user terminal 180, and connects a session with the user terminal 180 in operation 1150. As described by reference numeral 740 in FIG. 7 and reference numeral 510 in FIG. 5 , the service server receiving the connection request in operation 1140 may be different from the service server performing the previous operation, but for the sake of brevity, the service server is the same. explain the case.

일 실시 예에 따르면 동작 1160에서, 다시 연결된 서비스 서버(100)의 프로세서(120)는 액세스 정보 데이터베이스(130)를 참조하여 사용자 단말의 액세스 정보에 기초하여 이전에 사용자 단말(180)로 제공되었던 해당 다른 웹 앱의 최종 화면을 제공할 수 있다. According to an embodiment, in operation 1160, the processor 120 of the service server 100 connected again refers to the access information database 130 and based on the access information of the user terminal, the corresponding service server 180 previously provided to the user terminal 180. You can provide end screens for other web apps.

예를 들어, 홈 앱 실행 중 다른 웹 앱인 키즈 앱 실행을 요청한 사용자 단말(180)의 경우, 동작 1160에서 이전에 키즈 앱에 접속했다가 세션 연결이 중단되어 저장했던 액세스 정보에 기초하여 이전에 접속했던 키즈 앱의 최종 화면 및 포인터의 위치를 제공받을 수 있다.For example, in the case of the user terminal 180 requesting the execution of another web app, the Kids App, while the Home App is running, in operation 1160, the session connection was interrupted after previously accessing the Kids App, and the previous access was made based on the stored access information. The final screen of the previously used Kids App and the location of the pointer can be provided.

이상에서 설명된 실시예들은 하드웨어 구성요소, 소프트웨어 구성요소, 및/또는 하드웨어 구성요소 및 소프트웨어 구성요소의 조합으로 구현될 수 있다. 예를 들어, 실시예들에서 설명된 장치, 방법 및 구성요소는, 예를 들어, 프로세서, 콘트롤러, ALU(arithmetic logic unit), 디지털 신호 프로세서(digital signal processor), 마이크로컴퓨터, FPGA(field programmable gate array), PLU(programmable logic unit), 마이크로프로세서, 또는 명령(instruction)을 실행하고 응답할 수 있는 다른 어떠한 장치와 같이, 범용 컴퓨터 또는 특수 목적 컴퓨터를 이용하여 구현될 수 있다. 처리 장치는 운영 체제(OS) 및 상기 운영 체제 상에서 수행되는 소프트웨어 애플리케이션을 수행할 수 있다. 또한, 처리 장치는 소프트웨어의 실행에 응답하여, 데이터를 접근, 저장, 조작, 처리 및 생성할 수도 있다. 이해의 편의를 위하여, 처리 장치는 하나가 사용되는 것으로 설명된 경우도 있지만, 해당 기술분야에서 통상의 지식을 가진 자는, 처리 장치가 복수 개의 처리 요소(processing element) 및/또는 복수 유형의 처리 요소를 포함할 수 있음을 알 수 있다. 예를 들어, 처리 장치는 복수 개의 프로세서 또는 하나의 프로세서 및 하나의 컨트롤러를 포함할 수 있다. 또한, 병렬 프로세서(parallel processor)와 같은, 다른 처리 구성(processing configuration)도 가능하다.The embodiments described above may be implemented as hardware components, software components, and/or a combination of hardware components and software components. For example, the devices, methods and components described in the embodiments may include, for example, a processor, a controller, an arithmetic logic unit (ALU), a digital signal processor, a microcomputer, a field programmable gate (FPGA). array), programmable logic units (PLUs), microprocessors, or any other device capable of executing and responding to instructions. The processing device may execute an operating system (OS) and software applications running on the operating system. A processing device may also access, store, manipulate, process, and generate data in response to execution of software. For convenience of understanding, there are cases in which one processing device is used, but those skilled in the art will understand that the processing device includes a plurality of processing elements and/or a plurality of types of processing elements. It can be seen that it can include. For example, a processing device may include a plurality of processors or a processor and a controller. Other processing configurations are also possible, such as parallel processors.

소프트웨어는 컴퓨터 프로그램(computer program), 코드(code), 명령(instruction), 또는 이들 중 하나 이상의 조합을 포함할 수 있으며, 원하는 대로 동작하도록 처리 장치를 구성하거나 독립적으로 또는 결합적으로(collectively) 처리 장치를 명령할 수 있다. 소프트웨어 및/또는 데이터는, 처리 장치에 의하여 해석되거나 처리 장치에 명령 또는 데이터를 제공하기 위하여, 어떤 유형의 기계, 구성요소(component), 물리적 장치, 가상 장치(virtual equipment), 컴퓨터 저장 매체 또는 장치, 또는 전송되는 신호 파(signal wave)에 영구적으로, 또는 일시적으로 구체화(embody)될 수 있다. 소프트웨어는 네트워크로 연결된 컴퓨터 시스템 상에 분산되어서, 분산된 방법으로 저장되거나 실행될 수도 있다. 소프트웨어 및 데이터는 컴퓨터 판독 가능 기록 매체에 저장될 수 있다.Software may include a computer program, code, instructions, or a combination of one or more of the foregoing, which configures a processing device to operate as desired or processes independently or collectively. The device can be commanded. Software and/or data may be any tangible machine, component, physical device, virtual equipment, computer storage medium or device, intended to be interpreted by or provide instructions or data to a processing device. , or may be permanently or temporarily embodied in a transmitted signal wave. Software may be distributed on networked computer systems and stored or executed in a distributed manner. Software and data may be stored on computer readable media.

실시예에 따른 방법은 다양한 컴퓨터 수단을 통하여 수행될 수 있는 프로그램 명령 형태로 구현되어 컴퓨터 판독 가능 매체에 기록될 수 있다. 컴퓨터 판독 가능 매체는 프로그램 명령, 데이터 파일, 데이터 구조 등을 단독으로 또는 조합하여 포함할 수 있으며 매체에 기록되는 프로그램 명령은 실시예를 위하여 특별히 설계되고 구성된 것들이거나 컴퓨터 소프트웨어 당업자에게 공지되어 사용 가능한 것일 수도 있다. 컴퓨터 판독 가능 기록 매체의 예에는 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체(magnetic media), CD-ROM, DVD와 같은 광기록 매체(optical media), 플롭티컬 디스크(floptical disk)와 같은 자기-광 매체(magneto-optical media), 및 롬(ROM), 램(RAM), 플래시 메모리 등과 같은 프로그램 명령을 저장하고 수행하도록 특별히 구성된 하드웨어 장치가 포함된다. 프로그램 명령의 예에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함한다. The method according to the embodiment may be implemented in the form of program instructions that can be executed through various computer means and recorded on a computer readable medium. The computer readable medium may include program instructions, data files, data structures, etc. alone or in combination, and the program instructions recorded on the medium may be specially designed and configured for the embodiment or may be known and usable to those skilled in the art of computer software. may be Examples of computer-readable recording media include magnetic media such as hard disks, floppy disks and magnetic tapes, optical media such as CD-ROMs and DVDs, and magnetic media such as floptical disks. - includes hardware devices specially configured to store and execute program instructions, such as magneto-optical media, and ROM, RAM, flash memory, and the like. Examples of program instructions include high-level language codes that can be executed by a computer using an interpreter, as well as machine language codes such as those produced by a compiler.

위에서 설명한 하드웨어 장치는 실시예의 동작을 수행하기 위해 하나 또는 복수의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지이다.The hardware device described above may be configured to operate as one or a plurality of software modules to perform the operations of the embodiments, and vice versa.

이상과 같이 실시예들이 비록 한정된 도면에 의해 설명되었으나, 해당 기술분야에서 통상의 지식을 가진 자라면 이를 기초로 다양한 기술적 수정 및 변형을 적용할 수 있다. 예를 들어, 설명된 기술들이 설명된 방법과 다른 순서로 수행되거나, 및/또는 설명된 시스템, 구조, 장치, 회로 등의 구성요소들이 설명된 방법과 다른 형태로 결합 또는 조합되거나, 다른 구성요소 또는 균등물에 의하여 대치되거나 치환되더라도 적절한 결과가 달성될 수 있다.As described above, although the embodiments have been described with limited drawings, those skilled in the art can apply various technical modifications and variations based on this. For example, the described techniques may be performed in an order different from the method described, and/or the components of the described system, structure, device, circuit, etc. may be combined or combined in a different form than the method described, or other components may be used. Or even if it is replaced or substituted by equivalents, appropriate results can be achieved.

그러므로, 다른 구현들, 다른 실시예들 및 특허청구범위와 균등한 것들도 후술하는 특허청구범위의 범위에 속한다.Therefore, other implementations, other embodiments, and equivalents of the claims are within the scope of the following claims.

Claims (17)

사용자 단말 각각에 대한 액세스(access) 정보를 저장하는 데이터베이스;
상기 사용자 단말로부터 수신된 키 입력 신호의 유형을 결정하고, 웹 앱(Web app)을 실행하는 브라우저; 및
프로세서를 포함하고,
상기 프로세서는,
상기 사용자 단말로부터 웹 앱(Web app)의 실행 요청을 수신하는 동작;
상기 실행 요청에 포함된 상기 사용자 단말 정보를 참조하여 상기 사용자 단말에 대응하는 상기 액세스 정보에 기초하여 상기 사용자 단말로 세션 연결이 중단된 이전에 제공한 상기 웹 앱의 최종 화면을 제공하는 동작; 및
상기 사용자 단말로 화면 제공 중 상기 사용자 단말로부터 수신된 키 입력 신호의 유형에 대응하는 정보를 상기 사용자 단말로 전송하고, 상기 키 입력 신호의 유형에 기초하여 상기 사용자 단말과의 세션(session) 연결을 유지할지 결정하는 동작
을 수행하는,
서비스 서버.
a database for storing access information for each user terminal;
a browser that determines the type of key input signal received from the user terminal and executes a web app; and
contains a processor;
the processor,
Receiving an execution request of a web app from the user terminal;
providing a final screen of the web app provided before session connection is interrupted to the user terminal based on the access information corresponding to the user terminal with reference to the user terminal information included in the execution request; and
While providing the screen to the user terminal, information corresponding to the type of key input signal received from the user terminal is transmitted to the user terminal, and a session connection with the user terminal is established based on the type of the key input signal. action to decide whether to keep
to do,
service server.
제1항에 있어서,
상기 프로세서는,
상기 키 입력 신호가 상기 웹 앱 내 포커싱(focusing) 이동 신호인 경우,
상기 사용자 단말로 상기 포커싱 이동에 따른 화면을 전송하고, 상기 사용자 단말과의 세션 연결을 유지하는 동작
을 수행하는,
서비스 서버.
According to claim 1,
the processor,
When the key input signal is a focusing movement signal within the web app,
An operation of transmitting a screen according to the focusing movement to the user terminal and maintaining a session connection with the user terminal
to do,
service server.
제1항에 있어서,
상기 프로세서는,
상기 키 입력 신호가 네이티브 앱(native app) 실행 요청인 경우,
상기 사용자 단말에 대응하는 액세스 정보를 저장하는 동작; 및
상기 사용자 단말로 상기 네이티브 앱 실행 신호를 전송하고, 상기 사용자 단말과의 세션 연결을 중단하는 동작
을 수행하는,
서비스 서버.
According to claim 1,
the processor,
When the key input signal is a native app execution request,
storing access information corresponding to the user terminal; and
Transmitting the native app execution signal to the user terminal and stopping the session connection with the user terminal
to do,
service server.
제3항에 있어서,
상기 프로세서는,
상기 사용자 단말에서 상기 네이티브 앱 실행이 종료되고 상기 사용자 단말로부터 세션 연결 요청을 수신한 경우,
상기 사용자 단말과 세션을 연결하는 동작; 및
상기 사용자 단말에 대응하는 상기 액세스 정보에 기초하여 상기 사용자 단말로 화면을 제공하는 동작
을 더 수행하는,
서비스 서버.
According to claim 3,
the processor,
When the execution of the native app is terminated in the user terminal and a session connection request is received from the user terminal,
connecting a session with the user terminal; and
Providing a screen to the user terminal based on the access information corresponding to the user terminal
to do more,
service server.
제1항에 있어서,
상기 프로세서는,
상기 키 입력 신호가 상기 웹 앱과 다른 웹 앱(Web app) 실행 요청인 경우,
상기 사용자 단말에 대응하는 액세스 정보를 저장하는 동작; 및
상기 사용자 단말로 상기 다른 웹 앱에 대한 실행 신호를 전송하고, 상기 사용자 단말과의 세션 연결을 중단하는 동작
을 수행하는,
서비스 서버.
According to claim 1,
the processor,
When the key input signal is a request to execute a web app different from the web app,
storing access information corresponding to the user terminal; and
Transmitting an execution signal for the other web app to the user terminal and stopping the session connection with the user terminal
to do,
service server.
제5항에 있어서,
상기 프로세서는,
상기 사용자 단말로부터 상기 다른 웹 앱 실행 요청을 수신하는 경우,
상기 사용자 단말과 세션을 연결하는 동작; 및
상기 실행 요청 및 상기 사용자 단말에 대응하는 상기 액세스 정보에 기초하여 상기 사용자 단말로 화면을 제공하는 동작
을 더 수행하는,
서비스 서버.
According to claim 5,
the processor,
When receiving the other web app execution request from the user terminal,
connecting a session with the user terminal; and
Providing a screen to the user terminal based on the execution request and the access information corresponding to the user terminal
to do more,
service server.
제1항에 있어서,
상기 액세스 정보는,
사용자 단말 정보, 상기 사용자 단말로 이전에 제공된 웹 앱(Web app)에 대한 정보, 상기 사용자 단말로 제공된 상기 앱 각각의 최종 화면에 대한 화면 정보 및 상기 최종 화면 내 포인터의 위치에 대한 포커싱 정보를 포함하고,
상기 화면 정보는 초기 화면, 상기 초기 화면에서의 입력에 따른 1차 화면 및 상기 1차 화면에서의 입력에 따른 2차 화면 중 어느 하나에 대한 식별정보인,
서비스 서버.
According to claim 1,
The access information,
Includes user terminal information, information about web apps previously provided to the user terminal, screen information about the final screen of each app provided to the user terminal, and focusing information about the position of the pointer in the final screen do,
The screen information is identification information for any one of an initial screen, a first screen according to an input on the initial screen, and a second screen according to an input on the first screen,
service server.
제1항에 있어서,
상기 프로세서는,
상기 브라우저에서 실행된 상기 웹 앱의 렌더링된 이미지 중, 이전 화면에서 변경된 영역의 이미지를 캡쳐(capture)하여 상기 사용자 단말로 화면을 제공하는,
서비스 서버.
According to claim 1,
the processor,
Of the rendered images of the web app executed in the browser, capturing an image of a region changed from a previous screen and providing the screen to the user terminal,
service server.
사용자 단말로부터 웹 앱(Web app)의 실행 요청을 수신하는 동작;
상기 실행 요청에 포함된 상기 사용자 단말 정보를 참조하여 상기 사용자 단말에 대응하는 액세스 정보에 기초하여 상기 사용자 단말로 세션 연결이 중단된 이전에 제공한 상기 웹 앱의 최종 화면을 제공하는 동작; 및
상기 사용자 단말로 화면 제공 중 상기 사용자 단말로부터 수신된 키 입력 신호의 유형에 대응하는 정보를 상기 사용자 단말로 전송하고, 상기 키 입력 신호의 유형에 기초하여 상기 사용자 단말과의 세션(session) 연결을 유지할지 결정하는 동작
을 포함하는,
서비스 서버의 동작 방법.
Receiving an execution request of a web app from a user terminal;
providing a final screen of the web app provided before session connection is interrupted to the user terminal based on access information corresponding to the user terminal with reference to the user terminal information included in the execution request; and
While providing the screen to the user terminal, information corresponding to the type of key input signal received from the user terminal is transmitted to the user terminal, and a session connection with the user terminal is established based on the type of the key input signal. action to decide whether to keep
including,
How the service server works.
제9항에 있어서,
상기 키 입력 신호가 상기 웹 앱 내 포커싱(focusing) 이동 신호인 경우,
상기 사용자 단말로 상기 포커싱 이동에 따른 화면을 전송하고, 상기 사용자 단말과의 세션 연결을 유지하는 동작
을 포함하는,
서비스 서버의 동작 방법.
According to claim 9,
When the key input signal is a focusing movement signal within the web app,
An operation of transmitting a screen according to the focusing movement to the user terminal and maintaining a session connection with the user terminal
including,
How the service server works.
제9항에 있어서,
상기 키 입력 신호가 네이티브 앱(native app) 실행 요청인 경우,
상기 사용자 단말에 대응하는 액세스 정보를 저장하는 동작; 및
상기 사용자 단말로 상기 네이티브 앱 실행 신호를 전송하고, 상기 사용자 단말과의 세션 연결을 중단하는 동작
을 포함하는,
서비스 서버의 동작 방법.
According to claim 9,
When the key input signal is a native app execution request,
storing access information corresponding to the user terminal; and
Transmitting the native app execution signal to the user terminal and stopping the session connection with the user terminal
including,
How the service server works.
제11항에 있어서,
상기 사용자 단말에서 상기 네이티브 앱 실행이 종료되고 상기 사용자 단말로부터 세션 연결 요청을 수신한 경우,
상기 사용자 단말과 세션을 연결하는 동작; 및
상기 사용자 단말에 대응하는 액세스 정보에 기초하여 상기 사용자 단말로 화면을 제공하는 동작
을 더 포함하는,
서비스 서버의 동작 방법.
According to claim 11,
When the execution of the native app is terminated in the user terminal and a session connection request is received from the user terminal,
connecting a session with the user terminal; and
Providing a screen to the user terminal based on access information corresponding to the user terminal
Including more,
How the service server works.
제9항에 있어서,
상기 키 입력 신호가 상기 웹 앱과 다른 웹 앱(Web app) 실행 요청인 경우,
상기 사용자 단말에 대응하는 액세스 정보를 저장하는 동작; 및
상기 사용자 단말로 상기 다른 웹 앱에 대한 실행 신호를 전송하고, 상기 사용자 단말과의 세션 연결을 중단하는 동작
을 포함하는,
서비스 서버의 동작 방법.
According to claim 9,
When the key input signal is a request to execute a web app different from the web app,
storing access information corresponding to the user terminal; and
Transmitting an execution signal for the other web app to the user terminal and stopping the session connection with the user terminal
including,
How the service server works.
제13항에 있어서,
상기 사용자 단말로부터 상기 다른 웹 앱 실행 요청을 수신하는 경우,
상기 사용자 단말과 세션을 연결하는 동작; 및
상기 실행 요청 및 상기 사용자 단말에 대응하는 액세스 정보에 기초하여 상기 사용자 단말로 화면을 제공하는 동작
을 더 포함하는,
서비스 서버의 동작 방법.
According to claim 13,
When receiving the other web app execution request from the user terminal,
connecting a session with the user terminal; and
Providing a screen to the user terminal based on the execution request and access information corresponding to the user terminal
Including more,
How the service server works.
제9항에 있어서,
상기 액세스 정보는,
사용자 단말 정보, 상기 사용자 단말로 이전에 제공된 웹 앱(Web app)에 대한 정보, 상기 사용자 단말로 제공된 상기 앱 각각의 최종 화면에 대한 화면 정보 및 상기 최종 화면 내 포인터의 위치에 대한 포커싱 정보를 포함하고,
상기 화면 정보는 초기 화면, 상기 초기 화면에서의 입력에 따른 1차 화면 및 상기 1차 화면에서의 입력에 따른 2차 화면 중 어느 하나에 대한 식별정보인,
서비스 서버의 동작 방법.
According to claim 9,
The access information,
Includes user terminal information, information about web apps previously provided to the user terminal, screen information about the final screen of each app provided to the user terminal, and focusing information about the position of the pointer in the final screen do,
The screen information is identification information for any one of an initial screen, a first screen according to an input on the initial screen, and a second screen according to an input on the first screen,
How the service server works.
제9항에 있어서,
상기 실행 요청 및 상기 사용자 단말에 대응하는 상기 액세스 정보에 기초하여 상기 사용자 단말로 화면을 제공하는 동작은,
브라우저에서 실행된 상기 웹 앱의 렌더링된 이미지 중, 이전 화면에서 변경된 영역의 이미지를 캡쳐(capture)하여 상기 사용자 단말로 화면을 제공하는 동작
을 포함하는,
서비스 서버의 동작 방법.
According to claim 9,
The operation of providing a screen to the user terminal based on the execution request and the access information corresponding to the user terminal,
An operation of capturing an image of a region changed from a previous screen among rendered images of the web app executed in a browser and providing the screen to the user terminal.
including,
How the service server works.
하드웨어와 결합되어 제9항 내지 제16항 중 어느 하나의 항의 방법을 실행시키기 위하여 컴퓨터 판독 가능한 기록매체에 저장된 컴퓨터 프로그램.A computer program stored in a computer readable recording medium in order to execute the method of any one of claims 9 to 16 in combination with hardware.
KR1020210045821A 2021-04-08 2021-04-08 Service server and operating method thereof KR102566262B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020210045821A KR102566262B1 (en) 2021-04-08 2021-04-08 Service server and operating method thereof

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020210045821A KR102566262B1 (en) 2021-04-08 2021-04-08 Service server and operating method thereof

Publications (2)

Publication Number Publication Date
KR20220139632A KR20220139632A (en) 2022-10-17
KR102566262B1 true KR102566262B1 (en) 2023-08-11

Family

ID=83809876

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020210045821A KR102566262B1 (en) 2021-04-08 2021-04-08 Service server and operating method thereof

Country Status (1)

Country Link
KR (1) KR102566262B1 (en)

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102246556B1 (en) * 2014-12-02 2021-04-30 엘지전자 주식회사 Multimedia device and method for controlling the same
KR102384520B1 (en) * 2015-06-29 2022-04-08 엘지전자 주식회사 Display device and controlling method thereof
KR102004970B1 (en) * 2016-11-17 2019-07-30 에스케이플래닛 주식회사 Method and apparatus for cloud streaming service

Also Published As

Publication number Publication date
KR20220139632A (en) 2022-10-17

Similar Documents

Publication Publication Date Title
RU2631137C2 (en) Connection of devices
US9532103B2 (en) Multi-user support for set top boxes and game consoles
US20220360830A1 (en) Cloud Phone-Based Live Streaming Method and Apparatus
US11770371B2 (en) Systems and methods for connecting private devices to public devices according to connection parameters
US20100248698A1 (en) Mobile terminal device inlcuding mobile cloud platform
US8966547B2 (en) Seamless service information providing scheme
US11119859B2 (en) Method and apparatus for subscriber management
US10531165B1 (en) Embedded content synchronization
KR20130140434A (en) Method for controlling receiving of content data through a plurality of wireless networks connected in multiple mode and an apparatus for said method
US20230362106A1 (en) Application port management
US10412442B1 (en) Embedded content input and timing
US20180352285A1 (en) Method for providing a remote personal computer service to a digital device
KR102566262B1 (en) Service server and operating method thereof
CN110808996B (en) Network authentication method and device, electronic equipment and storage medium
KR102570284B1 (en) Service server for providing screen and operating method thereof
KR102566263B1 (en) Service server for providing screen and operating method thereof
KR101909257B1 (en) Server and method for executing virtual application requested from device, and the device
KR101557143B1 (en) Virtualization server for controlling reproduction device and method thereof
KR102107374B1 (en) Virtualization-based training content delivery system
KR101429891B1 (en) A method for adapting reception of content data to receiving state and an apparatus for said method
WO2023098163A1 (en) Application processing method and system, and electronic device and computer-readable storage medium
US20130061274A1 (en) Apparatus and method for managing a plurality of services
KR20230128914A (en) Method of transmitting IoT status information by a local server
KR20230128913A (en) Method of transmitting UI display information to peripheral clients by a local server
KR20230128916A (en) Method of transceiving UI displays between user devices

Legal Events

Date Code Title Description
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant