KR20170073930A - 웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 전자 장치 - Google Patents

웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 전자 장치 Download PDF

Info

Publication number
KR20170073930A
KR20170073930A KR1020150182735A KR20150182735A KR20170073930A KR 20170073930 A KR20170073930 A KR 20170073930A KR 1020150182735 A KR1020150182735 A KR 1020150182735A KR 20150182735 A KR20150182735 A KR 20150182735A KR 20170073930 A KR20170073930 A KR 20170073930A
Authority
KR
South Korea
Prior art keywords
push
electronic device
server
service
push service
Prior art date
Application number
KR1020150182735A
Other languages
English (en)
Other versions
KR102413396B1 (ko
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 KR1020150182735A priority Critical patent/KR102413396B1/ko
Priority to PCT/KR2016/013121 priority patent/WO2017111313A1/ko
Priority to US16/061,100 priority patent/US10997268B2/en
Publication of KR20170073930A publication Critical patent/KR20170073930A/ko
Application granted granted Critical
Publication of KR102413396B1 publication Critical patent/KR102413396B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/958Organisation or management of web site content, e.g. publishing, maintaining pages or automatic linking
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q50/00Systems or methods specially adapted for specific business sectors, e.g. utilities or tourism
    • G06Q50/10Services
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/903Querying
    • G06F16/9038Presentation of query results
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/30Authentication, i.e. establishing the identity or authorisation of security principals
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/14Digital output to display device ; Cooperation and interconnection of the display device with other functional units
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/12Protocols specially adapted for proprietary or special-purpose networking environments, e.g. medical networks, sensor networks, networks in vehicles or remote metering networks
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/55Push-based network services
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2221/00Indexing scheme relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F2221/21Indexing scheme relating to G06F21/00 and subgroups addressing additional information or applications relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F2221/2111Location-sensitive, e.g. geographical location, GPS

Abstract

본 발명은 웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 전자 장치에 관한 것으로, 본 발명의 다양한 실시예에 따른 푸시 서비스 제공 방법에 있어서, 소프트웨어 프로그램의 사용자 인터페이스를 표시하는 동작, 상기 사용자 인터페이스에서 제1 사용자 입력이 감지되면, 사용자 구독에 따른 푸시 서비스와 관련된 제1 서버로부터 제1 웹페이지를 수신하는 동작, 상기 제1 웹페이지와 푸시 서비스를 위한 인디케이터를 표시하는 동작, 및 상기 푸시 서비스 구독을 위한 제2 사용자 입력이 감지되면, 상기 푸시 서비스 구독을 나타내는 신호를 푸시 서비스를 제공하는 복수의 웹사이트를 관리하는 상기 제1 서버와 독립적인 제2 서버에 전송하는 동작을 포함할 수 있다. 다른 실시예도 가능하다.

Description

웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 전자 장치{METHOD FOR PROVIDING PUSH SERVICE USING WEBPUSH AND ELECTRONIC DEVICE SUPPORTING THE SAME}
본 발명의 다양한 실시예는 웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 전자 장치에 관한 것이다.
일반적으로 서비스 업체는 어플리케이션 또는 웹을 통해 사용자에게 푸시 서비스를 제공할 수 있다. 웹을 통해 사용자에게 푸시 서비스를 제공하는 경우, WWW/HTML 표준을 이용하여 푸시 서비스를 사용자에게 제공할 수 있다.
하지만, 개발 능력이 안 되는 웹사이트(예컨대, 설치형 블로그와 같은 CMS(contents management system)나 포털 공간을 이용하는 웹사이트)의 경우, 웹을 통해 사용자에게 푸시 서비스를 제공하는 것은 웹푸시에 필요한 스크립트를 수정해야하거나 푸시 메시지 전송을 위해 별도의 푸시 플랫폼 서버 API를 개발해야 하므로 기술적으로 어려움이 있다.
본 발명의 다양한 실시예에 따른 웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 전자 장치는 개발 능력을 보유하지 않은 서비스 업체들이 웹을 통해 웹푸시 서비스를 사용자에게 용이하게 제공할 수 있다.
본 발명의 다양한 실시예에 따른 웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 전자 장치는 사용자에게 푸시 서비스를 제공하기를 원하는 웹사이트의 리스트를 관리할 수 있다. 또한, 본 발명의 다양한 실시예에 따른 전자 장치는 사용자에게 푸시 서비스를 용이하게 전송하기 위한 사용자 인터페이스를 제공할 수 있다.
본 발명의 다양한 실시예에 따른 전자 장치는, 유무선 통신을 형성하는 통신부, 표시부, 상기 표시부와 별도로 또는 결합된 입력부, 적어도 부분적으로 웹 브라우징을 위해 구성된 소프트웨어 프로그램을 저장하는 비 휘발성 메모리, 및 상기 통신부, 상기 표시부, 상기 입력부, 및 상기 비 휘발성 메모리와 전기적으로 연결된 프로세서를 포함하고, 상기 프로세서와 전기적으로 연결된 메모리는, 상기 비 휘발성 메모리는 실행 시에, 상기 프로세서가, 상기 소프트웨어 프로그램의 사용자 인터페이스를 상기 표시부에 표시하고, 상기 입력부를 통한 제1 사용자 입력에 응답하여 상기 통신부를 통해 사용자 구독에 따른 푸시 서비스와 관련된 제1 서버로부터 제1 웹페이지를 수신하고, 상기 제1 웹페이지와 상기 사용자 인터페이스에 푸시 서비스를 위한 인디케이터를 표시하고, 상기 입력부를 통해 상기 푸시 서비스 구독을 위한 제2 사용자 입력을 수신하고, 상기 통신부를 통해 상기 푸시 서비스 구독을 나타내는 신호를 상기 푸시 서비스를 제공하는 복수의 웹사이트를 관리하는 상기 제1 서버와 독립적인 제2 서버에 전송하는 인스트럭션들을 저장할 수 있다.
본 발명의 다양한 실시예에 따른 웹푸시를 이용한 푸시 서비스 제공 방법에 있어서, 소프트웨어 프로그램의 사용자 인터페이스를 표시하는 동작, 상기 사용자 인터페이스에서 제1 사용자 입력이 감지되면, 사용자 구독에 따른 푸시 서비스와 관련된 제1 서버로부터 제1 웹페이지를 수신하는 동작, 상기 제1 웹페이지와 푸시 서비스를 위한 인디케이터를 표시하는 동작, 및 상기 푸시 서비스 구독을 위한 제2 사용자 입력이 감지되면, 상기 푸시 서비스 구독을 나타내는 신호를 푸시 서비스를 제공하는 복수의 웹사이트를 관리하는 상기 제1 서버와 독립적인 제2 서버에 전송하는 동작을 포함할 수 있다.
본 발명의 다양한 실시예에 따른 웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 전자 장치는 추가적인 어플리케이션을 설치하지 않고도 사용자 참여율을 높이기 위한 웹푸시 서비스를 사용자에게 제공할 수 있다.
또한, 본 발명의 다양한 실시예에 따른 전자 장치는 푸시 서비스를 위한 사용자 인터페이스를 제공함으로써 별도의 수정 동작을 수행하지 않고도 용이하게 사용자에게 푸시 서비스를 제공할 수 있다.
도 1은 본 발명의 다양한 실시예에 따른 네트워크 환경을 도시하는 블록도이다.
도 2는 본 발명의 다양한 실시예에 따른 전자 장치의 블록도이다.
도 3은 본 발명의 다양한 실시예에 따른 프로그램 모듈의 블록도이다.
도 4는 본 발명의 다양한 실시예에 따른 웹푸시를 이용한 푸시 서비스를 제공하는 시스템을 도시하는 도면이다.
도 5는 본 발명의 다양한 실시예에 따른 웹푸시를 이용한 푸시 서비스를 제공하는 시스템을 도시하는 도면이다.
도 6은 본 발명의 다양한 실시예에 따른 웹푸시를 이용한 푸시 서비스 제공 방법을 설명하기 위한 전자 장치와 서버 간에 신호 흐름을 도시하는 도면이다.
도 7a 및 도 7b는 본 발명의 다양한 실시예에 따른 전자 장치에서 웹푸시 메시지 작성을 설명하기 위한 도면이다.
도 8a 및 도 8b는 본 발명의 다양한 실시예에 따른 웹푸시 제공 서버의 동작을 설명하기 위한 도면이다.
도 9a 내지 도 9e는 본 발명의 다양한 실시예에 따른 전자 장치의 푸시 메시지 수신 동작을 설명하기 위한 도면이다.
도 10a 및 도 10b는 본 발명의 다양한 실시예에 따른 전자 장치의 푸시 서비스 수신 동작을 설명하기 위한 도면이다.
도 11은 본 발명의 다양한 실시예에 따른 전자 장치의 브라우저를 구성하는 구성요소를 설명하기 위한 도면이다.
이하, 본 문서의 다양한 실시예들이 첨부된 도면을 참조하여 기재된다. 실시예 및 이에 사용된 용어들은 본 문서에 기재된 기술을 특정한 실시 형태에 대해 한정하려는 것이 아니며, 해당 실시예의 다양한 변경, 균등물, 및/또는 대체물을 포함하는 것으로 이해되어야 한다. 도면의 설명과 관련하여, 유사한 구성요소에 대해서는 유사한 참조 부호가 사용될 수 있다. 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함할 수 있다. 본 문서에서, "A 또는 B" 또는 "A 및/또는 B 중 적어도 하나" 등의 표현은 함께 나열된 항목들의 모든 가능한 조합을 포함할 수 있다. "제 1," "제 2," "첫째," 또는 "둘째,"등의 표현들은 해당 구성요소들을, 순서 또는 중요도에 상관없이 수식할 수 있고, 한 구성요소를 다른 구성요소와 구분하기 위해 사용될 뿐 해당 구성요소들을 한정하지 않는다. 어떤(예: 제 1) 구성요소가 다른(예: 제 2) 구성요소에 "(기능적으로 또는 통신적으로) 연결되어" 있다거나 "접속되어" 있다고 언급된 때에는, 상기 어떤 구성요소가 상기 다른 구성요소에 직접적으로 연결되거나, 다른 구성요소(예: 제 3 구성요소)를 통하여 연결될 수 있다.
본 문서에서, "~하도록 구성된(또는 설정된)(configured to)"은 상황에 따라, 예를 들면, 하드웨어적 또는 소프트웨어적으로 "~에 적합한," "~하는 능력을 가지는," "~하도록 변경된," "~하도록 만들어진," "~를 할 수 있는," 또는 "~하도록 설계된"과 상호 호환적으로(interchangeably) 사용될 수 있다. 어떤 상황에서는, "~하도록 구성된 장치"라는 표현은, 그 장치가 다른 장치 또는 부품들과 함께 "~할 수 있는" 것을 의미할 수 있다. 예를 들면, 문구 "A, B, 및 C를 수행하도록 구성된(또는 설정된) 프로세서"는 해당 동작을 수행하기 위한 전용 프로세서(예: 임베디드 프로세서), 또는 메모리 장치에 저장된 하나 이상의 소프트웨어 프로그램들을 실행함으로써, 해당 동작들을 수행할 수 있는 범용 프로세서(예: CPU 또는 application processor)를 의미할 수 있다.
본 문서의 다양한 실시예들에 따른 전자 장치는, 예를 들면, 스마트폰, 태블릿 PC, 이동 전화기, 영상 전화기, 전자책 리더기, 데스크탑 PC, 랩탑 PC, 넷북 컴퓨터, 워크스테이션, 서버, PDA, PMP(portable multimedia player), MP3 플레이어, 의료기기, 카메라, 또는 웨어러블 장치 중 적어도 하나를 포함할 수 있다. 웨어러블 장치는 액세서리형(예: 시계, 반지, 팔찌, 발찌, 목걸이, 안경, 콘택트 렌즈, 또는 머리 착용형 장치(head-mounted-device(HMD)), 직물 또는 의류 일체형(예: 전자 의복), 신체 부착형(예: 스킨 패드 또는 문신), 또는 생체 이식형 회로 중 적어도 하나를 포함할 수 있다. 어떤 실시예들에서, 전자 장치는, 예를 들면, 텔레비전, DVD(digital video disk) 플레이어, 오디오, 냉장고, 에어컨, 청소기, 오븐, 전자레인지, 세탁기, 공기 청정기, 셋톱 박스, 홈 오토매이션 컨트롤 패널, 보안 컨트롤 패널, 미디어 박스(예: 삼성 HomeSyncTM, 애플TVTM, 또는 구글 TVTM), 게임 콘솔(예: XboxTM, PlayStationTM), 전자 사전, 전자 키, 캠코더, 또는 전자 액자 중 적어도 하나를 포함할 수 있다.
다른 실시예에서, 전자 장치는, 각종 의료기기(예: 각종 휴대용 의료측정기기(혈당 측정기, 심박 측정기, 혈압 측정기, 또는 체온 측정기 등), MRA(magnetic resonance angiography), MRI(magnetic resonance imaging), CT(computed tomography), 촬영기, 또는 초음파기 등), 네비게이션 장치, 위성 항법 시스템(GNSS(global navigation satellite system)), EDR(event data recorder), FDR(flight data recorder), 자동차 인포테인먼트 장치, 선박용 전자 장비(예: 선박용 항법 장치, 자이로 콤파스 등), 항공 전자기기(avionics), 보안 기기, 차량용 헤드 유닛(head unit), 산업용 또는 가정용 로봇, 드론(drone), 금융 기관의 ATM, 상점의 POS(point of sales), 또는 사물 인터넷 장치 (예: 전구, 각종 센서, 스프링클러 장치, 화재 경보기, 온도조절기, 가로등, 토스터, 운동기구, 온수탱크, 히터, 보일러 등) 중 적어도 하나를 포함할 수 있다. 어떤 실시예에 따르면, 전자 장치는 가구, 건물/구조물 또는 자동차의 일부, 전자 보드(electronic board), 전자 사인 수신 장치(electronic signature receiving device), 프로젝터, 또는 각종 계측 기기(예: 수도, 전기, 가스, 또는 전파 계측 기기 등) 중 적어도 하나를 포함할 수 있다. 다양한 실시예에서, 전자 장치는 플렉서블하거나, 또는 전술한 다양한 장치들 중 둘 이상의 조합일 수 있다. 본 문서의 실시예에 따른 전자 장치는 전술한 기기들에 한정되지 않는다. 본 문서에서, 사용자라는 용어는 전자 장치를 사용하는 사람 또는 전자 장치를 사용하는 장치(예: 인공지능 전자 장치)를 지칭할 수 있다.
도 1은 본 발명의 다양한 실시예에 따른 네트워크 환경을 도시하는 블록도이다.
도 1을 참조하여, 다양한 실시예에서의, 네트워크 환경 100 내의 전자 장치 101이 기재된다. 전자 장치 101은 버스 110, 프로세서 120, 메모리 130, 입출력 인터페이스 150, 디스플레이 160, 및 통신 인터페이스 170을 포함할 수 있다. 어떤 실시예에서는, 전자 장치 101은, 구성요소들 중 적어도 하나를 생략하거나 다른 구성요소를 추가적으로 구비할 수 있다. 버스 110은 구성요소들 110-170을 서로 연결하고, 구성요소들 간의 통신(예: 제어 메시지 또는 데이터)을 전달하는 회로를 포함할 수 있다. 프로세서 120은, 중앙처리장치, 어플리케이션 프로세서, 또는 커뮤니케이션 프로세서(communication processor(CP)) 중 하나 또는 그 이상을 포함할 수 있다. 프로세서 120은, 예를 들면, 전자 장치 101의 적어도 하나의 다른 구성요소들의 제어 및/또는 통신에 관한 연산이나 데이터 처리를 실행할 수 있다.
메모리 130은, 휘발성 및/또는 비휘발성 메모리를 포함할 수 있다. 메모리130은, 예를 들면, 전자 장치 101의 적어도 하나의 다른 구성요소에 관계된 명령 또는 데이터를 저장할 수 있다. 한 실시예에 따르면, 메모리 130은 소프트웨어 및/또는 프로그램 140을 저장할 수 있다. 프로그램 140은, 예를 들면, 커널 141, 미들웨어 143, 어플리케이션 프로그래밍 인터페이스(API) 145, 및/또는 어플리케이션 프로그램(또는 "어플리케이션") 147 등을 포함할 수 있다. 커널 141, 미들웨어 143, 또는 API 145의 적어도 일부는, 운영 시스템으로 지칭될 수 있다. 커널 141은, 예를 들면, 다른 프로그램들(예: 미들웨어 143, API 145, 또는 어플리케이션 프로그램 147)에 구현된 동작 또는 기능을 실행하는 데 사용되는 시스템 리소스들(예: 버스 110, 프로세서 120, 또는 메모리 130 등)을 제어 또는 관리할 수 있다. 또한, 커널 141은 미들웨어143, API 145, 또는 어플리케이션 프로그램 147에서 전자 장치 101의 개별 구성요소에 접근함으로써, 시스템 리소스들을 제어 또는 관리할 수 있는 인터페이스를 제공할 수 있다.
미들웨어 143은, 예를 들면, API 145 또는 어플리케이션 프로그램 147이 커널 141과 통신하여 데이터를 주고받을 수 있도록 중개 역할을 수행할 수 있다. 또한, 미들웨어 143은 어플리케이션 프로그램 147로부터 수신된 하나 이상의 작업 요청들을 우선 순위에 따라 처리할 수 있다. 예를 들면, 미들웨어 143은 어플리케이션 프로그램 147 중 적어도 하나에 전자 장치 101의 시스템 리소스(예: 버스 110, 프로세서 120, 또는 메모리 130 등)를 사용할 수 있는 우선 순위를 부여하고, 상기 하나 이상의 작업 요청들을 처리할 수 있다. API 145는 어플리케이션 147이 커널 141 또는 미들웨어 143에서 제공되는 기능을 제어하기 위한 인터페이스로, 예를 들면, 파일 제어, 창 제어, 영상 처리, 또는 문자 제어 등을 위한 적어도 하나의 인터페이스 또는 함수(예: 명령어)를 포함할 수 있다. 입출력 인터페이스 150은, 예를 들면, 사용자 또는 다른 외부 기기로부터 입력된 명령 또는 데이터를 전자 장치 101의 다른 구성요소(들)에 전달하거나, 또는 전자 장치 101의 다른 구성요소(들)로부터 수신된 명령 또는 데이터를 사용자 또는 다른 외부 기기로 출력할 수 있다.
디스플레이 160은, 예를 들면, 액정 디스플레이(LCD), 발광 다이오드(LED) 디스플레이, 유기 발광 다이오드(OLED) 디스플레이, 또는 마이크로 전자기계 시스템 (MEMS) 디스플레이, 또는 전자종이(electronic paper) 디스플레이를 포함할 수 있다. 디스플레이 160은, 예를 들면, 사용자에게 각종 콘텐츠(예: 텍스트, 이미지, 비디오, 아이콘, 및/또는 심볼 등)을 표시할 수 있다. 디스플레이 160은, 터치 스크린을 포함할 수 있으며, 예를 들면, 전자 펜 또는 사용자의 신체의 일부를 이용한 터치, 제스쳐, 근접, 또는 호버링 입력을 수신할 수 있다. 통신 인터페이스 170은, 예를 들면, 전자 장치 101과 외부 장치(예: 제 1 외부 전자 장치 102, 제 2 외부 전자 장치 104, 또는 서버 106) 간의 통신을 설정할 수 있다. 예를 들면, 통신 인터페이스 170은 무선 통신 또는 유선 통신을 통해서 네트워크 162에 연결되어 외부 장치(예: 제 2 외부 전자 장치 104 또는 서버 106)와 통신할 수 있다.
무선 통신은, 예를 들면, LTE, LTE-A(LTE Advance), CDMA(code division multiple access), WCDMA(wideband CDMA), UMTS(universal mobile telecommunications system), WiBro(Wireless Broadband), 또는 GSM(global system for mobile communications) 등 중 적어도 하나를 사용하는 셀룰러 통신을 포함할 수 있다. 한 실시예에 따르면, 무선 통신은, 예를 들면, WiFi(wireless fidelity), 블루투스, 블루투스 저전력(BLE), 지그비(zigbee), NFC(near field communication), 자력 시큐어 트랜스미션(magnetic secure transmission), 라디오 프리퀀시(RF), 또는 보디 에어리어 네트워크(BAN) 중 적어도 하나를 포함할 수 있다. 한 실시예에 따르면, 무선 통신은 GNSS를 포함할 수 있다. GNSS는, 예를 들면, GPS(global positioning system), Glonass(global navigation satellite system), Beidou Navigation Satellite System(이하 “Beidou”) 또는 Galileo, the European global satellite-based navigation system일 수 있다. 이하, 본 문서에서는, “GPS”는 “GNSS”와 상호 호환적으로 사용될 수 있다. 유선 통신은, 예를 들면, USB(universal serial bus), HDMI(high definition multimedia interface), RS-232(recommended standard232), 전력선 통신, 또는 POTS(plain old telephone service) 등 중 적어도 하나를 포함할 수 있다. 네트워크 162는 텔레커뮤니케이션 네트워크, 예를 들면, 컴퓨터 네트워크(예: LAN 또는 WAN), 인터넷, 또는 텔레폰 네트워크 중 적어도 하나를 포함할 수 있다.
제 1 및 제 2 외부 전자 장치 102, 104 각각은 전자 장치 101과 동일한 또는 다른 종류의 장치일 수 있다. 다양한 실시예에 따르면, 전자 장치 101에서 실행되는 동작들의 전부 또는 일부는 다른 하나 또는 복수의 전자 장치(예: 전자 장치 102, 104, 또는 서버 106에서 실행될 수 있다. 한 실시예에 따르면, 전자 장치 101이 어떤 기능이나 서비스를 자동으로 또는 요청에 의하여 수행해야 할 경우에, 전자 장치 101은 기능 또는 서비스를 자체적으로 실행시키는 대신에 또는 추가적으로, 그와 연관된 적어도 일부 기능을 다른 장치(예: 전자 장치 102, 104, 또는 서버 106)에게 요청할 수 있다. 다른 전자 장치(예: 전자 장치 102, 104, 또는 서버 106)는 요청된 기능 또는 추가 기능을 실행하고, 그 결과를 전자 장치 101로 전달할 수 있다. 전자 장치 101은 수신된 결과를 그대로 또는 추가적으로 처리하여 요청된 기능이나 서비스를 제공할 수 있다. 이를 위하여, 예를 들면, 클라우드 컴퓨팅, 분산 컴퓨팅, 또는 클라이언트-서버 컴퓨팅 기술이 이용될 수 있다.
도 2는 본 발명의 다양한 실시예에 따른 전자 장치의 블록도이다.
전자 장치 201은, 예를 들면, 도 1에 도시된 전자 장치 101의 전체 또는 일부를 포함할 수 있다. 전자 장치 201은 하나 이상의 프로세서(예: AP) 210, 통신 모듈 220, 가입자 식별 모듈 224, 메모리 230, 센서 모듈 240, 입력 장치 250, 디스플레이 260, 인터페이스 270, 오디오 모듈 280, 카메라 모듈 291, 전력 관리 모듈 295, 배터리 296, 인디케이터 297, 및 모터 298을 포함할 수 있다. 프로세서 210은, 예를 들면, 운영 체제 또는 응용 프로그램을 구동하여 프로세서 210에 연결된 다수의 하드웨어 또는 소프트웨어 구성요소들을 제어할 수 있고, 각종 데이터 처리 및 연산을 수행할 수 있다. 프로세서 210은, 예를 들면, SoC(system on chip) 로 구현될 수 있다. 한 실시예에 따르면, 프로세서 210은 GPU(graphic processing unit) 및/또는 이미지 신호 프로세서를 더 포함할 수 있다. 프로세서 210은 도 2에 도시된 구성요소들 중 적어도 일부(예: 셀룰러 모듈 221)를 포함할 수도 있다. 프로세서 210은 다른 구성요소들(예: 비휘발성 메모리) 중 적어도 하나로부터 수신된 명령 또는 데이터를 휘발성 메모리에 로드)하여 처리하고, 결과 데이터를 비휘발성 메모리에 저장할 수 있다.
통신 모듈 220(예: 통신 인터페이스 170)과 동일 또는 유사한 구성을 가질 수 있다. 통신 모듈 220은, 예를 들면, 셀룰러 모듈 221, WiFi 모듈 223, 블루투스 모듈 225, GNSS 모듈 227, NFC 모듈 228 및 RF 모듈 229를 포함할 수 있다. 셀룰러 모듈 221은, 예를 들면, 통신망을 통해서 음성 통화, 영상 통화, 문자 서비스, 또는 인터넷 서비스 등을 제공할 수 있다. 한 실시예에 따르면, 셀룰러 모듈 221은 가입자 식별 모듈(예: SIM 카드) 224를 이용하여 통신 네트워크 내에서 전자 장치 201의 구별 및 인증을 수행할 수 있다. 한 실시예에 따르면, 셀룰러 모듈 221은 프로세서 210이 제공할 수 있는 기능 중 적어도 일부 기능을 수행할 수 있다. 한 실시예에 따르면, 셀룰러 모듈 221은 커뮤니케이션 프로세서(CP)를 포함할 수 있다. 어떤 실시예에 따르면, 셀룰러 모듈 221, WiFi 모듈 223, 블루투스 모듈 225, GNSS 모듈 227 또는 NFC 모듈 228 중 적어도 일부(예: 두 개 이상)는 하나의 integrated chip(IC) 또는 IC 패키지 내에 포함될 수 있다. RF 모듈 229는, 예를 들면, 통신 신호(예: RF 신호)를 송수신할 수 있다. RF 모듈 229는, 예를 들면, 트랜시버, PAM(power amp module), 주파수 필터, LNA(low noise amplifier), 또는 안테나 등을 포함할 수 있다. 다른 실시예에 따르면, 셀룰러 모듈 221, WiFi 모듈 223, 블루투스 모듈 225, GNSS 모듈 227 또는 NFC 모듈 228 중 적어도 하나는 별개의 RF 모듈을 통하여 RF 신호를 송수신할 수 있다. 가입자 식별 모듈 224는, 예를 들면, 가입자 식별 모듈을 포함하는 카드 또는 임베디드 SIM을 포함할 수 있으며, 고유한 식별 정보(예: ICCID(integrated circuit card identifier)) 또는 가입자 정보(예: IMSI(international mobile subscriber identity))를 포함할 수 있다.
메모리 230(예: 메모리 130)은, 예를 들면, 내장 메모리 232 또는 외장 메모리 234를 포함할 수 있다. 내장 메모리 232는, 예를 들면, 휘발성 메모리(예: DRAM, SRAM, 또는 SDRAM 등), 비휘발성 메모리(예: OTPROM(one time programmable ROM), PROM, EPROM, EEPROM, mask ROM, flash ROM, 플래시 메모리, 하드 드라이브, 또는 솔리드 스테이트 드라이브 (SSD) 중 적어도 하나를 포함할 수 있다. 외장 메모리 234는 플래시 드라이브(flash drive), 예를 들면, CF(compact flash), SD(secure digital), Micro-SD, Mini-SD, xD(extreme digital), MMC(multi-media card) 또는 메모리 스틱 등을 포함할 수 있다. 외장 메모리 234는 다양한 인터페이스를 통하여 전자 장치 201과 기능적으로 또는 물리적으로 연결될 수 있다.
센서 모듈 240은, 예를 들면, 물리량을 계측하거나 전자 장치 201의 작동 상태를 감지하여, 계측 또는 감지된 정보를 전기 신호로 변환할 수 있다. 센서 모듈 240은, 예를 들면, 제스처 센서 240A, 자이로 센서 240B, 기압 센서 240C, 마그네틱 센서 240D, 가속도 센서 240E, 그립 센서 240F, 근접 센서 240G, 컬러(color) 센서 240H(예: RGB(red, green, blue) 센서), 생체 센서 240I, 온/습도 센서 240J, 조도 센서 240K, 또는 UV(ultra violet) 센서 240M 중의 적어도 하나를 포함할 수 있다. 추가적으로 또는 대체적으로, 센서 모듈 240은, 예를 들면, 후각(e-nose) 센서, 일렉트로마이오그라피(EMG) 센서, 일렉트로엔씨팔로그램(EEG) 센서, 일렉트로카디오그램(ECG) 센서, IR(infrared) 센서, 홍채 센서 및/또는 지문 센서를 포함할 수 있다. 센서 모듈 240은 그 안에 속한 적어도 하나 이상의 센서들을 제어하기 위한 제어 회로를 더 포함할 수 있다. 어떤 실시예에서는, 전자 장치 201은 프로세서 210의 일부로서 또는 별도로, 센서 모듈 240을 제어하도록 구성된 프로세서를 더 포함하여, 프로세서 210이 슬립(sleep) 상태에 있는 동안, 센서 모듈 240을 제어할 수 있다.
입력 장치 250은, 예를 들면, 터치 패널 252, (디지털) 펜 센서 254, 키 256, 또는 초음파 입력 장치 258를 포함할 수 있다. 터치 패널 252는, 예를 들면, 정전식, 감압식, 적외선 방식, 또는 초음파 방식 중 적어도 하나의 방식을 사용할 수 있다. 또한, 터치 패널 252는 제어 회로를 더 포함할 수도 있다. 터치 패널 252는 택타일 레이어(tactile layer)를 더 포함하여, 사용자에게 촉각 반응을 제공할 수 있다. (디지털) 펜 센서 254는, 예를 들면, 터치 패널의 일부이거나, 별도의 인식용 쉬트를 포함할 수 있다. 키 256은, 예를 들면, 물리적인 버튼, 광학식 키, 또는 키패드를 포함할 수 있다. 초음파 입력 장치 258은 마이크(예: 마이크 288)를 통해, 입력 도구에서 발생된 초음파를 감지하여, 상기 감지된 초음파에 대응하는 데이터를 확인할 수 있다.
디스플레이 260(예: 디스플레이 160)은 패널 262, 홀로그램 장치 264, 프로젝터 266, 및/또는 이들을 제어하기 위한 제어 회로를 포함할 수 있다. 패널 262는, 예를 들면, 유연하게, 투명하게, 또는 착용할 수 있게 구현될 수 있다. 패널 262는 터치 패널 252와 하나 이상의 모듈로 구성될 수 있다. 홀로그램 장치 264는 빛의 간섭을 이용하여 입체 영상을 허공에 보여줄 수 있다. 프로젝터 266은 스크린에 빛을 투사하여 영상을 표시할 수 있다. 스크린은, 예를 들면, 전자 장치 201의 내부 또는 외부에 위치할 수 있다. 인터페이스 270은, 예를 들면, HDMI 272, USB 274, 광 인터페이스(optical interface) 276, 또는 D-sub(D-subminiature) 278을 포함할 수 있다. 인터페이스 270은, 예를 들면, 도 1에 도시된 통신 인터페이스 170에 포함될 수 있다. 추가적으로 또는 대체적으로, 인터페이스 270은, 예를 들면, MHL(mobile high-definition link) 인터페이스, SD카드/MMC(multi-media card) 인터페이스, 또는 IrDA(infrared data association) 규격 인터페이스를 포함할 수 있다.
오디오 모듈 280은, 예를 들면, 소리와 전기 신호를 쌍방향으로 변환시킬 수 있다. 오디오 모듈 280의 적어도 일부 구성요소는, 예를 들면, 도 1 에 도시된 입출력 인터페이스 145에 포함될 수 있다. 오디오 모듈 280은, 예를 들면, 스피커 282, 리시버 284, 이어폰 286, 또는 마이크 288 등을 통해 입력 또는 출력되는 소리 정보를 처리할 수 있다. 카메라 모듈 291은, 예를 들면, 정지 영상 및 동영상을 촬영할 수 있는 장치로서, 한 실시예에 따르면, 하나 이상의 이미지 센서(예: 전면 센서 또는 후면 센서), 렌즈, 이미지 시그널 프로세서(ISP), 또는 플래시(예: LED 또는 xenon lamp 등)를 포함할 수 있다. 전력 관리 모듈 295는, 예를 들면, 전자 장치 201의 전력을 관리할 수 있다. 한 실시예에 따르면, 전력 관리 모듈 295는 PMIC(power management integrated circuit), 충전 IC, 또는 배터리 또는 연료 게이지를 포함할 수 있다. PMIC는, 유선 및/또는 무선 충전 방식을 가질 수 있다. 무선 충전 방식은, 예를 들면, 자기공명 방식, 자기유도 방식 또는 전자기파 방식 등을 포함하며, 무선 충전을 위한 부가적인 회로, 예를 들면, 코일 루프, 공진 회로, 또는 정류기 등을 더 포함할 수 있다. 배터리 게이지는, 예를 들면, 배터리 296의 잔량, 충전 중 전압, 전류, 또는 온도를 측정할 수 있다. 배터리 296은, 예를 들면, 충전식 전지 및/또는 태양 전지를 포함할 수 있다.
인디케이터 297은 전자 장치 201 또는 그 일부(예: 프로세서 210)의 특정 상태, 예를 들면, 부팅 상태, 메시지 상태 또는 충전 상태 등을 표시할 수 있다. 모터 298은 전기적 신호를 기계적 진동으로 변환할 수 있고, 진동, 또는 햅틱 효과 등을 발생시킬 수 있다. 전자 장치 201은, 예를 들면, DMB(digital multimedia broadcasting), DVB(digital video broadcasting), 또는 미디어플로(mediaFloTM) 등의 규격에 따른 미디어 데이터를 처리할 수 있는 모바일 TV 지원 장치(예: GPU)를 포함할 수 있다. 본 문서에서 기술된 구성요소들 각각은 하나 또는 그 이상의 부품(component)으로 구성될 수 있으며, 해당 구성요소의 명칭은 전자 장치의 종류에 따라서 달라질 수 있다. 다양한 실시예에서, 전자 장치(예: 전자 장치 201)는 일부 구성요소가 생략되거나, 추가적인 구성요소를 더 포함하거나, 또는, 구성요소들 중 일부가 결합되어 하나의 개체로 구성되되, 결합 이전의 해당 구성요소들의 기능을 동일하게 수행할 수 있다.
도 3은 본 발명의 다양한 실시예에 따른 프로그램 모듈의 블록도이다. 한 실시예에 따르면, 프로그램 모듈 310(예: 프로그램 140)은 전자 장치(예: 전자 장치 101)에 관련된 자원을 제어하는 운영 체제 및/또는 운영 체제 상에서 구동되는 다양한 어플리케이션(예: 어플리케이션 프로그램 147)을 포함할 수 있다. 운영 체제는, 예를 들면, AndroidTM, iOSTM, WindowsTM, SymbianTM, TizenTM, 또는 BadaTM를 포함할 수 있다. 도 3을 참조하면, 프로그램 모듈 310은 커널 320(예: 커널 141), 미들웨어 330(예: 미들웨어 143), API 360(예: API 145), 및/또는 어플리케이션 370(예: 어플리케이션 프로그램 147)을 포함할 수 있다. 프로그램 모듈 310의 적어도 일부는 전자 장치 상에 프리로드 되거나, 외부 전자 장치(예: 전자 장치 102, 104, 서버 106 등)로부터 다운로드 가능하다.
커널 320은, 예를 들면, 시스템 리소스 매니저 321 및/또는 디바이스 드라이버 323을 포함할 수 있다. 시스템 리소스 매니저 321은 시스템 리소스의 제어, 할당, 또는 회수를 수행할 수 있다. 한 실시예에 따르면, 시스템 리소스 매니저 321은 프로세스 관리부, 메모리 관리부, 또는 파일 시스템 관리부를 포함할 수 있다. 디바이스 드라이버 323은, 예를 들면, 디스플레이 드라이버, 카메라 드라이버, 블루투스 드라이버, 공유 메모리 드라이버, USB 드라이버, 키패드 드라이버, WiFi 드라이버, 오디오 드라이버, 또는 IPC(inter-process communication) 드라이버를 포함할 수 있다. 미들웨어 330은, 예를 들면, 어플리케이션 370이 공통적으로 필요로 하는 기능을 제공하거나, 어플리케이션 370이 전자 장치 내부의 제한된 시스템 자원을 사용할 수 있도록 API 360을 통해 다양한 기능들을 어플리케이션 370으로 제공할 수 있다. 한 실시예에 따르면, 미들웨어 330은 런타임 라이브러리 335, 어플리케이션 매니저 341, 윈도우 매니저 342, 멀티미디어 매니저 343, 리소스 매니저 344, 파워 매니저 345, 데이터베이스 매니저 346, 패키지 매니저 347, 커넥티비티 매니저 348, 노티피케이션 매니저 349, 로케이션 매니저 350, 그래픽 매니저 351, 또는 시큐리티 매니저 352 중 적어도 하나를 포함할 수 있다.
런타임 라이브러리 335는, 예를 들면, 어플리케이션 370이 실행되는 동안에 프로그래밍 언어를 통해 새로운 기능을 추가하기 위해 컴파일러가 사용하는 라이브러리 모듈을 포함할 수 있다. 런타임 라이브러리 335는 입출력 관리, 메모리 관리, 또는 산술 함수 처리를 수행할 수 있다. 어플리케이션 매니저 341은, 예를 들면, 어플리케이션 370의 생명 주기를 관리할 수 있다. 윈도우 매니저 342는 화면에서 사용되는 GUI 자원을 관리할 수 있다. 멀티미디어 매니저 343은 미디어 파일들의 재생에 필요한 포맷을 파악하고, 해당 포맷에 맞는 코덱을 이용하여 미디어 파일의 인코딩 또는 디코딩을 수행할 수 있다. 리소스 매니저 344는 어플리케이션 370의 소스 코드 또는 메모리의 공간을 관리할 수 있다. 파워 매니저 345는, 예를 들면, 배터리의 용량 또는 전원을 관리하고, 전자 장치의 동작에 필요한 전력 정보를 제공할 수 있다. 한 실시예에 따르면, 파워 매니저 345는 바이오스(BIOS: basic input/output system)와 연동할 수 있다. 데이터베이스 매니저 346은, 예를 들면, 어플리케이션 370에서 사용될 데이터베이스를 생성, 검색, 또는 변경할 수 있다. 패키지 매니저 347은 패키지 파일의 형태로 배포되는 어플리케이션의 설치 또는 갱신을 관리할 수 있다.
커넥티비티 매니저 348은, 예를 들면, 무선 연결을 관리할 수 있다. 노티피케이션 매니저 349는, 예를 들면, 도착 메시지, 약속, 근접성 알림 등의 이벤트를 사용자에게 제공할 수 있다. 로케이션 매니저 350은, 예를 들면, 전자 장치의 위치 정보를 관리할 수 있다. 그래픽 매니저 351은, 예를 들면, 사용자에게 제공될 그래픽 효과 또는 이와 관련된 사용자 인터페이스를 관리할 수 있다. 보안 매니저 352는, 예를 들면, 시스템 보안 또는 사용자 인증을 제공할 수 있다. 한 실시예에 따르면, 미들웨어 330은 전자 장치의 음성 또는 영상 통화 기능을 관리하기 위한 통화(telephony) 매니저 또는 전술된 구성요소들의 기능들의 조합을 형성할 수 있는 하는 미들웨어 모듈을 포함할 수 있다. 한 실시예에 따르면, 미들웨어 330은 운영 체제의 종류 별로 특화된 모듈을 제공할 수 있다. 미들웨어 330은 동적으로 기존의 구성요소를 일부 삭제하거나 새로운 구성요소들을 추가할 수 있다. API 360은, 예를 들면, API 프로그래밍 함수들의 집합으로, 운영 체제에 따라 다른 구성으로 제공될 수 있다. 예를 들면, 안드로이드 또는 iOS의 경우, 플랫폼 별로 하나의 API 셋을 제공할 수 있으며, 타이젠의 경우, 플랫폼 별로 두 개 이상의 API 셋을 제공할 수 있다.
어플리케이션 370은, 예를 들면, 홈 371, 다이얼러 372, SMS/MMS 373, IM(instant message) 374, 브라우저 375, 카메라 376, 알람 377, 컨택트 378, 음성 다이얼 379, 이메일 380, 달력 381, 미디어 플레이어 382, 앨범 383, 와치 384, 헬스 케어(예: 운동량 또는 혈당 등을 측정), 또는 환경 정보(예: 기압, 습도, 또는 온도 정보) 제공 어플리케이션을 포함할 수 있다. 한 실시예에 따르면, 어플리케이션 370은 전자 장치와 외부 전자 장치 사이의 정보 교환을 지원할 수 있는 정보 교환 어플리케이션을 포함할 수 있다. 정보 교환 어플리케이션은, 예를 들면, 외부 전자 장치에 특정 정보를 전달하기 위한 노티피케이션 릴레이 어플리케이션, 또는 외부 전자 장치를 관리하기 위한 장치 관리 어플리케이션을 포함할 수 있다. 예를 들면, 알림 전달 어플리케이션은 전자 장치의 다른 어플리케이션에서 발생된 알림 정보를 외부 전자 장치로 전달하거나, 또는 외부 전자 장치로부터 알림 정보를 수신하여 사용자에게 제공할 수 있다. 장치 관리 어플리케이션은, 예를 들면, 전자 장치와 통신하는 외부 전자 장치의 기능(예: 외부 전자 장치 자체(또는, 일부 구성 부품)의 턴-온/턴-오프 또는 디스플레이의 밝기(또는, 해상도) 조절), 또는 외부 전자 장치에서 동작하는 어플리케이션을 설치, 삭제, 또는 갱신할 수 있다. 한 실시예에 따르면, 어플리케이션 370은 외부 전자 장치의 속성에 따라 지정된 어플리케이션(예: 모바일 의료 기기의 건강 관리 어플리케이션)을 포함할 수 있다. 한 실시예에 따르면, 어플리케이션 370은 외부 전자 장치로부터 수신된 어플리케이션을 포함할 수 있다. 프로그램 모듈 310의 적어도 일부는 소프트웨어, 펌웨어, 하드웨어(예: 프로세서 210), 또는 이들 중 적어도 둘 이상의 조합으로 구현(예: 실행)될 수 있으며, 하나 이상의 기능을 수행하기 위한 모듈, 프로그램, 루틴, 명령어 세트 또는 프로세스를 포함할 수 있다.
본 문서에서 사용된 용어 "모듈"은 하드웨어, 소프트웨어 또는 펌웨어로 구성된 유닛을 포함하며, 예를 들면, 로직, 논리 블록, 부품, 또는 회로 등의 용어와 상호 호환적으로 사용될 수 있다. "모듈"은, 일체로 구성된 부품 또는 하나 또는 그 이상의 기능을 수행하는 최소 단위 또는 그 일부가 될 수 있다. "모듈"은 기계적으로 또는 전자적으로 구현될 수 있으며, 예를 들면, 어떤 동작들을 수행하는, 알려졌거나 앞으로 개발될, ASIC(application-specific integrated circuit) 칩, FPGAs(field-programmable gate arrays), 또는 프로그램 가능 논리 장치를 포함할 수 있다. 다양한 실시예에 따른 장치(예: 모듈들 또는 그 기능들) 또는 방법(예: 동작들)의 적어도 일부는 프로그램 모듈의 형태로 컴퓨터로 판독 가능한 저장 매체(예: 메모리 130)에 저장된 명령어로 구현될 수 있다. 상기 명령어가 프로세서(예: 프로세서 120)에 의해 실행될 경우, 프로세서가 상기 명령어에 해당하는 기능을 수행할 수 있다. 컴퓨터로 판독 가능한 기록 매체는, 하드디스크, 플로피디스크, 마그네틱 매체(예: 자기테이프), 광기록 매체(예: CD-ROM, DVD, 자기-광 매체 (예: 플롭티컬 디스크), 내장 메모리 등을 포함할 수 있다. 명령어는 컴파일러에 의해 만들어지는 코드 또는 인터프리터에 의해 실행될 수 있는 코드를 포함할 수 있다. 다양한 실시예에 따른 모듈 또는 프로그램 모듈은 전술한 구성요소들 중 적어도 하나 이상을 포함하거나, 일부가 생략되거나, 또는 다른 구성요소를 더 포함할 수 있다. 다양한 실시예에 따른, 모듈, 프로그램 모듈 또는 다른 구성요소에 의해 수행되는 동작들은 순차적, 병렬적, 반복적 또는 휴리스틱하게 실행되거나, 적어도 일부 동작이 다른 순서로 실행되거나, 생략되거나, 또는 다른 동작이 추가될 수 있다.
본 발명의 다양한 실시예에서 전자 장치는 웹푸시(webpush)를 이용하여 서버로부터 푸시 메시지를 수신할 수 있다. 웹푸시를 이용하여 서버로부터 푸시 메시지를 수신하기 위해 전자 장치는 푸시 서비스를 수신하기 위해 계속적인 연결을 유지하기 위한 푸시 플랫폼과 서비스 워커(service worker) 기술을 사용할 수 있다. 상기 서비스워커는 백그라운드 자바스크립트(background javascript)를 지원하기 위한 기술이다. 본 발명의 다양한 실시예에서 푸시 서비스가 수신되기 위해서는 상기 서비스워커를 설치하는 동작이 수행될 수 있으며, 상기 서비스워커는 웹푸시 제공 서버 또는 전자 장치 내 웹 브라우저에 위치할 수 있다. 전자 장치는 서비스워커를 통해 웹 브라우저가 실행 중이 아니어도 플랫폼 레벨의 특정 신호를 받아 백그라운드로 특정 작업을 수행할 수 있다. 예컨대, 플랫폼 레벨에서 특정 신호를 전송하면, 상기 전송된 특정 신호를 서비스워커가 처리(예컨대, 팝업창 표시, 해당 페이지 오픈)할 수 있다. 서버는 전자 장치ID를 이용하여 푸시 플랫폼으로 푸시 서비스를 전송할 수 있다. 상기 전송된 푸시 서비스는 서비스워커가 분석하여 알림 메시지를 만드는 등의 작업을 수행할 수 있다.
도 4는 본 발명의 다양한 실시예에 따른 웹푸시를 이용한 푸시 서비스를 제공하는 시스템을 도시하는 도면이다.
도 4를 참조하면, 본 발명의 실시예에 따른 푸시 서비스 제공 시스템은 전자 장치 401, 웹사이트 403, 웹푸시 제공 서버 405, 및 푸시 서버 407을 포함할 수 있다.
본 발명의 다양한 실시예에서 전자 장치 401은 통신부 410, 메모리 420, 터치스크린 430, 및 프로세서 440을 포함할 수 있다.
본 발명의 다양한 실시예에서 전자 장치 401은 통신부 410(예컨대, 도 1의 통신 인터페이스 170, 도 2의 통신 모듈 220)을 통해 푸시 서비스 수신에 동의하는 동작에서 서비스워커를 웹푸시 제공 서버 405로부터 수신할 수 있다. 상기 전자 장치 401은 통신부 410을 통해 웹푸시 제공 서버 405로 상기 전자 장치401의 ID 생성을 요청할 수 있다. 상기 전자 장치 401은 상기 통신부 410을 통해 웹푸시 제공 서버 405로부터 생성된 전자 장치 401의 ID를 수신할 수 있다. 상기 전자 장치 401은 상기 통신부 410을 통해 웹사이트 403의 관리자(예컨대, 웹푸시 전송 전자 장치)로부터 전송된 푸시 메시지를 푸시 서버 407로부터 수신할 수 있다.
본 발명의 다양한 실시예에서 메모리 420(예컨대, 도 1의 메모리 130, 도 2의 메모리 230)은 웹 브라우저와 관련된 프로그램을 저장할 수 있다. 또는, 상기 메모리 420은 푸시 서비스를 제공하는 웹사이트 리스트를 저장할 수 있다.
터치스크린 430 은 표시부 431과 터치패널 432를 포함할 수 있다. 상기 표시부 431(예컨대, 디스플레이 160, 디스플레이 260)은 웹 브라우저를 통해 특정 웹사이트를 표시할 수 있다. 표시부 431은 상기 특정 웹사이트가 화이트리스트에 포함되면 푸시 서비스 수신 여부에 대한 푸시 서비스 아이콘 또는 팝업창을 표시할 수 있다. 상기 표시부 431은 푸시 서비스 예컨대, 푸시 메시지가 수신되면 상기 푸시 메시지 알림을 위한 팝업창 또는 상태바에 푸시 메시지 알림 아이콘을 표시할 수 있다.
상기 터치패널 432(예컨대, 도2 의 입력 장치 250)는 표시부 431에 표시되는 푸시 서비스 수신 여부에 대한 푸시 서비스 아이콘 또는 팝업창에서 푸시 서비스를 수신하기 위한 입력을 감지할 수 있다. 상기 터치패널 432는 수신된 푸시 메시지에 포함된 컨텐츠(예컨대, URL)를 선택하는 입력을 감지할 수 있다.
본 발명의 다양한 실시예에서 프로세서 440(예컨대, 도 1의 프로세서 120, 도 2의 프로세서 210)은 통신부 410을 통해 웹푸시 제공 서버405로부터 화이트리스트를 수신하여 메모리 420에 저장할 수 있다. 프로세서 440은 웹 브라우저를 실행하여 특정 웹사이트 화면을 표시부 431에 표시하도록 할 수 있다.
본 발명의 다양한 실시예에서 프로세서 440은 메모리 420에 저장된 화이트리스트에 상기 특정 웹사이트가 포함되어 있는지 여부를 결정할 수 있다. 상기 화이트리스트에 상기 특정 웹사이트가 포함되어 있으면, 프로세서 440은 웹푸시 제공 서버 405에 서비스워커(service worker)를 요청할 수 있다. 프로세서 440은 웹푸시 제공 서버 405로부터 서비스워커를 수신하여 설치(install)할 수 있다. 본 발명의 다양한 실시예에서 프로세서 440은 상기 서비스워커를 설치한 후, 상기 특정 웹사이트의 푸시 서비스 수신 여부를 결정할 수 있다. 예컨대, 프로세서 440은 상기 서비스워커를 설치한 후, 상기 특정 웹사이트의 푸시 서비스 수신 여부에 대한 팝업창 또는 푸시 서비스 아이콘을 표시할 수 있다. 프로세서 440은 상기 팝업창 또는 푸시 서비스 아이콘을 통해 상기 특정 웹사이트로부터 푸시 서비스를 수신하기 위한 입력이 감지되면, 상기 특정 웹사이트의 푸시 서비스를 수신하는 것으로 결정할 수 있다.
본 발명의 다양한 실시예에서 메모리 420에 저장된 화이트리스트에 상기 특정 웹사이트가 포함되어 있으면, 프로세서 440은 상기 특정 웹사이트의 푸시 서비스 수신 여부에 대한 팝업창 또는 푸시 서비스 아이콘을 표시할 수 있다. 프로세서 440은 상기 팝업창 또는 푸시 서비스 아이콘을 통해 상기 웹사이트로부터 푸시 서비스를 수신하기 위한 입력이 감지되면, 상기 특정 웹사이트의 푸시 서비스를 수신하는 것으로 결정하고, 웹푸시 제공 서버 405에 서비스워커를 요청할 수 있다. 프로세서 440은 웹푸시 제공 서버 405로부터 서비스워커를 수신하여 설치할 수 있다.
본 발명의 다양한 실시예에서 프로세서 440은 상기 특정 웹사이트의 푸시 서비스를 수신하는 것으로 결정되면, 웹푸시 제공 서버 405에 전자 장치 401의 ID를 요청할 수 있다. 프로세서 440은 상기 웹푸시 제공 서버 405로부터 생성된 전자 장치 401의 ID를 수신할 수 있다. 프로세서 440은 상기 수신된 전자 장치 401의 ID를 웹푸시 제공 서버 405 또는 웹사이트 403에 전송할 수 있다. 또는, 웹사이트 403은 전자 장치 401로부터 ID를 획득할 수 있다. 프로세서 440은 전자 장치 401의 서비스워커를 통해 푸시 서버 407로부터 상기 전자 장치 401의 ID에 대응하는 푸시 메시지를 수신하여 표시할 수 있다.
또는, 본 발명의 다양한 실시예에서 메모리 420에 저장된 화이트리스트에 상기 특정 웹사이트가 포함되어 있으면, 프로세서 440은 전자 장치 401의 웹 브라우저 내 서비스워커가 존재하는지 탐색할 수 있다. 상기 웹 브라우저 내 서비스워커가 존재하는 경우, 프로세서 440은 상기 서비스워커를 설치할 수 있다. 프로세서 440은 상기 서비스워커를 설치한 후, 상기 특징 웹사이트의 푸시 서비스 수신 여부를 결정할 수 있다. 상기 특정 웹사이트의 푸시 서비스를 수신하는 것으로 결정되면, 프로세서 440은 웹푸시 제공 서버 405에 전자 장치 401의 ID를 요청할 수 있다. 프로세서 440은 상기 웹푸시 제공 서버 405로부터 생성된 전자 장치 401의 ID를 수신할 수 있다. 프로세서 440은 상기 수신된 전자 장치 401의 ID를 웹푸시 제공 서버 405 또는 웹사이트 403에 전송할 수 있다. 또는, 웹사이트 403은 전자 장치 401로부터 상기 ID를 획득할 수 있다. 프로세서 440은 서비스워커를 통해 푸시 서버 407로부터 상기 전자 장치 401의 ID에 대응하는 푸시 메시지를 수신하여 표시할 수 있다.
본 발명의 다양한 실시예에서 전자 장치 401은 유무선 통신을 형성하는 통신부 410, 표시부 431, 상기 표시부 431과 별도로 또는 결합된 입력부, 적어도 부분적으로 웹 브라우징을 위해 구성된 소프트웨어 프로그램을 저장하는 비 휘발성 메모리 및 상기 통신부 410, 상기 표시부 431, 상기 입력부, 및 상기 비 휘발성 메모리와 전기적으로 연결된 프로세서 440을 포함하고, 상기 프로세서 440과 전기적으로 연결된 메모리 420은, 상기 비 휘발성 메모리는 실행 시에, 상기 프로세서 440이 상기 소프트웨어 프로그램의 사용자 인터페이스를 상기 표시부 431에 표시하고, 상기 입력부를 통한 제1 사용자 입력에 응답하여 상기 통신부 410을 통해 사용자 구독에 따른 푸시 서비스와 관련된 제1 서버(예컨대, 웹사이트 403)로부터 제1 웹페이지를 수신하고, 상기 제1 웹페이지와 상기 사용자 인터페이스에 푸시 서비스를 위한 인디케이터를 표시하고, 상기 입력부를 통해 상기 푸시 서비스 구독을 위한 제2 사용자 입력을 수신하고, 상기 통신부 410을 통해 상기 푸시 서비스 구독을 나타내는 신호를 상기 푸시 서비스를 제공하는 복수의 웹사이트를 관리하는 상기 제1 서버(예컨대, 웹사이트 403)와 독립적인 제2 서버(예컨대, 웹푸시 제공 서버 405)에 전송하는 인스트럭션들을 저장하도록 할 수 있다.
본 발명의 다양한 실시예에서 상기 인스트럭션들은, 상기 프로세서 440이, 상기 통신부 410을 통해 상기 제2 서버(예컨대, 웹푸시 제공 서버 405)와 독립적인 제3 서버(예컨대, 푸시 서버 407)로부터 상기 푸시 서비스와 관련된 데이터를 수신하고, 상기 수신된 데이터에 응답하여 상기 표시부를 통해 푸시 서비스 알림을 제공하도록 할 수 있다.
본 발명의 다양한 실시예에서 상기 인스트럭션들은, 상기 프로세서 440이, 상기 제2 서버(예컨대, 웹푸시 제공 서버 405)의 정보에 적어도 일부 기반하여 상기 제1 서버(예컨대, 웹사이트 403)가 푸시 서비스를 제공하는지 여부를 결정하고, 상기 제1 서버(예컨대, 웹사이트 403)가 푸시 서비스를 제공하는지 여부에 대한 결정에 적어도 일부 기반하여 인디케이터를 표시하도록 할 수 있다.
본 발명의 다양한 실시예에서 상기 정보는 상기 푸시 서비스를 제공하는 복수의 웹사이트를 포함하는 리스트일 수 있다.
본 발명의 다양한 실시예에서 상기 인스트럭션들은, 상기 프로세서 440이, 상기 제1 서버(예컨대, 웹사이트 403)가 푸시 서비스를 제공하면 푸시 서비스에 필요한 서비스워커를 상기 제2 서버(예컨대, 웹푸시 제공 서버 405)에 요청하고, 상기 제2 서버(예컨대, 웹푸시 제공 서버 405)로부터 상기 서비스워커를 수신하여 설치하도록 할 수 있다.
본 발명의 다양한 실시예에서 상기 인스트럭션들은, 상기 프로세서 440이, 상기 제1 서버(예컨대, 웹사이트 403)가 푸시 서비스를 제공하면 푸시 서비스에 필요한 서비스워커가 상기 전자 장치 401 내에 저장되어 있는지 여부를 확인하고, 확인 결과 상기 전자 장치 401 내에 상기 서비스워커가 저장되어 있는 경우 상기 전자 장치 401의 브라우저 엔진을 통해 설치하도록 할 수 있다.
본 발명의 다양한 실시예에서 상기 인스트럭션들은, 상기 프로세서 440이, 상기 서비스워커가 설치된 후 상기 푸시 서비스를 위한 인디케이터에서 상기 제2 사용자 입력을 수신하면 상기 전자 장치 401의 ID를 상기 제2 서버(예컨대, 웹푸시 제공 서버 405)로 요청하고, 상기 제2 서버(예컨대, 웹푸시 제공 서버 405)로부터 상기 전자 장치 401의 ID를 수신하도록 할 수 있다.
본 발명의 다양한 실시예에서 상기 인스트럭션들은, 상기 프로세서 440이, 상기 전자 장치 401의 ID를 상기 제1 서버(예컨대, 웹사이트 403) 또는 상기 제2 서버(예컨대, 웹푸시 제공 서버 405)에 전송하도록 할 수 있다.
본 발명의 다양한 실시예에서 상기 인스트럭션들은, 상기 프로세서 440이, 상기 서비스워커를 통해 상기 제3 서버(예컨대, 푸시 서버 407)로부터 상기 전자 장치 401의 ID에 대응하는 푸시 메시지를 수신하도록 할 수 있다.
본 발명의 다양한 실시예에서 상기 푸시 서비스를 위한 인디케이터는 상기 푸시 서비스 수신 여부에 대한 팝업창 또는 푸시 서비스 아이콘을 포함할 수 있다.
일 실시예에 따르면, 상기 도 4에 도시하지 않았지만 상기 전자 장치 401은 위치 정보 수신을 위한 GPS(global positioning system) 모듈, 이미지 또는 동영상 촬영을 위한 카메라 모듈, 방송 수신을 위한 방송 수신 모듈 등의 부가 기능을 갖는 구성 요소들을 선택적으로 더 포함할 수 있다.
본 발명의 다양한 실시예에서 웹사이트 403은 푸시 서비스를 전자 장치 401에 제공하는 주체를 의미하며, 예컨대, 중소기업 웹사이트, 비기업 유명 웹사이트(예컨대, 설치형 블로그와 같은 CMS나 포털 공간을 이용하는 웹사이트)를 포함할 수 있다. 또는, 웹사이트403은 웹푸시 전송 전자 장치, 웹사이트 서버 또는 웹푸시 서비스 서버를 포함할 수 있다.
본 발명의 다양한 실시예에서 웹푸시 제공 서버 405는 전자 장치 401에 웹사이트 403의 웹푸시 서비스 제공을 허가할 수 있다. 상기 웹푸시 제공 서버 405는 상기 웹푸시 서비스 제공을 허가한 웹사이트 403을 화이트리스트에 등록하여 관리하고, 웹 푸시 서비스를 제공할 수 있다.
본 발명의 다양한 실시예에서 푸시 서버 407은 웹푸시 제공 서버 405로부터 수신한 푸시 메시지를 상기 전자 장치 401의 ID에 대응하는 푸시 플랫폼으로 변경하여 상기 전자 장치 401에 전송할 수 있다. 예컨대, 상기 푸시 서버 407은 GCM(google cloud messaging), SPP(samsung push platform)를 포함할 수 있다.
전술한 웹사이트 403, 웹푸시 제공 서버 405, 및 푸시 서버 407에 관하여 후술하는 도 5를 통해 상세히 살펴보도록 한다.
도 5는 본 발명의 다양한 실시예에 따른 푸시 서비스를 제공하는 시스템을 도시하는 도면이다.
도 5를 참조하면, 본 발명의 다양한 실시예에서 푸시 서비스 제공 시스템 500은 전자 장치 501(예컨대, 도 4의 전자 장치 401), 웹사이트 503(예컨대, 도 4의 웹사이트 403), 웹푸시 제공 서버 505(예컨대, 도 4의 웹푸시 제공 서버 405), 및 푸시 서버 507(예컨대, 도 4의 푸시 서버 407)을 포함할 수 있다.
본 발명의 다양한 실시예에서 전자 장치 501은 웹 브라우저를 실행할 수 있다. 전자 장치 501은 웹 브라우저를 실행하여 특정 웹사이트에 접속하면 웹사이트 503으로부터 웹 페이지520을 수신하여 출력할 수 있다.
본 발명의 다양한 실시예에서 웹사이트 503은 푸시 서비스 또는 웹 페이지를 전자 장치 501에 제공하는 주체를 의미하며, 예컨대, 중소기업 웹사이트, 비기업 유명 웹사이트(예컨대, 설치형 블로그와 같은 CMS나 포털 공간을 이용하는 웹사이트)를 포함할 수 있다. 또는, 웹사이트503은 웹푸시 전송 전자 장치 502, 웹사이트 서버 또는 웹푸시 서비스 서버를 포함할 수 있다.
본 발명의 다양한 실시예에서 웹푸시 제공 서버 505는 전자 장치 501에 웹사이트 503의 웹푸시 서비스 제공을 허가할 수 있다. 상기 웹푸시 제공 서버 505는 상기 웹푸시 서비스 제공을 허가한 웹사이트 503을 화이트리스트에 등록하여 관리할 수 있다. 또는, 상기 웹푸시 제공 서버 505는 웹푸시 서비스 제공을 허가한 복수의 웹사이트들이 포함된 화이트리스트를 전자 장치 501에 전송할 수 있다. 예컨대, 상기 웹푸시 제공 서버 505는 전자 장치 501에 화이트리스트 전체를 전송하거나 또는 화이트리스트 일부분 예컨대, 추가/변경된 웹사이트만을 전송할 수 있다. 전자 장치 501은 상기 웹푸시 제공 서버 505로부터 수신한 화이트리스트를 메모리에 저장할 수 있다. 일 실시예에서, 전자 장치 501은 메모리에 화이트리스트가 저장된 경우, 상기 웹푸시 제공 서버 505로부터 수신한 화이트리스트를 기반으로 업데이트할 수 있다.
본 발명의 다양한 실시예에서 전자 장치 501은 웹 브라우저를 통해 접속한 특정 웹사이트가 푸시 서비스를 제공하는지 여부를 확인할 수 있다. 전자 장치 501은 메모리에 저장된 화이트리스트를 통해 상기 특정 웹사이트가 푸시 서비스를 제공하는 사이트인지 여부를 확인할 수 있다. 예를 들어, 상기 특정 웹사이트가 화이트리스트에 포함된 경우, 전자 장치 501은 상기 특정 웹사이트가 푸시 서비스를 제공하는 것으로 결정할 수 있다. 상기 특정 웹사이트가 상기 화이트리스트에 포함됨에 따라 푸시 서비스를 제공하는 사이트로 결정되면, 전자 장치 501은 웹푸시 서비스에 필요한 서비스워커를 설치할 수 있다. 본 발명의 다양한 실시예에서 상기 서비스워커는 원격에 위치할 수 있으며, 전자 장치 501은 상기 서비스워커를 수신하여 <script> 삽입(injection) 방식으로 설치할 수 있다. 본 발명의 다양한 실시예에서 상기 서비스워커는 상기 전자 장치 501 내에 저장되어 있을 수 있으며, 전자 장치 501은 상기 서비스워커를 설치할 수 있다.
본 발명의 다양한 실시예에서 상기 서비스워커가 원격에 위치하여 스크립트 삽입 방식으로 설치되는 경우, 전자 장치 501은 웹푸시 제공 서버 505에 서비스워커를 요청 523할 수 있다. 이에 응답하여 웹푸시 제공 서버 505는 상기 전자 장치 501에 서비스워커를 전송525할 수 있다. 전자 장치 501은 상기 웹푸시 제공 서버 505로부터 수신된 서비스워커를 설치할 수 있다.
일 실시예에 따르면, 상기 서비스워커는 전자 장치 501 내에 저장되어 있을 수 있다. 예컨대, 특정 웹사이트가 푸시 서비스를 제공하는 경우, 전자 장치 501은 웹푸시 서비스에 필요한 상기 저장된 서비스워커를 설치할 수 있다.
상기 서비스워커가 설치되면, 전자 장치 501은 특정 웹사이트의 푸시 서비스 수신 여부를 결정할 수 있다. 예컨대, 상기 서비스워커가 설치되면, 전자 장치 501은 특정 웹사이트의 푸시 서비스 수신 여부에 대한 팝업창 또는 푸시 서비스 아이콘을 표시할 수 있다. 상기 푸시 서비스 수신 여부에 대한 팝업창은 특정 웹사이트의 푸시 서비스를 수신할 것인지 질의하는 팝업창일 수 있으며, 예컨대, 확인/취소 버튼이 함께 표시될 수 있다.
일 실시예에 따르면, 상기 푸시 서비스 수신 여부에 대한 푸시 서비스 아이콘은 토글 기능을 가질 수 있으며, 상기 푸시 서비스 아이콘을 선택함에 따라 온(on)/오프(off)로 제어되어 푸시 메시지 수신/해제할 수 있다. 상기 팝업창 또는 상기 푸시 서비스 아이콘을 통해 웹사이트로부터 푸시 서비스를 수신하기 위한 입력(예컨대, 팝업창에서 확인 선택, 푸시 서비스 아이콘을 온으로 제어)이 감지되면, 전자 장치 501은 상기 웹사이트로부터 푸시 서비스를 수신하는 것으로 결정할 수 있다.
본 발명의 다양한 실시예에서 전자 장치 501은 웹푸시 제공 서버 505에 상기 전자 장치 501의 ID를 요청 526할 수 있다. 상기 전자 장치 501의 ID 요청에 응답하여, 웹푸시 제공 서버 505는 상기 전자 장치 501의 ID를 생성하여 상기 전자 장치 501에 전송 527할 수 있다. 전자 장치 501은 상기 웹푸시 제공 서버 505로부터 상기 전자 장치 501의 ID를 수신할 수 있다. 전자 장치 501은 특정 웹사이트의 푸시 서비스를 수신하기 위해 상기 전자 장치 501의 ID를 웹푸시 제공 서버 505 또는 웹사이트 503에 전송할 수 있다. 또는, 웹사이트 503은 전자 장치 501로부터 상기 ID를 획득할 수 있다.
본 발명의 다양한 실시예에서 상기 웹사이트 503은 웹푸시 전송 전자 장치 502를 통해 전자 장치 501에 푸시 서비스 예컨대, 푸시 메시지를 전송하기 위한 입력을 감지하면, 푸시 메시지를 웹푸시 제공 서버 505에 전송 530할 수 있다. 예를 들어, 상기 웹사이트 503은 푸시 메시지를 웹푸시 제공 서버 505에 전송 530할 수 있다. 상기 웹푸시 제공 서버 505는 푸시 API를 호출 533하여 상기 푸시 메시지를 푸시 서버 507에 전송할 수 있다. 상기 푸시 서버 507은 상기 전자 장치 501의 ID에 대응하는 푸시 메시지를 상기 전자 장치 501에 전송 535할 수 있다. 예컨대, 상기 푸시 서버 507은 상기 웹사이트 503으로부터 전송된 푸시 메시지를 상기 전자 장치 501의 플랫폼에 적합하게 변경하여 상기 전자 장치 501에 전송할 수 있다. 전자 장치 501은 서비스워커를 통해 상기 수신한 푸시 메시지에 대한 알림을 출력할 수 있다. 예컨대, 전자 장치 501은 표시부에 푸시 서비스 알림에 대한 인디케이터 또는 팝업창 등을 표시할 수 있다. 사용자는 상기 표시부에 표시되는 푸시 서비스 알림에 대한 인디케이터 또는 팝업창을 통해 특정 웹사이트로부터 푸시 서비스가 수신되었음을 확인할 수 있다. 일 실시예에 따르면, 웹푸시 전송 전자 장치 502는 전자 장치501과 동일 또는 유사할 수 있다.
도 6은 본 발명의 다양한 실시예에 따른 웹푸시를 이용한 푸시 서비스 제공 방법을 설명하기 위한 전자 장치와 서버 간에 신호 흐름을 도시하는 도면이다.
도 6을 참조하면, 푸시 서버 607(예컨대, 도 4의 푸시 서버 407, 도 5의 푸시 서버 507)과 웹푸시 수신 전자 장치 601(예컨대, 도 4의 전자 장치 401, 도 5의 전자 장치 501)은 통신부를 통해 연결 상태를 유지611할 수 있다. 웹푸시 전송 전자 장치 602(예컨대, 도 5의 웹푸시 전송 전자 장치 502)는 웹푸시 수신 전자 장치 601에 푸시 서비스를 제공하기 위해 웹푸시 제공 서버 605(예컨대, 도 4의 웹푸시 제공 서버 405, 도 5의 웹푸시 제공 서버 505)에 웹푸시 서비스를 신청 613할 수 있다.
본 발명의 다양한 실시예에서 상기 웹푸시 수신 전자 장치 601은 도 4 의 전자 장치 401 또는 도 5의 전자 장치501과 동일 또는 유사할 수 있다. 또는 웹푸시 수신 전자 장치 601은 웹푸시 전송 전자 장치602와 동일 또는 유사할 수 있다.
웹푸시 제공 서버 605는 상기 웹사이트 603 으로부터 수신한 웹푸시 서비스 신청에 응답하여 상기 웹사이트 603을 화이트리스트에 등록(추가)할 수 있다. 웹푸시 제공 서버 605는 웹푸시 수신 전자 장치 601에 화이트리스트를 전송 615할 수 있다. 웹푸시 수신 전자 장치 601은 상기 웹푸시 제공 서버 605로부터 수신한 화이트리스트를 메모리에 저장할 수 있다.
본 발명의 다양한 실시예에서 웹푸시 수신 전자 장치 601은 웹 브라우저를 통해 접속한 특정 웹사이트의 웹 페이지를 웹사이트 603에 요청 617할 수 있다. 웹사이트 603은 상기 웹 페이지를 웹푸시 수신 전자 장치 601에 전송 619할 수 있다. 웹푸시 수신 전자 장치 601은 상기 웹사이트 603으로부터 수신한 웹 페이지를 표시할 수 있다.
본 발명의 다양한 실시예에서 상기 특정 웹사이트가 화이트리스트에 포함된 경우, 웹푸시 수신 전자 장치 601은 서비스워커를 설치(install) 621할 수 있다. 상기 서비스워커가 설치되면, 웹푸시 수신 전자 장치 601은 표시부의 적어도 일부 영역(예컨대, 브라우저의 주소 표시줄)에 상기 웹사이트의 푸시 서비스를 수신하기 위한 푸시 서비스 아이콘을 표시할 수 있다.
본 발명의 다양한 실시예에 따르면, 서비스워커가 상기 웹푸시 수신 전자 장치 601 내에 저장되어 있지 않은 경우, 웹푸시 수신 전자 장치 601은 웹푸시 제공 서버 605에 서비스워커를 요청할 수 있다. 이에 응답하여 웹푸시 제공 서버 605는 상기 서비스워커를 상기 웹푸시 수신 전자 장치 601에 전송할 수 있다. 웹푸시 수신 전자 장치 601은 웹푸시 제공 서버 605로부터 수신된 서비스워커를 설치할 수 있다. 상기 서비스워커가 설치되면, 상기 웹푸시 수신 전자 장치 601은 표시부의 적어도 일부 영역(예컨대, 브라우저의 주소 표시줄)에 상기 웹사이트의 푸시 서비스를 수신하기 위한 푸시 서비스 아이콘을 표시할 수 있다.
본 발명의 다양한 실시예에서 웹푸시 수신 전자 장치 601은 상기 푸시 서비스 아이콘을 선택하는 입력이 감지되면, 상기 웹푸시 수신 전자 장치 601의 ID(subscriptionID)를 웹푸시 제공 서버 605에 요청623할 수 있다. 상기 웹푸시 제공 서버 605는 상기 웹푸시 수신 전자 장치 601의 ID를 생성 625하고, 상기 웹푸시 수신 전자 장치 601에 전송 627할 수 있다. 웹푸시 수신 전자 장치 601은 상기 웹푸시 제공 서버 605로부터 생성된 상기 전자 장치 601의 ID를 수신할 수 있다. 또는, 웹사이트 603은 웹푸시 수신 전자 장치 601로부터 상기 ID를 획득할 수 있다.
본 발명의 다양한 실시예에 따르면, 푸시 서버 607과 웹푸시 수신 전자 장치 601은 통신부를 통해 연결 629된 상태일 수 있다. 웹푸시 전송 전자 장치 602는 푸시 메시지의 내용을 작성하기 위한 화면을 표시할 수 있다. 예컨대, 상기 푸시 메시지의 내용을 작성하기 위한 화면은 웹 어드민(web admin) 화면 또는 브라우저 내 관리화면을 포함할 수 있다. 본 발명의 다양한 실시예에서 웹 어드민(web admin) 화면은 웹푸시 전송 전자 장치 602를 통해 푸시 메시지 작성을 위한 화면을 표시하는 기능과 상기 푸시 메시지 내용 작성을 위한 입력이 수신됨에 따른 푸시 메시지 내용을 작성하는 기능과 상기 작성된 푸시 메시지를 전자 장치 601에 전송할 수 있는 기능을 구비한 웹 페이지를 의미할 수 있다. 상기 웹 어드민 화면으로 푸시 메시지의 내용을 작성하고, 웹푸시 제공 서버 605에 전송 631할 수 있다. 웹푸시 제공 서버 605는 푸시 서버 607에 푸시 메시지를 전송 635할 수 있다. 푸시 서버 607은 상기 웹푸시 제공 서버 605로부터 수신한 푸시 메시지를 웹푸시 수신 전자 장치 601의 ID에 기초하여 상기 웹푸시 수신 전자 장치 601 의 ID에 대응하는 플랫폼 포맷으로 변환하여 웹푸시 수신 전자 장치 601에 전송 637할 수 있다. 웹푸시 수신 전자 장치 601은 푸시 메시지를 수신 639하여 표시할 수 있다.
본 발명의 다양한 실시예에서 상기 웹푸시 전송 전자 장치 602의 브라우저 내 관리화면을 이용하여 푸시 메시지의 내용을 작성하는 경우, 웹푸시 전송 전자 장치 602는 푸시 메시지의 내용을 작성한 후 푸시 메시지를 웹푸시 제공 서버 605에 전송 633할수 있다. 웹푸시 제공 서버 605는 푸시 서버 607에 푸시 메시지를 전송 635할 수 있다. 푸시 서버 607은 상기 웹푸시 제공 서버 605로부터 수신한 푸시 메시지를 웹푸시 수신 전자 장치 601의 ID를 기반으로 웹푸시 수신 전자 장치 601에 전송하거나, 또는 상기 웹푸시 수신 전자 장치 601 의 ID에 대응하는 플랫폼 포맷으로 변환하여 웹푸시 수신 전자 장치 601에 전송 637할 수 있다. 웹푸시 수신 전자 장치 601은 푸시 메시지를 수신 639하여 표시할 수 있다.
본 발명의 다양한 실시예에 따른 전자 장치(예컨대, 도 4의 전자 장치 401, 도 5의 전자 장치 501)는 소프트웨어 프로그램의 사용자 인터페이스를 표시하고, 상기 사용자 인터페이스에서 제1 사용자 입력이 감지되면, 사용자 구독에 따른 푸시 서비스와 관련된 제1 서버(예컨대, 도 4의 웹사이트 403, 도 5의 웹사이트 503, 도 6의 웹사이트 603)로부터 제1 웹페이지를 수신하고, 상기 제1 웹페이지와 푸시 서비스를 위한 인디케이터를 표시하고, 상기 푸시 서비스 구독을 위한 제2 사용자 입력이 감지되면, 상기 푸시 서비스 구독을 나타내는 신호를 푸시 서비스를 제공하는 복수의 웹사이트를 관리하는 상기 제1 서버와 독립적인 제2 서버(예컨대, 도 4의 웹푸시 제공 서버 405, 도 5의 웹푸시 제공 서버 505, 도 6의 웹푸시 제공 서버 605)에 전송할 수 있다.
본 발명의 다양한 실시예에 따른 전자 장치는 상기 제2 서버와 독립적인 제3 서버(예컨대, 도 4의 푸시 서버 407, 도 5의 푸시 서버 507, 도 6의 푸시 서버 607)로부터 상기 푸시 서비스와 관련된 데이터를 수신하고, 상기 수신된 데이터에 응답하여 푸시 서비스 알림을 출력할 수 있다.
본 발명의 다양한 실시예에 따른 전자 장치는 상기 제2 서버의 정보에 적어도 일부 기반하여 상기 제1 서버가 푸시 서비스를 제공하는지 여부를 결정할 수 있다.
본 발명의 다양한 실시예에 따른 상기 정보는 상기 푸시 서비스를 제공하는 복수의 웹사이트를 포함하는 리스트일 수 있다.
본 발명의 다양한 실시예에서 전자 장치는 상기 제1 서버가 푸시 서비스를 제공하면, 푸시 서비스에 필요한 서비스워커를 상기 제2 서버에 요청하고, 상기 제2 서버로부터 상기 서비스워커를 수신하여 설치할 수 있다.
본 발명의 다양한 실시예에서 전자 장치는 상기 제1 서버가 푸시 서비스를 제공하면, 푸시 서비스에 필요한 서비스워커가 상기 전자 장치 내에 저장되어 있는지 여부를 확인하고, 확인 결과, 상기 전자 장치 내에 상기 서비스워커가 저장되어 있는 경우 상기 전자 장치의 브라우저 엔진을 통해 상기 서비스워커를 설치할 수 있다.
본 발명의 다양한 실시예에서 전자 장치는 상기 서비스워커를 설치하고, 상기 푸시 서비스를 위한 인디케이터에서 상기 제2사용자 입력이 감지되는지 여부를 결정하고, 상기 인디케이터에서 상기 제2 사용자 입력이 감지되면, 상기 전자 장치의 ID를 상기 제2 서버로 요청하고, 상기 제2 서버로부터 상기 전자 장치의 ID를 수신할 수 있다.
본 발명의 다양한 실시예에서 전자 장치는 상기 전자 장치의 ID를 수신하고, 상기 전자 장치의 ID를 상기 제1 서버 또는 상기 제2 서버에 전송할 수 있다.
본 발명의 다양한 실시예에서 전자 장치는 상기 서비스워커를 통해 상기 제3 서버로부터 상기 전자 장치의 ID에 대응하는 푸시 메시지를 수신할 수 있다.
본 발명의 다양한 실시예에 따른 상기 푸시 서비스를 위한 인디케이터는 상기 푸시 서비스 수신 여부에 대한 팝업창 또는 푸시 서비스 아이콘을 포함할 수 있다.
도 7a 및 도 7b는 본 발명의 다양한 실시예에 따른 전자 장치에서 웹푸시 메시지 작성을 설명하기 위한 도면이다.
본 발명의 다양한 실시예에서 도 7a는 전자 장치(예컨대, 도 5의 웹푸시 전송 전자 장치 502, 도 6의 웹푸시 전송 전자 장치 602)에서 푸시 메시지를 작성하는 인터페이스를 설명하기 위한 도면이고, 도 7b는 전자 장치에서 웹푸시 메시지를 작성하는 동작을 설명하기 위한 도면이다.
본 발명의 다양한 실시예에 따른, 도 7a를 참조하면, 상기 도 7a는 브라우저 내 관리화면에서 푸시 메시지 전송 내용을 작성하는 인터페이스에 관한 도면이다.
일 실시예에 따르면, 전자 장치는 관리자 로그인 정보를 이용하여 푸시 메시지 전송 내용을 작성하는 인터페이스에 접근할 수 있다. 예컨대, 관리자로 로그인하면 전자 장치는 도 7a와 같은 푸시 메시지 작성 화면을 표시할 수 있다. 상기 푸시 메시지 작성 화면은 제목 723, 아이콘, 725, URL 725, 및 내용 729를 작성할 수 있는 영역을 포함할 수 있다. 상기 제목 723, 아이콘, 725, URL 725, 및 내용 729에 푸시 메시지 작성 후 전송 731을 선택하는 입력이 감지되면, 전자 장치는 상기 작성된 푸시 메시지를 웹푸시 제공 서버(예컨대, 도 4의 웹푸시 제공 서버 405, 도 5의 웹푸시 제공 서버 505, 도 6의 웹푸시 제공 서버 605)로 전송할 수 있다.
본 발명의 다양한 실시예에 따른, 도 7b를 참조하면, 전자 장치는 741동작에서 푸시 메시지 전송 요청 신호를 수신하면 푸시 메시지 작성을 위한 화면을 표시할 수 있다. 전자 장치는 743동작에서 상기 푸시 메시지 작성을 위한 화면을 통해 푸시 메시지 내용 작성을 위한 입력을 수신할 수 있다. 상기 도 6에서 전술한 바와 같이 상기 푸시 메시지는 웹 어드민(web admin) 화면 또는 브라우저 내 관리화면을 이용해 작성될 수 있다.
도 8a 및 도 8b는 본 발명의 다양한 실시예에 따른 웹푸시 제공 서버의 동작을 설명하기 위한 도면이다.
본 발명의 다양한 실시예에서 도 8a는 웹푸시 제공 서버(예컨대, 도 4의 웹푸시 제공 서버 405, 도 5의 웹푸시 제공 서버 505, 도 6의 웹푸시 제공 서버 605)의 푸시 서비스 등록 동작을 설명하기 위한 도면이고, 도 8b는 웹푸시 제공 서버의 푸시 서비스 제공 동작을 설명하기 위한 도면이다.
본 발명의 다양한 실시예에 따른, 도 8a를 참조하면, 웹푸시 제공 서버는 801동작에서 화이트리스트를 업데이트할 수 있다. 예컨대, 웹푸시 제공 서버는 웹푸시 서비스를 신청한 웹사이트를 화이트리스트에 등록할 수 있다. 웹푸시 제공 서버는 803동작에서 상기 업데이트된 화이트리스트를 전자 장치(예: 도 6의 웹푸시 수신 전자 장치 601)에 전송할 수 있다. 예컨대, 상기 웹푸시 제공 서버는 업데이트된 화이트리스트 전체 또는 상기 화이트리스트에 추가/변경된 웹사이트만을 전자 장치(예컨대, 도 4의 전자 장치 401, 도 5의 전자 장치 501, 도 6의 전자 장치 601)에 전송할 수 있다.
웹푸시 제공 서버는 805동작에서 전자 장치로부터 서비스워커 요청 신호를 수신하면, 807동작에서 전자 장치에 서비스워커를 전송할 수 있다. 웹푸시 제공 서버는809동작에서 전자 장치로부터 장치 ID 요청을 수신하면, 811동작에서 상기 전자 장치에 대한 ID를 생성하여 상기 전자 장치에 전송할 수 있다.
본 발명의 다양한 실시예에서 전술한 805동작 및 807동작은 생략될 수 있다. 예컨대, 상기 서비스워커가 전자 장치 웹 브라우저 내에 저장되어 있는 경우 전술한 805동작 및 807동작은 생략될 수 있다.
본 발명의 다양한 실시예에 따른, 도 8b를 참조하면, 웹푸시 제공 서버는 821동작에서 웹사이트(예컨대, 도 4의 웹사이트 403, 도 5의 웹사이트 503, 도 6의 웹사이트 603) 관리자의 전자 장치(예컨대, 도 5의 웹푸시 전송 전자 장치 502, 도 6의 웹푸시 전송 전자 장치 602)로부터 푸시 메시지를 수신할 수 있다. 웹푸시 제공 서버는 823동작에서 푸시 API를 호출하여 상기 수신한 푸시 메시지를 푸시 서버(예컨대, 도 4의 푸시 서버 407, 도 5의 푸시 서버 507, 도 6의 푸시 서버 607)에 전송할 수 있다.
도 9a 내지 도 9e는 본 발명의 다양한 실시예에 따른 전자 장치의 푸시 메시지 수신 동작을 설명하기 위한 도면이다.
도 9a를 참조하면, 전자 장치(예컨대, 도 4의 전자 장치 401, 도 5의 전자 장치 501, 도 6의 웹푸시 수신 전자 장치 601)는 901동작에서 화이트리스트를 수신할 수 있다. 예컨대, 전자 장치는 웹푸시 제공 서버(예컨대, 도 4의 웹푸시 제공 서버405, 도 5의 웹푸시 제공 서버 505, 도 6의 웹푸시 제공 서버 605)로부터 화이트리스트 전체를 수신하거나, 또는 일부(예컨대, 추가/변경된 웹사이트)만을 수신하여 업데이트할 수 있다. 이에 관하여 후술하는 도 9b 및 도 9c를 참조하여 상세히 설명하도록 한다.
전자 장치는 903동작에서 웹 브라우저를 실행하여 특정 웹사이트 화면을 표시할 수 있다. 전자 장치는 905동작에서 화이트리스트에 상기 특정 웹사이트가 포함되어 있는지 여부를 결정할 수 있다. 상기 화이트리스트에 상기 특정 웹사이트가 포함되어 있으면, 전자 장치는 907동작에서 웹푸시 제공 서버(예컨대, 도 4의 웹푸시 제공 서버 405, 도 5의 웹푸시 제공 서버 505, 도 6의 웹푸시 제공 서버 605)에 서비스워커를 요청할 수 있다. 전자 장치는 909동작에서 웹푸시 제공 서버로부터 서비스워커를 수신하여 설치할 수 있다.
상기 서비스워커를 설치한 후, 전자 장치는 911동작에서 상기 웹사이트의 푸시 서비스 수신 여부를 결정할 수 있다. 예컨대, 서비스워커가 설치되면, 전자 장치는 상기 웹사이트의 푸시 서비스 수신 여부에 대한 팝업창을 표시할 수 있다. 상기 팝업창을 통해 상기 웹사이트로부터 푸시 서비스를 수신하기 위한 입력을 수신할 수 있도록 구성될 수 있다. 전자 장치는 상기 입력에 기반하여 상기 웹사이트로부터 푸시 서비스의 수신 여부를 결정할 수 있다. 또는, 서비스워커가 설치되면, 전자 장치는 상기 웹사이트의 푸시 서비스 수신 여부에 대한 푸시 서비스 아이콘을 표시할 수 있다. 상기 푸시 서비스 아이콘은 토글 기능을 가질 수 있으며, 상기 푸시 서비스 아이콘을 선택함에 따라 온(on)/오프(off)로 제어되어 푸시 서비스를 수신하거나 또는 상기 푸시 서비스 수신을 해제할 수 있다.
본 발명의 다양한 실시예에서 상기 909동작에서 서비스워커를 설치한 후 911동작에서 특정 웹사이트의 푸시 서비스 수신 여부를 결정하는 동작을 수행하는 것으로 설명하였지만, 이에 한정하는 것은 아니며, 전자 장치는 911동작의 특정 웹사이트의 푸시 서비스 수신 여부를 결정한 후 909동작의 서비스워커를 설치할 수 있다. 예컨대, 화이트리스트에 상기 특정 웹사이트가 포함되어 있으면, 전자 장치는 상기 특정 웹사이트의 푸시 서비스 수신 여부에 대한 팝업창 또는 푸시 서비스 아이콘을 표시할 수 있다. 상기 팝업창 또는 푸시 서비스 아이콘을 통해 상기 웹사이트로부터 푸시 서비스를 수신하기 위한 입력이 감지되면, 전자 장치는 푸시 서비스를 수신하는 것으로 결정하고, 웹푸시 제공 서버에 서비스워커를 요청할 수 있다. 전자 장치는 웹푸시 제공 서버로부터 서비스워커를 수신하여 설치할 수 있다.
일 실시예에 따르면, 상기 911동작에서 상기 웹사이트의 푸시 메시지를 수신하는 것으로 결정되면, 전자 장치는 상기 전자 장치의 홈화면에 웹사이트의 바로가기 아이콘을 생성할 수 있다. 전자 장치는 913동작에서 웹푸시 제공 서버에 상기 전자 장치의 ID 요청에 응답하여 상기 웹푸시 제공 서버로부터 생성된 전자 장치의 ID를 수신할 수 있다. 전자 장치는 915동작에서 상기 전자 장치의 서비스워커를 통해 푸시 서버(예: 도 4의 푸시 서버 407, 도 5의 푸시 서버 507, 도 6의 푸시 서버607)로부터 상기 전자 장치의 ID에 대응하는 푸시 플랫폼으로 변경된 푸시 메시지를 수신하여 표시할 수 있다.
본 발명의 다양한 실시예에서 상기 905동작에서 화이트리스트에 특정 웹사이트가 포함되어 있지 않는 것으로 결정되거나, 상기 911동작에서 웹사이트의 푸시 서비스를 수신하지 않는 경우, 전자 장치는 푸시 서비스 수신하는 동작을 종료할 수 있다.
본 발명의 다양한 실시예에 따른, 도 9b 및 도 9c는 전술한 도 9a의 901동작에서 화이트리스트를 수신하는 동작을 설명한 도면이다.
도 9b를 참조하면, 전자 장치는 921동작에서 웹푸시 제공 서버에 화이트리스트를 요청할 수 있다. 이에 응답하여 전자 장치는 923동작에서 웹푸시 제공 서버로부터 화이트리스트를 수신하고, 925동작에서 상기 수신된 화이트리스트를 메모리에 저장할 수 있다.
본 발명의 다양한 실시예에 따른, 도 9c를 참조하면, 전자 장치는 931동작에서 웹푸시 제공 서버로부터 추가/변경된 화이트리스트를 수신할 수 있다. 예를 들어, 전자 장치는 이전에 웹푸시 제공 서버로부터 수신한 화이트리스트에서 추가/변경된 웹사이트만을 수신할 수 있다. 전자 장치는 933동작에서 수신된 추가/변경된 화이트리스트를 기반으로 메모리에 저장된 화이트리스트를 업데이트할 수 있다.
도 9d는 전술한 웹 브라우저를 통해 접속된 웹사이트가 화이트리스트에 포함되는 경우 웹푸시 제공 서버에 서비스워커를 요청 및 수신하는 동작을 설명하기 위한 도면이다.
도 9d를 참조하면, 전자 장치 951(예컨대, 도 4의 전자 장치 401, 도 5의 전자 장치 501, 도 6의 웹푸시 수신 전자 장치 601)은 웹 브라우저를 실행하여 웹사이트 953(예컨대, 도 4의 웹사이트 403, 도 5의 웹사이트 503, 도 6의 웹사이트 603)으로부터 예컨대, https://example.com의 페이지를 수신 941하여 표시할 수 있다. 전자 장치 951은 상기 웹사이트 https://example.com이 메모리(예컨대, 도 4의 메모리 420)에 저장된 화이트리스트에 포함되는지 여부를 결정할 수 있다. 상기 웹사이트 https://example.com이 화이트리스트에 포함되는 경우, 전자 장치 951은 웹푸시 제공 서버 955(예컨대, 도 4의 웹푸시 제공 서버405, 도 5의 웹푸시 제공 서버 505, 도 6의 웹푸시 제공 서버 605)에 웹푸시 서비스에 필요한 서비스워커(sw.js)를 요청 943할 수 있다. 상기 서비스워커 요청에 응답하여 웹푸시 제공 서버 955는 서비스워커를 상기 전자 장치 951에 전송 945할 수 있다. 전자 장치 951은 웹푸시 제공 서버 955로부터 수신한 서비스워커를 설치 949할 수 있다.
도 9e는 전자 장치가 특정 웹사이트의 푸시 서비스 수신 여부를 결정하는 인터페이스에 관한 도면이다.
일 실시예에 따르면, 전자 장치는 특정 웹사이트가 화이트리스트에 포함되는 것으로 결정됨에 따라 서비스워커를 설치하면 도 9e에 도시된 바와 같이 푸시 서비스 아이콘 961을 웹 브라우저의 주소 표시줄의 일부 영역에 표시할 수 있다. 상기 푸시 서비스 아이콘 961을 선택하는 입력이 감지됨에 따라 상기 푸시 서비스 아이콘 961이 활성화되면, 전자 장치는 웹사이트의 푸시 서비스를 수신하는 것으로 결정할 수 있다. 상기 푸시 서비스 아이콘 961이 활성화된 상태에서 다시 선택 입력이 감지되는 경우, 전자 장치는 푸시 메시지 수신을 해제하는 것으로 결정할 수 있다. 예컨대, 상기 푸시 서비스 아이콘 961은 토글 기능을 가질 수 있으며, 상기 푸시 서비스 아이콘 961을 선택함에 따라 온(on)/오프(off)로 제어되어 푸시 메시지를 수신하거나 또는 상기 푸시 메시지 수신을 해제할 수 있다. 상기 푸시 서비스 아이콘 961은 웹 브라우저 주소 표시줄의 일부 영역에 표시되는 것으로 설명하였지만, 이에 한정하는 것은 아니며 상기 푸시 서비스 아이콘 961은 표시부(예: 도 4의 431)의 적어도 일부 영역에 표시될 수 있다.
도 10a 및 도 10b는 본 발명의 다양한 실시예에 따른 전자 장치의 푸시 서비스 수신 동작을 설명하기 위한 도면이다.
상기 전자 장치는 도 1의 전자 장치 101, 도 4의 전자 장치 401, 도 5의 전자 장치 501, 도 6의 웹푸시 전송 전자 장치 602 또는 도 6의 웹푸시 수신 전자 장치 601과 동일 또는 유사할 수 있다.
도 10a를 참조하면, 전자 장치는 1001동작에서 화이트리스트를 수신할 수 있다. 예컨대, 전자 장치는 웹푸시 제공 서버(예컨대, 도 4의 웹푸시 제공 서버405, 도 5의 웹푸시 제공 서버 505, 도 6의 웹푸시 제공 서버 605)로부터 화이트리스트 전체를 수신하거나, 또는 일부(예컨대, 추가/변경된 웹사이트)만을 수신하여 업데이트할 수 있다.
전자 장치는 1003동작에서 웹 브라우저를 실행하여 특정 웹사이트 화면을 표시할 수 있다. 전자 장치는 1005동작에서 화이트리스트에 상기 특정 웹사이트가 포함되어 있는지 여부를 결정할 수 있다. 상기 화이트리스트에 상기 특정 웹사이트가 포함되어 있으면, 전자 장치는 1007동작에서 상기 전자 장치의 웹 브라우저 내 서비스워커가 존재하는지 탐색할 수 있다. 상기 웹 브라우저 내 서비스워커가 존재하는 경우, 전자 장치는 1009동작에서 상기 서비스워커를 설치할 수 있다.
상기 서비스워커를 설치한 후, 전자 장치는 1011동작에서 웹사이트의 푸시 서비스 수신 여부를 결정할 수 있다. 상기 1011동작은 전술한 도 9a의 911동작과 유사 또는 동일하므로 상세한 설명은 생략하도록 한다.
본 발명의 다양한 실시예에 따르면, 상기 1007 동작 및 1009동작에서 웹 브라우저 내 서비스워커가 존재하는지 탐색하여 상기 웹 브라우저 내 서비스워커가 존재하는 경우 서비스워커를 설치할 수 있다. 전자 장치는 1011동작에서 특정 웹사이트의 푸시 서비스 수신 여부를 결정할 수 있다. 또는, 전자 장치는 1011동작의 특정 웹사이트의 푸시 서비스 수신 여부를 결정한 후 1007동작 및 1009동작에서 웹 브라우저 내 서비스워커가 존재하는지 탐색하여 상기 웹 브라우저 내 서비스워커가 존재하는 경우 서비스워커를 설치할 수 있다.
본 발명의 다양한 실시예에 따르면, 상기 웹사이트의 푸시 서비스를 수신하는 것으로 결정되면, 전자 장치는 상기 전자 장치의 홈화면에 웹사이트의 바로가기 아이콘을 생성할 수 있다. 전자 장치는 1013동작에서 웹푸시 제공 서버에 상기 전자 장치의 ID 요청에 응답하여 상기 웹푸시 제공 서버로부터 생성된 전자 장치의 ID를 수신할 수 있다. 전자 장치는 1015동작에서 서비스워커를 통해 푸시 서버로부터 상기 전자 장치의 ID에 대응하는 푸시 플랫폼으로 변경된 푸시 메시지를 수신하여 표시할 수 있다.
본 발명의 다양한 실시예에서 상기 1005동작에서 화이트리스트에 특정 웹사이트가 포함되어 있지 않는 것으로 결정되거나, 상기 1011동작에서 웹사이트의 푸시 서비스를 수신하지 않는 경우, 전자 장치는 푸시 서비스 수신하는 동작을 종료할 수 있다.
도 10b는 웹 브라우저를 통해 접속된 웹사이트가 화이트리스트에 포함되는 경우 전자 장치 내 브라우저에 저장된 서비스워커를 설치하는 동작을 설명하기 위한 도면이다.
도 10b를 참조하면, 전자 장치 1031은 웹 브라우저를 실행하여 웹사이트 1033(예컨대, 도 4의 웹사이트 403, 도 5의 웹사이트 503, 도 6의 웹사이트 603)으로부터 예컨대, https://example.com의 페이지를 수신 1021하여 표시할 수 있다. 전자 장치 1031은 상기 웹사이트 https://example.com이 화이트리스트에 포함되는지 여부를 결정할 수 있다. 상기 웹사이트 https://example.com이 화이트리스트에 포함되는 경우, 전자 장치 1031은 브라우저 내 저장된 웹푸시 서비스에 필요한 서비스워커 1023을 설치 1025할 수 있다.
도 11은 본 발명의 다양한 실시예에 따른 전자 장치의 웹 브라우저를 구성하는 구성요소를 설명하기 위한 도면이다. 상기 전자 장치는 도 1의 전자 장치 101, 도 4의 전자 장치 401, 도 5의 전자 장치 501, 도 6의 웹푸시 전송 전자 장치 602 또는 도 6의 웹푸시 수신 전자 장치 601과 동일 또는 유사할 수 있다.
도 11을 참조하면, 본 발명의 다양한 실시예에서 웹 브라우저는 사용자 인터페이스 1101, 브라우저 엔진 1103, 렌더링 엔진 1105, 통신 1107, 자바스크립트 해석기 1109, UI 백엔드 1111, 및 자료저장소 1113을 포함할 수 있다.
상기 사용자 인터페이스 1101은 주소 표시줄, 이전/다음 버튼, 북마크 메뉴 등 요청한 페이지를 보여주는 창을 제외한 나머지 UI를 포함할 수 있다.
본 발명의 다양한 실시예에서 전자 장치가 푸시 서비스 수신에 동의하는 동작에서 상기 사용자 인터페이스 1101은 브라우저 엔진 1103을 통해 사용자가 웹 브라우저를 통해 요청한 웹사이트가 화이트리스트에 포함되는지 여부를 결정하고, 상기 웹사이트가 화이트리스트에 포함되는 경우 푸시 서비스 수신 여부에 대한 푸시 서비스 아이콘 또는 팝업창을 표시할 수 있다.
본 발명의 다양한 실시예에서 전자 장치가 푸시 서비스를 수신하는 동작에서 상기 사용자 인터페이스 1101은 푸시 서비스 알림을 위한 팝업창을 표시할 수 있다. 상기 팝업창은 제목, 또는 아이콘, 선택 시 이동할 수 있는 URL 중 적어도 하나를 포함할 수 있다. 또는 상기 사용자 인터페이스 1101은 푸시 서비스 알림을 위한 상태바에 상기 푸시 서비스 알림 아이콘을 표시할 수 있다.
상기 브라우저 엔진 1103은 사용자 인터페이스 1101과 렌더링 엔진 1105 간의 동작을 제어할 수 있다. 상기 브라우저 엔진 1103은 자료저장소 1115에 저장된 정보를 로딩하여 웹 브라우저 기능(예컨대, 캐시, 쿠키)을 수행할 수 있다.
본 발명의 다양한 실시예에서 전자 장치가 푸시 서비스를 수신하는 것으로 결정하는 동작에서 상기 브라우저 엔진 1103은 푸시 서비스에 필요한 서비스워커를 웹푸시 제공 서버에 요청하여 설치할 수 있다. 사용자가 웹 브라우저를 통해 요청한 웹사이트가 화이트리스트에 포함되는지 확인하고, 상기 웹사이트가 화이트리스트에 포함되는 경우 상기 서비스워커를 설치하여 자료저장소 1113에 저장할 수 있다. 상기 브라우저 엔진 1103은 상기 웹사이트가 화이트리스트에 포함되는 경우 사용자 인터페이스 1101에 푸시 서비스 수신 여부에 대한 푸시 서비스 아이콘 또는 팝업창을 표시할 수 있다.
본 발명의 다양한 실시예에서 전자 장치가 푸시 서비스를 수신하는 동작에서 상기 브라우저 엔진 1103은 통신 1107을 통해 전송된 푸시 메시지를 수신하여 자료저장소 1113에 저장되어 있는 서비스워커를 재구동(fetch)할 수 있다. 상기 브라우저 엔진 1103은 상기 서비스워커를 요청하는 경우 푸시 서비스를 수신에 동의하는 동작에서 자료저장소 1113에 저장된 서비스워커를 반환할 수 있다. 상기 서비스워커는 푸시 메시지 알림을 위한 팝업창을 생성하는 스크립트를 포함할 수 있다.
상기 렌더링 엔진 1105는 요청한 컨텐츠를 표시할 수 있다. 예컨대, HTML을 요청하면, 상기 렌더링 엔진 1105는 상기 HTML과 CSS를 파싱하여 화면에 표시할 수 있다.
상기 통신 1107은 HTTP 요청과 같은 네트워크 호출을 수행하고, 렌더링 엔진 1105와 송수신할 수 있다. 이러한 통신은 플랫폼 독립적인 인터페이스이며, 각 플랫폼 하부에서 실행될 수 있다.
본 발명의 다양한 실시예에서 푸시 서비스를 수신에 동의하는 동작에서 서비스워커를 웹푸시 제공 서버를 통해 수신하여 설치한 경우, 상기 통신 1107은 브라우저 엔진 1103에서 인증된 웹사이트(예컨대, 푸시 서비스를 신청한 웹사이트가 웹푸시 제공 서버에 등록된 경우)에 대한 화이트리스트와 자료저장소 1113 내 화이트리스트를 업데이트하기 위해 웹푸시 제공 서버와 통신할 수 있다. 상기 통신 1107은 전자 장치로부터 웹사이트의 푸시 서비스를 수신하는 입력을 감지하면, 상기 웹푸시 제공 서버로부터 전자 장치의 ID를 수신하기 위해 통신할 수 있다.
본 발명의 다양한 실시예에서 푸시 서비스를 수신하는 동작에서 상기 통신 1107은 웹사이트가 전송한 푸시 메시지 페이로드(payload)를 수신하여 브라우저 엔진 1103으로 전송할 수 있다.
상기 UI백엔드 1109는 콤보 박스와 같은 플랫폼에서 명시하지 않은 일반적인 인터페이스로, 운영체제(OS) 사용자 인터페이스 체계를 사용할 수 있다.
상기 자바스크립트 해석기 1111은 자바스크립트 코드를 해석하고 실행할 수 있다.
상기 자료저장소 1113은 쿠키, 캐시, 또는 데이터 등을 저장할 수 있다.
본 발명의 다양한 실시예에서 전자 장치가 푸시 서비스를 수신에 동의하는 동작에서 자료저장소 1113은 푸시 서비스를 신청한 웹사이트를 화이트리스트에 추가하여 저장할 수 있다. 자료저장소 1113은 상기 자료저장소 1113 내 저장된 화이트리스트를 주기적으로 업데이트할 수 있다.
이상에서는 본 발명의 실시예에 따른 웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 장치에 대하여 본 명세서 및 도면을 통해 바람직한 실시예들에 대하여 설명하였으며, 비록 특정 용어들이 사용되었으나 이는 단지 본 발명의 기술 내용을 쉽게 설명하고 발명의 이해를 돕기 위해 일반적인 의미에서 사용된 것일 뿐, 본 발명이 전술한 실시예에 한정되는 것은 아니다. 즉, 본 발명의 기술적 사상에 바탕을 둔 다양한 실시예가 가능함은 본 발명이 속하는 기술 분야에서 통상의 지식을 가진 자에게 자명한 것이다.
410: 통신부
420: 메모리
430: 터치스크린
440: 프로세서

Claims (20)

  1. 전자 장치에 있어서,
    유무선 통신을 형성하는 통신부;
    표시부;
    상기 표시부와 별도로 또는 결합된 입력부;
    적어도 부분적으로 웹 브라우징을 위해 구성된 소프트웨어 프로그램을 저장하는 비 휘발성 메모리; 및
    상기 통신부, 상기 표시부, 상기 입력부, 및 상기 비 휘발성 메모리와 전기적으로 연결된 프로세서를 포함하고,
    상기 프로세서와 전기적으로 연결된 메모리,
    상기 비 휘발성 메모리는 실행 시에, 상기 프로세서가,
    상기 소프트웨어 프로그램의 사용자 인터페이스를 상기 표시부에 표시하고,
    상기 입력부를 통한 제1 사용자 입력에 응답하여 상기 통신부를 통해 사용자 구독에 따른 푸시 서비스와 관련된 제1 서버로부터 제1 웹페이지를 수신하고,
    상기 제1 웹페이지와 상기 사용자 인터페이스에 푸시 서비스를 위한 인디케이터를 표시하고,
    상기 입력부를 통해 상기 푸시 서비스 구독을 위한 제2 사용자 입력을 수신하고,
    상기 통신부를 통해 상기 푸시 서비스 구독을 나타내는 신호를 상기 푸시 서비스를 제공하는 복수의 웹사이트를 관리하는 상기 제1 서버와 독립적인 제2 서버에 전송하는 인스트럭션들을 저장하는 전자 장치.
  2. 제 1 항에 있어서,
    상기 인스트럭션들은, 상기 프로세서가,
    상기 통신부를 통해 상기 제2 서버와 독립적인 제3 서버로부터 상기 푸시 서비스와 관련된 데이터를 수신하고,
    상기 수신된 데이터에 응답하여 상기 표시부를 통해 푸시 서비스 알림을 제공하도록 하는 전자 장치.
  3. 제 1 항에 있어서,
    상기 인스트럭션들은, 상기 프로세서가,
    상기 제2 서버의 정보에 적어도 일부 기반하여 상기 제1 서버가 푸시 서비스를 제공하는지 여부를 결정하고, 상기 제1 서버가 푸시 서비스를 제공하는지 여부에 대한 결정에 적어도 일부 기반하여 인디케이터를 표시하도록 하는 전자 장치.
  4. 제 3 항에 있어서,
    상기 정보는 상기 푸시 서비스를 제공하는 복수의 웹사이트를 포함하는 리스트인 전자 장치.
  5. 제 4 항에 있어서,
    상기 인스트럭션들은, 상기 프로세서가,
    상기 제1 서버가 푸시 서비스를 제공하면 푸시 서비스에 필요한 서비스워커를 상기 제2 서버에 요청하고, 상기 제2 서버로부터 상기 서비스워커를 수신하여 설치하도록 하는 전자 장치.
  6. 제 4 항에 있어서,
    상기 인스트럭션들은, 상기 프로세서가,
    상기 제1 서버가 푸시 서비스를 제공하면 푸시 서비스에 필요한 서비스워커가 상기 전자 장치 내에 저장되어 있는지 여부를 확인하고, 확인 결과 상기 전자 장치 내에 상기 서비스워커가 저장되어 있는 경우 상기 전자 장치의 브라우저 엔진을 통해 설치하도록 하는 전자 장치.
  7. 제 5 항 또는 제 6 항에 있어서,
    상기 인스트럭션들은, 상기 프로세서가,
    상기 서비스워커가 설치된 후 상기 푸시 서비스를 위한 인디케이터에서 상기 제2 사용자 입력을 수신하면 상기 전자 장치의 ID를 상기 제2 서버로 요청하고, 상기 제2 서버로부터 상기 전자 장치의 ID를 수신하도록 하는 전자 장치.
  8. 제 7 항에 있어서,
    상기 인스트럭션들은, 상기 프로세서가,
    상기 전자 장치의 ID를 상기 제1 서버 또는 상기 제2 서버에 전송하도록하는 전자 장치.
  9. 제 8 항에 있어서,
    상기 인스트럭션들은, 상기 프로세서가,
    상기 서비스워커를 통해 상기 제3 서버로부터 상기 전자 장치의 ID에 대응하는 푸시 메시지를 수신하도록 하는 전자 장치.
  10. 제 7 항에 있어서,
    상기 푸시 서비스를 위한 인디케이터는 상기 푸시 서비스 수신 여부에 대한 팝업창 또는 푸시 서비스 아이콘을 포함하는 전자 장치.
  11. 전자 장치의 푸시 서비스 제공 방법에 있어서,
    소프트웨어 프로그램의 사용자 인터페이스를 표시하는 동작;
    상기 사용자 인터페이스에서 제1 사용자 입력이 감지되면, 사용자 구독에 따른 푸시 서비스와 관련된 제1 서버로부터 제1 웹페이지를 수신하는 동작;
    상기 제1 웹페이지와 푸시 서비스를 위한 인디케이터를 표시하는 동작; 및
    상기 푸시 서비스 구독을 위한 제2 사용자 입력이 감지되면, 상기 푸시 서비스 구독을 나타내는 신호를 푸시 서비스를 제공하는 복수의 웹사이트를 관리하는 상기 제1 서버와 독립적인 제2 서버에 전송하는 동작;을 포함하는 푸시 서비스 제공 방법.
  12. 제 11 항에 있어서,
    상기 제2 서버와 독립적인 제3 서버로부터 상기 푸시 서비스와 관련된 데이터를 수신하는 동작; 및
    상기 수신된 데이터에 응답하여 푸시 서비스 알림을 출력하는 동작;을 더 포함하는 푸시 서비스 제공 방법.
  13. 제 11 항에 있어서,
    상기 푸시 서비스를 위한 인디케이터를 표시하는 동작은,
    상기 제2 서버의 정보에 적어도 일부 기반하여 상기 제1 서버가 푸시 서비스를 제공하는지 여부를 결정하는 동작을 포함하는 푸시 서비스 제공 방법.
  14. 제 13 항에 있어서,
    상기 정보는 상기 푸시 서비스를 제공하는 복수의 웹사이트를 포함하는 리스트인 푸시 서비스 제공 방법.
  15. 제 14 항에 있어서,
    상기 제1 서버가 푸시 서비스를 제공하면, 푸시 서비스에 필요한 서비스워커를 상기 제2 서버에 요청하는 동작; 및
    상기 제2 서버로부터 상기 서비스워커를 수신하여 설치하는 동작을 더 포함하는 푸시 서비스 제공 방법.
  16. 제 14 항에 있어서,
    상기 제1 서버가 푸시 서비스를 제공하면, 푸시 서비스에 필요한 서비스워커가 상기 전자 장치 내에 저장되어 있는지 여부를 확인하는 동작; 및
    확인 결과, 상기 전자 장치 내에 상기 서비스워커가 저장되어 있는 경우 상기 전자 장치의 브라우저 엔진을 통해 상기 서비스워커를 설치하는 동작을 더 포함하는 푸시 서비스 제공 방법.
  17. 제 15 항 또는 제 16 항에 있어서,
    상기 설치하는 동작에,
    상기 푸시 서비스를 위한 인디케이터에서 상기 제2사용자 입력이 감지되는지 여부를 결정하는 동작;
    상기 인디케이터에서 상기 제2 사용자 입력이 감지되면, 상기 전자 장치의 ID를 상기 제2 서버로 요청하는 동작; 및
    상기 제2 서버로부터 상기 전자 장치의 ID를 수신하는 동작을 더 포함하는 푸시 서비스 제공 방법.
  18. 제 17 항에 있어서,
    상기 전자 장치의 ID를 수신하는 동작에,
    상기 전자 장치의 ID를 상기 제1 서버 또는 상기 제2 서버에 전송하는 동작을 더 포함하는 푸시 서비스 제공 방법.
  19. 제 18 항에 있어서,
    상기 서비스워커를 통해 상기 제3 서버로부터 상기 전자 장치의 ID에 대응하는 푸시 메시지를 수신하는 푸시 서비스 제공 방법.
  20. 제 17 항에 있어서,
    상기 푸시 서비스를 위한 인디케이터는 상기 푸시 서비스 수신 여부에 대한 팝업창 또는 푸시 서비스 아이콘을 포함하는 푸시 서비스 제공 방법.
KR1020150182735A 2015-12-21 2015-12-21 웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 전자 장치 KR102413396B1 (ko)

Priority Applications (3)

Application Number Priority Date Filing Date Title
KR1020150182735A KR102413396B1 (ko) 2015-12-21 2015-12-21 웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 전자 장치
PCT/KR2016/013121 WO2017111313A1 (ko) 2015-12-21 2016-11-15 웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 전자 장치
US16/061,100 US10997268B2 (en) 2015-12-21 2016-11-15 Method for providing push service using web push, and electronic device supporting same

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020150182735A KR102413396B1 (ko) 2015-12-21 2015-12-21 웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 전자 장치

Publications (2)

Publication Number Publication Date
KR20170073930A true KR20170073930A (ko) 2017-06-29
KR102413396B1 KR102413396B1 (ko) 2022-06-28

Family

ID=59090775

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020150182735A KR102413396B1 (ko) 2015-12-21 2015-12-21 웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 전자 장치

Country Status (3)

Country Link
US (1) US10997268B2 (ko)
KR (1) KR102413396B1 (ko)
WO (1) WO2017111313A1 (ko)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102483272B1 (ko) * 2022-06-15 2023-01-02 주식회사 플레어랩스 웹 푸시 서비스 서버 및 그 동작 방법

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11250492B2 (en) * 2016-03-22 2022-02-15 Paypal, Inc. Automatic population of data on an internet web page via a browser plugin
US10114999B1 (en) 2016-12-02 2018-10-30 Koupon Media, Inc. Using dynamic occlusion to protect against capturing barcodes for fraudulent use on mobile devices
US11089123B2 (en) * 2018-05-15 2021-08-10 Microsoft Technology Licensing, Llc Service worker push violation enforcement
AU2022303166A1 (en) * 2021-06-29 2024-02-01 Ryan BARES User interface control server and method for remote control management of marine dock electric charging stations

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101229951B1 (ko) * 2012-11-07 2013-02-05 주식회사 씨앤피 통신망을 통한 푸시메시지 발송 방법
KR20140021324A (ko) * 2012-08-10 2014-02-20 네이버 주식회사 사용자 단말을 이용한 모바일 단말에서의 애플리케이션 설치 시스템, 장치, 방법 및 컴퓨터 판독 가능한 기록 매체
KR101448593B1 (ko) * 2013-01-15 2014-10-13 주식회사 네이블커뮤니케이션즈 웹 서비스 푸시 방법 및 이를 수행하는 웹서비스푸시서버 및 웹 서비스 제공 서버

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20130082937A (ko) 2011-12-23 2013-07-22 유영민 개발자의 어플리케이션으로 푸시 서비스를 제공하는 푸시 서비스 시스템 및 푸시 서비스 방법
KR101919949B1 (ko) 2012-10-08 2018-11-19 에스케이플래닛 주식회사 웹 애플리케이션을 위한 메시지 제공 시스템 및 방법
KR20140081150A (ko) 2012-12-21 2014-07-01 주식회사 쿨엔터 다중 웹사이트 접속용 웹푸시 어플리케이션
EP2899940B1 (en) * 2014-01-23 2020-06-03 Vodafone GmbH Connection method for secure connecting of a mobile device system to a network
US10334066B2 (en) * 2014-07-23 2019-06-25 Varian Medical Systems, Inc. Method and system applications for push notifications

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20140021324A (ko) * 2012-08-10 2014-02-20 네이버 주식회사 사용자 단말을 이용한 모바일 단말에서의 애플리케이션 설치 시스템, 장치, 방법 및 컴퓨터 판독 가능한 기록 매체
KR101229951B1 (ko) * 2012-11-07 2013-02-05 주식회사 씨앤피 통신망을 통한 푸시메시지 발송 방법
KR101448593B1 (ko) * 2013-01-15 2014-10-13 주식회사 네이블커뮤니케이션즈 웹 서비스 푸시 방법 및 이를 수행하는 웹서비스푸시서버 및 웹 서비스 제공 서버

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102483272B1 (ko) * 2022-06-15 2023-01-02 주식회사 플레어랩스 웹 푸시 서비스 서버 및 그 동작 방법

Also Published As

Publication number Publication date
KR102413396B1 (ko) 2022-06-28
US10997268B2 (en) 2021-05-04
US20180365255A1 (en) 2018-12-20
WO2017111313A1 (ko) 2017-06-29

Similar Documents

Publication Publication Date Title
KR102449533B1 (ko) 전자 장치 및 전자 장치에서 어플리케이션의 실행을 제어하는 방법
CN106354451B (zh) 用于操作电子设备的方法和电子设备
KR102296323B1 (ko) 전자 장치 및 전자 장치에서의 정보 처리 방법
KR20170096408A (ko) 어플리케이션을 표시하는 방법 및 이를 지원하는 전자 장치
KR102560635B1 (ko) 컨텐트 인식 장치 및 그 동작 방법
KR20180022021A (ko) 음성 인식 방법 및 이를 수행하는 전자 장치
EP3179388A1 (en) Web page operation method and electronic device for supporting the same
KR20170061473A (ko) 알림을 제공하기 위한 방법 및 그 전자 장치
KR20180080629A (ko) 전자 장치 및 전자 장치의 어플리케이션 실행 히스토리 표시 방법
KR102416549B1 (ko) 어플리케이션을 관리하는 방법 및 그를 위한 전자 장치
KR20160101600A (ko) 스크린 미러링 서비스 제공방법 및 장치
US10659933B2 (en) Electronic device and information processing system including the same
KR102458444B1 (ko) 전자 장치 및 그 동작 방법
KR20170059201A (ko) 전자 장치 및 전자 장치의 컨텐츠 출력 방법
CN108702806B (zh) 电子设备及用于其的操作方法
KR102413396B1 (ko) 웹푸시를 이용한 푸시 서비스 제공 방법 및 이를 지원하는 전자 장치
KR20180073188A (ko) 전자장치 및 이를 활용한 웹 페이지 표시 방법
KR20170100309A (ko) 음성 인식 제어를 제공하는 전자 장치 및 그 동작 방법
KR102471739B1 (ko) 전자 장치의 히스토리 정보 관리 장치 및 방법
KR102460274B1 (ko) 연락처 정보 제공 방법 및 장치
KR20160071694A (ko) 웹 애플리케이션 처리 방법, 장치, 및 기록 매체
KR20180046032A (ko) 전자 장치 및 그의 동작 방법
KR102323797B1 (ko) 전자 장치 및 그의 정보 공유 방법
KR102490673B1 (ko) 어플리케이션에 대한 부가 정보 제공 방법 및 이를 지원하는 전자 장치
KR20170119948A (ko) 전자 장치 및 그 제어 방법

Legal Events

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