KR102381436B1 - 웹과 관련된 데이터에서 아이템을 검출하기 위한 전자 장치 및 방법 - Google Patents

웹과 관련된 데이터에서 아이템을 검출하기 위한 전자 장치 및 방법 Download PDF

Info

Publication number
KR102381436B1
KR102381436B1 KR1020170032571A KR20170032571A KR102381436B1 KR 102381436 B1 KR102381436 B1 KR 102381436B1 KR 1020170032571 A KR1020170032571 A KR 1020170032571A KR 20170032571 A KR20170032571 A KR 20170032571A KR 102381436 B1 KR102381436 B1 KR 102381436B1
Authority
KR
South Korea
Prior art keywords
electronic device
information
item
transaction
web
Prior art date
Application number
KR1020170032571A
Other languages
English (en)
Other versions
KR20180105464A (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 KR1020170032571A priority Critical patent/KR102381436B1/ko
Priority to US15/901,232 priority patent/US20180268383A1/en
Publication of KR20180105464A publication Critical patent/KR20180105464A/ko
Application granted granted Critical
Publication of KR102381436B1 publication Critical patent/KR102381436B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/08Payment architectures
    • G06Q20/085Payment architectures involving remote charge determination or related payment systems
    • 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
    • G06Q30/00Commerce
    • G06Q30/02Marketing; Price estimation or determination; Fundraising
    • G06Q30/0241Advertisements
    • G06Q30/0251Targeted advertisements
    • G06Q30/0255Targeted advertisements based on user history
    • 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/953Querying, e.g. by the use of web search engines
    • G06F16/9535Search customisation based on user profiles and personalisation
    • 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
    • G06F16/986Document structures and storage, e.g. HTML extensions
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/20Natural language analysis
    • G06F40/205Parsing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N20/00Machine learning
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/08Payment architectures
    • G06Q20/12Payment architectures specially adapted for electronic shopping systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/30Payment architectures, schemes or protocols characterised by the use of specific devices or networks
    • G06Q20/306Payment architectures, schemes or protocols characterised by the use of specific devices or networks using TV related infrastructures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/30Payment architectures, schemes or protocols characterised by the use of specific devices or networks
    • G06Q20/308Payment architectures, schemes or protocols characterised by the use of specific devices or networks using the Internet of Things
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/30Payment architectures, schemes or protocols characterised by the use of specific devices or networks
    • G06Q20/32Payment architectures, schemes or protocols characterised by the use of specific devices or networks using wireless devices
    • G06Q20/321Payment architectures, schemes or protocols characterised by the use of specific devices or networks using wireless devices using wearable devices
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/30Payment architectures, schemes or protocols characterised by the use of specific devices or networks
    • G06Q20/32Payment architectures, schemes or protocols characterised by the use of specific devices or networks using wireless devices
    • G06Q20/325Payment architectures, schemes or protocols characterised by the use of specific devices or networks using wireless devices using wireless networks
    • G06Q20/3255Payment architectures, schemes or protocols characterised by the use of specific devices or networks using wireless devices using wireless networks using mobile network messaging services for payment, e.g. SMS
    • 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
    • G06Q30/00Commerce
    • G06Q30/02Marketing; Price estimation or determination; Fundraising
    • G06Q30/0241Advertisements
    • G06Q30/0251Targeted advertisements
    • G06Q30/0269Targeted advertisements based on user profile or attribute
    • G06Q30/0271Personalized advertisement
    • 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
    • G06Q30/00Commerce
    • G06Q30/06Buying, selling or leasing transactions
    • G06Q30/0601Electronic shopping [e-shopping]
    • G06Q30/0631Item recommendations

Landscapes

  • Engineering & Computer Science (AREA)
  • Business, Economics & Management (AREA)
  • Theoretical Computer Science (AREA)
  • Accounting & Taxation (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Strategic Management (AREA)
  • General Business, Economics & Management (AREA)
  • Finance (AREA)
  • Development Economics (AREA)
  • Databases & Information Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Economics (AREA)
  • Marketing (AREA)
  • Data Mining & Analysis (AREA)
  • Game Theory and Decision Science (AREA)
  • Entrepreneurship & Innovation (AREA)
  • Software Systems (AREA)
  • Artificial Intelligence (AREA)
  • Computing Systems (AREA)
  • Computational Linguistics (AREA)
  • General Health & Medical Sciences (AREA)
  • Audiology, Speech & Language Pathology (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Evolutionary Computation (AREA)
  • Medical Informatics (AREA)
  • Health & Medical Sciences (AREA)
  • Mathematical Physics (AREA)
  • User Interface Of Digital Computer (AREA)
  • Information Transfer Between Computers (AREA)
  • Telephone Function (AREA)

Abstract

다양한 실시 예들에 따른 전자 장치는, 명령어(instruction)들을 저장하는 메모리와, 무선 통신 회로(wireless communication circuit)와, 상기 메모리와 상기 무선 통신 회로와 전기적으로(electrically) 연결(coupled to)되고, 제1 외부 전자 장치로부터 제1 거래(transaction)가 완료됨(completed)을 나타내기 위한 제1 메시지를 수신하고, 상기 제1 메시지가 수신된 시점(timing)에 기반하여 결정되는 시구간(interval) 동안 상기 전자 장치가 접속하였던 복수의 웹 주소들 중에서 거래와 관련된 도메인 네임(domain name)을 포함하는 적어도 하나의 웹 주소를 결정하고, 상기 적어도 하나의 웹 주소와 관련된 적어도 하나의 웹 문서에 대한 데이터를 파싱하여 상기 제1 거래의 아이템(item)에 대한 정보를 결정하고, 상기 제1 거래의 아이템에 대한 정보를 상기 제1 외부 전자 장치 또는 제2 외부 전자 장치에게 송신하기 위해 상기 저장된 명령어들을 실행하도록 설정된 적어도 하나의 프로세서를 포함할 수 있다.

Description

웹과 관련된 데이터에서 아이템을 검출하기 위한 전자 장치 및 방법{ELECTRONIC DEVICE AND METHOD FOR DETECTING ITEM IN DATA ASSOCIATED WITH WEB}
다양한 실시 예들은 전자 장치(electronic device)에 관한 것으로, 보다 구체적으로 웹(web)과 관련된 데이터에서 아이템(item)을 검출하기 위한 전자 장치 및 그의 방법에 관한 것이다.
디지털 기술의 발달과 함께 이동통신 단말기, PDA(personal digital assistant), 전자 수첩, 스마트폰, 태블릿(tablet) PC(personal computer), 또는 웨어러블 디바이스(wearable device) 등과 같이 이동성(mobility)을 가지면서 통신 및/또는 정보 처리를 수행할 수 있는 전자 장치들이 보급되고 있다. 이러한 전자 장치는 음성 통화, 문자 메시지 송신 등과 같은 서비스 뿐 아니라 사진 촬영, 길 찾기, 또는 웹 인터페이스를 제공하고 있다.
한편, 통신 기술의 발달에 따라 현금(cash)보다 휴대가 간편한 신용카드 결제(payment) 등과 같은 전자 거래(electronic transactioin)가 활성화되고 있다. 즉, 사용자는 현금을 휴대하지 않더라도 신용카드 등을 이용하여 특정 아이템에 대한 댓가를 지불할 수 있다. 이러한 휴대 측면에서의 편의성으로 인하여, 결제 기능을 구비한 전자 장치가 개발되고 있다.
스마트폰 등과 같은 전자 장치를 이용하여 온라인(on-line) 쇼핑몰(shopping mall)을 이용하는 사용자가 증가함에 따라, 온라인 쇼핑몰에서 판매되는 상품(또는 아이템)에 대한 사용자의 구매를 유도하기 위한 다양한 마케팅(marketing) 수단들이 등장하고 있다. 예를 들면, 온라인 쇼핑몰은 상기 전자 장치에게 SMS(short message service) 메시지, MMS(multi-media message service) 메시지, 메신져(messenger)의 챗(chat), 또는 이메일(E-mail) 등을 통해 자신이 판매하는 아이템(item, 또는 상품(product))에 대한 정보를 제공한다. 하지만, 온라인 쇼핑몰 등으로부터 제공되는 정보는, 일반적으로 사용자의 선호도(preference)를 고려하지 않은 광고성 정보일 수 있다.
따라서, 다양한 실시 예들은, 전자 장치에서,사용자의 선호도 또는 특성을 반영한 아이템 정보를 제공하는 전자 장치 및 방법을 제공할 수 있다.
다양한 실시 예들에 따른 전자 장치(electronic device)는, 하우징과, 상기 하우징의 일부를 통해 노출된 터치스크린 디스플레이와, 무선 통신 회로와, 상기 디스플레이 및 상기 통신 회로와 전기적으로 연결된 프로세서와, 상기 프로세서와 연결되고, 상기 통신 회로를 통해 제1 외부 서버에 거래 관련(transaction-related) 정보를 송신하도록 설정된 제1 어플리케이션 프로그램을 저장하고, 상기 전자 장치가 상기 통신 회로를 통해 접속하는 웹 주소(web address)들에 대한 제1 정보를 적어도 임시적으로 저장하고, 상기 제1 어플리케이션 프로그램을 이용하여 거래를 실행하기 위한 사용자 입력을 상기 디스플레이를 통해 수신하고, 상기 사용자 입력을 수신하면, 상기 통신 회로를 통해 상기 제1 외부 서버에게 상기 거래와 관련된 제2 정보를 송신하고, 상기 제2 정보를 송신하는 동작 직전 또는 직후에 상기 웹 주소들 중 하나와 관련된 웹 문서에 접근하고, 상기 거래와 관련된 적어도 하나의 아이템을 획득하기 위해 상기 웹 문서를 파싱(parsing)하고, 상기 통신 회로를 이용하여 상기 전자 장치 외부에 상기 적어도 하나의 아이템 또는 상기 웹 주소들 중 하나 중 하나 또는 그 이상에 대한 제3 정보를 송신하기 위해 상기 프로세서를 야기하는 명령어들을 더 저장하는 메모리를 포함할 수 있다.
다양한 실시 예들에 따른 전자 장치는, 명령어(instruction)들을 저장하는 메모리와, 무선 통신 회로(wireless communication circuit)와, 상기 메모리와 상기 무선 통신 회로와 전기적으로(electrically) 연결(coupled to)되고, 제1 외부 전자 장치로부터 제1 거래(transaction)가 완료됨(completed)을 나타내기 위한 제1 메시지를 수신하고, 상기 제1 메시지가 수신된 시점(timing)에 기반하여 결정되는 시구간(interval) 동안 상기 전자 장치가 접속하였던 복수의 웹 주소들 중에서 거래와 관련된 도메인 네임(domain name)을 포함하는 적어도 하나의 웹 주소를 결정하고, 상기 적어도 하나의 웹 주소와 관련된 적어도 하나의 웹 문서에 대한 데이터를 파싱하여 상기 제1 거래의 아이템(item)에 대한 정보를 결정하고, 상기 제1 거래의 아이템에 대한 정보를 상기 제1 외부 전자 장치 또는 제2 외부 전자 장치에게 송신하기 위해 상기 저장된 명령어들을 실행하도록 설정된 적어도 하나의 프로세서를 포함할 수 있다.
다양한 실시 예들에 따른 서버(server)는, 적어도 하나의 프로세서와, 상기 적어도 하나의 프로세서와 연결되고, 복수의 전자 장치들로부터 거래와 관련된 복수의 아이템들에 대한 정보를 수신하고, 미리 결정된 주기 동안 상기 복수의 전자 장치들로부터 수신되는 정보에 제1 아이템이 포함되는 빈도가 기준치(reference value) 이상인 경우, 상기 제1 아이템에 대한 정보를 송신하기 위해 상기 적어도 하나의 프로세서를 야기하는 명령어들을 저장하는 메모리를 포함할 수 있고, 상기 복수의 아이템들에 대한 정보는, 상기 복수의 전자 장치들 각각에서 상기 복수의 아이템들 각각에 대한 거래가 완료되는 것에 기반하여 상기 복수의 전자 장치들 각각으로부터 송신될 수 있다.
다양한 실시 예들에 따른 전자 장치의 방법은, 상기 전자 장치가 상기 통신 회로를 통해 접속하는 웹 주소(web address)들에 대한 제1 정보를 적어도 임시적으로 저장하는 동작과, 상기 전자 장치의 메모리에 저장된 제1 어플리케이션 프로그램을 이용하여 거래를 실행하기 위한 사용자 입력을 상기 디스플레이를 통해 수신하는 동작과, 상기 사용자 입력을 수신하면, 상기 통신 회로를 통해 상기 제1 외부 서버에게 상기 거래와 관련된 제2 정보를 송신하는 동작과, 상기 제2 정보를 송신하는 동작 직전 또는 직후에 상기 웹 주소들 중 하나와 관련된 웹 문서에 접근하는 동작과, 상기 거래와 관련된 적어도 하나의 아이템을 획득하기 위해 상기 웹 문서를 파싱(parsing)하는 동작과, 상기 통신 회로를 이용하여 상기 전자 장치 외부에 상기 적어도 하나의 아이템 또는 상기 웹 주소들 중 하나 중 하나 또는 그 이상에 대한 제3 정보를 송신하는 동작을 포함할 수 있다.
다양한 실시 예들에 따른 전자 장치의 방법은, 제1 외부 전자 장치로부터 제1 거래(transaction)가 완료됨(completed)을 나타내기 위한 제1 메시지를 수신하는 동작과, 상기 제1 메시지가 수신된 시점(timing)에 기반하여 결정되는 시구간(interval) 동안 상기 전자 장치가 접속하였던 복수의 웹 주소들 중에서 거래와 관련된 도메인 네임(domain name)을 포함하는 적어도 하나의 웹 주소를 결정하는 동작과, 상기 적어도 하나의 웹 주소와 관련된 적어도 하나의 웹 문서에 대한 데이터를 파싱하여 상기 제1 거래의 아이템(item)에 대한 정보를 결정하는 동작과, 상기 제1 거래의 아이템에 대한 정보를 상기 제1 외부 전자 장치 또는 제2 외부 전자 장치에게 송신하는 동작을 포함할 수 있다.
다양한 실시 예들에 따른 서버의 방법은, 복수의 전자 장치들로부터 거래와 관련된 복수의 아이템들에 대한 정보를 수신하는 동작과, 미리 결정된 주기 동안 상기 복수의 전자 장치들로부터 수신되는 정보에 제1 아이템이 포함되는 빈도가 기준치(reference value) 이상인 경우, 상기 제1 아이템에 대한 정보를 송신하는 동작을 포함할 수 있고, 상기 복수의 아이템들에 대한 정보는, 상기 복수의 전자 장치들 각각에서 상기 복수의 아이템들 각각에 대한 거래가 완료되는 것에 기반하여 상기 복수의 전자 장치들 각각으로부터 송신될 수 있다.
도 1은 다양한 실시 예들에 따른 전자 장치를 포함하는 네트워크 환경의 예를 도시한다.
도 2는 다양한 실시 예들에 따른 전자 장치의 블록도이다.
도 3은 다양한 실시 예들에 따른 프로그램 모듈의 블록도이다.
도 4는 다양한 실시 예들에 따른 전자 장치의 기능적 구성의 예를 도시한다.
도 5는 다양한 실시 예들에 따라 거래를 수행하는 전자 장치를 포함하는 시스템의 예를 도시한다.
도 6은 다양한 실시 예들에 따른 전자 장치의 동작의 예를 도시한다.
도 7은, 다양한 실시 예들에 따라 웹 정보에 기반하여 아이템에 대한 정보를 결정하는 전자 장치의 동작의 예를 도시한다.
도 8는, 다양한 실시 예들에 따라 웹 정보에 기반하여 아이템에 대한 정보를 결정하는 전자 장치의 다른 동작의 예를 도시한다.
도 9는, 다양한 실시 예들에 따라 복수의 웹들의 주소들 중에서 거래와 관련된 웹 주소를 결정하는 방법을 설명하기 위한 개념도이다.
도 10은 다양한 실시 예들에 따라 웹 주소를 동작 별로 분류하는 방법을 설명하기 위한 개념도이다.
도 11은 다양한 실시 예들에 따라 파싱된 데이터에 포함된 공통 태그의 예를 설명하기 위한 개념도이다.
도 12는 다양한 실시 예들에 따라 참조 아이템에 대한 정보를 결정하는 전자 장치의 동작의 예를 도시한다.
도 13은 다양한 실시 예들에 따라 참조 아이템에 대한 정보를 결정하는 빅 데이터 서버와 전자 장치 사이의 신호 흐름의 예를 도시한다.
도 14는 다양한 실시 예들에 따라 참조 아이템에 대한 정보를 결정하는 빅 데이터 서버, 결제 서버, 및 전자 장치 사이의 신호 흐름의 예를 도시한다.
도 15는 다양한 실시 예들에 따라 알림 메시지를 수신하는 전자 장치, 빅 데이터 서버, 결제 서버 사이의 신호 흐름의 예를 도시한다.
도 16은 다양한 실시 예들에 따라 알림 메시지를 수신하는 전자 장치, 빅 데이터 서버, 결제 서버 사이의 신호 흐름의 다른 예를 도시한다.
도 17은 다양한 실시 예들에 따른 전자 장치에 표시된 알림 메시지의 화면(screen)의 예를 도시한다.
이하, 본 문서의 다양한 실시 예들이 첨부된 도면을 참조하여 기재된다. 실시 예 및 이에 사용된 용어들은 본 문서에 기재된 기술을 특정한 실시 형태에 대해 한정하려는 것이 아니며, 해당 실시 예의 다양한 변경, 균등물, 및/또는 대체물을 포함하는 것으로 이해되어야 한다. 도면의 설명과 관련하여, 유사한 구성요소에 대해서는 유사한 참조 부호가 사용될 수 있다. 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함할 수 있다. 본 문서에서, "A 또는 B" 또는 "A 및/또는 B 중 적어도 하나" 등의 표현은 함께 나열된 항목들의 모든 가능한 조합을 포함할 수 있다. "제 1," "제 2," "첫째," 또는 "둘째,"등의 표현들은 해당 구성요소들을, 순서 또는 중요도에 상관없이 수식할 수 있고, 한 구성요소를 다른 구성요소와 구분하기 위해 사용될 뿐 해당 구성요소들을 한정하지 않는다. 어떤(예: 제 1) 구성요소가 다른(예: 제 2) 구성요소에 "(기능적으로 또는 통신적으로) 연결되어" 있다거나 "접속되어" 있다고 언급된 때에는, 상기 어떤 구성요소가 상기 다른 구성요소에 직접적으로 연결되거나, 다른 구성요소(예: 제 3 구성요소)를 통하여 연결될 수 있다.
본 문서에서, "~하도록 구성된(또는 설정된)(configured to)"은 상황에 따라, 예를 들면, 하드웨어적 또는 소프트웨어적으로 "~에 적합한," "~하는 능력을 가지는," "~하도록 변경된," "~하도록 만들어진," "~를 할 수 있는," 또는 "~하도록 설계된"과 상호 호환적으로(interchangeably) 사용될 수 있다. 어떤 상황에서는, "~하도록 구성된 장치"라는 표현은, 그 장치가 다른 장치 또는 부품들과 함께 "~할 수 있는" 것을 의미할 수 있다. 예를 들면, 문구 "A, B, 및 C를 수행하도록 구성된(또는 설정된) 프로세서"는 해당 동작을 수행하기 위한 전용 프로세서(예: 임베디드 프로세서), 또는 메모리 장치에 저장된 하나 이상의 소프트웨어 프로그램들을 실행함으로써, 해당 동작들을 수행할 수 있는 범용 프로세서(예: CPU 또는 application processor)를 의미할 수 있다.
본 문서의 다양한 실시 예들에 따른 전자 장치는, 예를 들면, 스마트폰, 태블릿 PC, 이동 전화기, 영상 전화기, 전자책 리더기, 데스크탑 PC, 랩탑 PC, 넷북 컴퓨터, 워크스테이션, 서버, PDA(personal digital assistant), 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은 본 발명의 다양한 실시 예들에 따른 전자 장치를 포함하는 네트워크 환경(100)을 도시하는 도면이다.
도 1을 참조하면, 전자 장치(101)는 버스(110), 프로세서(120), 메모리(130), 입출력 인터페이스(150), 디스플레이(160), 및 통신 인터페이스(170)를 포함할 수 있다. 어떤 실시 예에서는, 전자 장치(101)는, 구성요소들 중 적어도 하나를 생략하거나 다른 구성요소를 추가적으로 구비할 수 있다.
버스(110)는 구성요소들(120-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) 등 중 적어도 하나를 사용하는 셀룰러 통신을 포함할 수 있다. 한 실시 예에 따르면, 무선 통신은, 예를 들면, 도 2의 element 164로 예신된 바와 같이, WiFi(wireless fidelity), LiFi(light 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)의 블록도이다.
전자 장치(201)는, 예를 들면, 도 1에 도시된 전자 장치(101)의 전체 또는 일부를 포함할 수 있다. 도 2를 참조하면, 전자 장치(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)의 구별 및 인증을 수행할 수 있다. 상기 통신 모듈(220)은 적어도 하나의 다른 전자 장치와의 D2D 신호를 송신하거나 수신할 수 있다. 상기 통신 모듈(220)은 실시 예들에 따라 적어도 하나의 송수신기(transceiver)로 지칭될 수 있다.
한 실시 예에 따르면, 셀룰러 모듈(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)과 하나 이상의 모듈로 구성될 수 있다. 한 실시 예에 따르면, 패널(262)은 사용자의 터치에 대한 압력의 세기를 측정할 수 있는 압력 센서(또는 포스 센서)를 포함할 수 있다. 압력 센서는 터치 패널(252)과 일체형으로 구현되거나, 또는 터치 패널(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, 201))에 관련된 자원을 제어하는 운영 체제 및/또는 운영 체제 상에서 구동되는 다양한 어플리케이션(예: 어플리케이션 프로그램(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))에 저장된 명령어로 구현될 수 있다. 상기 명령어가 프로세서(예: 도 1의 프로세서(120) 또는 도 2의 프로세서(210))에 의해 실행될 경우, 프로세서가 상기 명령어에 해당하는 기능을 수행할 수 있다.
컴퓨터로 판독 가능한 기록 매체는, 하드디스크, 플로피디스크, 마그네틱 매체(예: 자기테이프), 광기록 매체(예: CD-ROM, DVD, 자기-광 매체 (예: 플롭티컬 디스크), 내장 메모리 등을 포함할 수 있다. 명령어는 컴파일러에 의해 만들어지는 코드 또는 인터프리터에 의해 실행될 수 있는 코드를 포함할 수 있다. 다양한 실시 예들에 따른 모듈 또는 프로그램 모듈은 전술한 구성요소들 중 적어도 하나 이상을 포함하거나, 일부가 생략되거나, 또는 다른 구성요소를 더 포함할 수 있다. 다양한 실시 예들에 따른, 모듈, 프로그램 모듈 또는 다른 구성요소에 의해 수행되는 동작들은 순차적, 병렬적, 반복적 또는 휴리스틱하게 실행되거나, 적어도 일부 동작이 다른 순서로 실행되거나, 생략되거나, 또는 다른 동작이 추가될 수 있다.
도 4는 다양한 실시 예들에 따른 전자 장치의 기능적 구성의 예를 도시한다. 이러한 기능적 구성은 도 1에 도시된 전자 장치 101 또는 상기 전자 장치 101에 포함된 구성 요소(예: 프로세서 120, 메모리 130 등)에 포함될 수 있다.
도 4를 참조하면, 상기 전자 장치 101은 로깅 프레임워크(logging framework) 410, 아이템 결정부 450을 포함할 수 있다.
본 발명의 다양한 실시예에 따른, 로깅 프레임워크 410은, 상기 전자 장치 101 내의 이벤트 로그(event log)를 수집하고 관리할 수 있다. 일부 실시 예들에서, 상기 로깅 프레임워크 410은, 이벤트 검출부(event detector) 460, 로그 저장부(log repository) 465, 또는 POI(point of interest) 검출부(POI detector) 466을 포함할 수 있다.
일부 실시 예들에서, 상기 이벤트 검출부 460은, 상기 전자 장치 101 내에서 발생되는 이벤트와 관련된 정보를 수신할 수 있다. 상기 이벤트 관리부 460은, 메시지 이벤트 검출부(message event detector) 461, 결제 어플리케이션 이벤트 검출부(payment application event detector) 462, 또는 웹 이벤트 검출부(web event detector) 463, 위치 변경 이벤트 검출부(location changed event detector) 464를 포함할 수 있다.
본 발명의 다양한 실시예에 따른 메시지 이벤트 검출부 461은 상기 전자 장치 101에 수신되는 문자 메시지를 모니터링할 수 있다. 예를 들면, 상기 메시지 이벤트 검출부 461은 상기 전자 장치 101에 수신되는 SMS(short message service) 메시지, MMS(multi-media message service) 메시지, 메신져 어플리케이션에 대한 채팅(chat) 메시지, 푸쉬 메시지(push message) 등을 모니터링할 수 있다. 상기 메시지 이벤트 검출부 461은 상기 메시지에 포함된 데이터를 분석함으로써, 상기 메시지가 거래와 관련되는지 여부를 확인할 수 있다. 예를 들면, 상기 메시지 이벤트 검출부 461은 상기 메시지를 파싱함으로써, 상기 메시지에 포함된 데이터를 추출할 수 있다. 상기 메시지 이벤트 검출부 461은 상기 추출 또는 분석된 데이터에 대한 정보를 상기 로그 저장부 465에 제공할 수 있다. 상기 제공된 정보는 상기 로그 저장부 465에 저장될 수 있다.
본 발명의 다양한 실시예에 따른 결제 어플리케이션 이벤트 검출부 462는, 상기 전자 장치 101에 저장된 모바일 결제 어플리케이션을 모니터링할 수 있다. 일부 실시 예들에서, 상기 결제 어플리케이션 이벤트 검출부 462는 상기 모바일 결제 어플리케이션이 활성화되는 것에 기반하여, 상기 모바일 결제 어플리케이션의 상태를 모니터링할 수 있다. 예를 들면, 상기 결제 어플리케이션 이벤트 검출부 462는 상기 활성화된 모바일 결제 어플리케이션을 통해 다른 개체에게 송신되는 메시지를 모니터링할 수 있다. 다른 예를 들면, 상기 결제 어플리케이션 이벤트 검출부 462는 다른 개체로부터 상기 모바일 결제 어플리케이션을 통해 수신되는 메시지를 모니터링할 수 있다. 상기 결제 어플리케이션 이벤트 검출부 462는 상기 송신되거나 수신되는 메시지를 모니터링함으로써, 결제 이벤트의 발생 여부를 모니터링할 수 있다. 상기 결제 어플리케이션 이벤트 검출부 462은, 상기 모니터링된 정보를 분석함으로써, 상기 정보가 거래와 관련되는지 여부를 확인할 수 있다. 상기 결제 어플리케이션 이벤트 검출부 462는 상기 추출 또는 분석된 정보를 상기 로그 저장부 465에 제공할 수 있다. 상기 제공된 정보는 상기 로그 저장부 465에 저장될 수 있다.
본 발명의 다양한 실시예에 따른 웹 이벤트 검출부 463은 상기 전자 장치 101에서 표시되거나 실행되는 적어도 하나의 웹 페이지를 모니터링할 수 있다. 일부 실시 예들에서, 상기 웹 이벤트 검출부 463은 상기 적어도 하나의 웹 페이지를 모니터링하고, 상기 모니터링된 적어도 하나의 웹 페이지를 저장(또는 임시적으로 저장)할 수 있다. 상기 웹 이벤트 검출부 463은 상기 적어도 하나의 웹 페이지가 거래와 관련되는지 여부를 확인(또는 식별)할 수 있다. 상기 웹 이벤트 검출부 463은 상기 적어도 하나의 웹 페이지에 대한 정보를 상기 로그 저장부 465에 제공할 수 있다. 상기 제공된 정보는 상기 로그 저장부 465에 저장될 수 있다.
본 발명의 다양한 실시예에 따른 위치 변경 이벤트 검출부 464는 상기 전자 장치 101의 위치의 변화를 모니터링할 수 있다. 예를 들면, 상기 위치 변경 이벤트 검출부 464는, 상기 전자 장치 101에 포함된 센서, 상기 전자 장치 101에 포함된 통신 인터페이스를 이용하여, 상기 전자 장치 101의 위치 변화를 모니터링할 수 있다. 상기 위치 변경 이벤트 검출부 464는 상기 전자 장치 101의 위치 변화에 대한 정보를 상기 로그 저장부 465에게 제공할 수 있다. 상기 제공된 정보는 상기 로그 저장부 465에 저장될 수 있다.
본 발명의 다양한 실시예에 따른 로그 저장부 465는 상기 메시지 이벤트 검출부 461, 상기 결제 어플리케이션 이벤트 검출부 462, 상기 웹 이벤트 검출부 463, 상기 위치 변경 이벤트 검출부 464, 또는 상기 POI 검출부 466에 의해 검출된 정보를 저장할 수 있다. 일부 실시 예들에서, 상기 로그 저장부 465는 상기 정보를 임시적으로 저장할 수도 있다.
본 발명의 다양한 실시예에 따른 POI 검출부 466은, 상기 메시지 이벤트 검출부 461, 상기 결제 어플리케이션 이벤트 검출부 462, 상기 웹 이벤트 검출부 463, 및/또는 상기 위치 변경 이벤트 검출부 464에 의해 검출된 정보에 기반하여 상기 전자 장치 101의 사용자의 POI를 검출할 수 있다. 상기 POI 검출부 466은 상기 검출된 POI에 대한 정보를 상기 로그 저장부 465에게 제공할 수 있다. 상기 검출된 POI에 대한 정보는, 상기 로그 저장부 465에 저장될 수 있다.
본 발명의 다양한 실시예에 따른 아이템 결정부 450은 상기 로깅 프레임워크 410과 연동하여 상기 전자 장치 101의 사용자가 거래하는 아이템이 무엇인지를 결정할 수 있다. 일부 실시 예들에서, 상기 아이템 결정부 450은 아이템 추출부(item extractor) 470, 모니터링부(monitoring unit) 480, 또는 상태 관리부(state manager) 490을 포함할 수 있다.
본 발명의 다양한 실시예에 따른 아이템 추출부 470은, 상기 로깅 프레임워크 410으로부터 제공 받은 정보에 기반하여 상기 전자 장치 101의 사용자가 거래하는 아이템 또는 상기 전자 장치 101과 관련된 아이템이 무엇인지를 특정할 수 있다. 상기 아이템 추출부 470은 컨텐츠 추출부(contents extractor) 471 및/또는 파싱 관련 명령어 저장부(parsing relating instruction repository) 472를 포함할 수 있다.
본 발명의 다양한 실시예에 따른 컨텐츠 추출부 471은 상기 파싱 관련 명령어 저장부 472에 저장된 명령어 또는 룰(rule) 정보에 기반하여 특정 데이터에 포함된 컨텐츠 또는 아이템을 추출할 수 있다. 예를 들면, 상기 컨텐츠 추출부 471은 상기 로깅 프레임워크로부터 수신되는 웹 문서를 상기 명령어 또는 룰 정보에 기반하여 파싱함으로써, 상기 웹 문서로부터 컨텐츠 또는 아이템을 추출할 수 있다.
본 발명의 다양한 실시예에 따른 파싱 관련 명령어 저장부 472는 상기 로깅 프레임워크 410으로부터 제공 받은 정보를 파싱하는 명령어 또는 룰 정보를 저장할 수 있다. 예를 들면, 상기 파싱 관련 명령어 저장부 472는 상기 제공 받은 정보를 파싱하는 단위, 파싱하는 기법 등에 대한 데이터를 저장할 수 있다. 상기 파싱 관련 명령어 저장부 472는 상기 저장된 데이터를 상기 컨텐츠 추출부 471에 제공할 수 있다.
본 발명의 다양한 실시예에 따른 모니터링부 480은 상기 전자 장치 101에서 발생되는 거래 이벤트가 개시됨을 분석하고, 거래와 관련된 로그를 수집할 수 있다. 상기 모니터링부 480은 도메인 저장부(domain repository) 481, 웹 문서 분류부(web document classifier) 482, URL 추출부(URL extractor) 483을 포함할 수 있다.
본 발명의 다양한 실시예에 따른 도메인 저장부 481은 거래와 관련된 적어도 하나의 웹 페이지의 적어도 하나의 URL을 저장할 수 있다. 예를 들면, 도메인 저장부 481은 주요 온라인 쇼핑몰 사이트에 상기 전자 장치 101이 접속한 이력을 확인하기 위하여, 거래와 관련된 온라인 쇼핑몰의 URL을 저장할 수 있다. 일부 실시 예들에서, 상기 도메인 저장부 481은 상기 적어도 하나의 웹 페이지의 적어도 하나의 URL을 거래 동작 별로 분류하여 저장할 수 있다. 예를 들면, 상기 도메인 저장부 481은 거래와 관련된 웹페이지들을 아이템의 조회와 관련된 웹페이지, 아이템의 결제와 관련된 웹 페이지, 또는 특정 아이템의 상세 정보를 표시하는 웹페이지 등으로 분류하여 저장할 수 있다.
본 발명의 다양한 실시예에 따른 웹문서 분류부 482는 상기 전자 장치 101과 관련된 웹 페이지의 웹 문서를 분석함으로써, 상기 웹 페이지가 어떤 카테고리에 해당하는지 여부를 확인할 수 있다. 또한, 상기 웹문서 분류부 482는 상기 확인 결과에 기반하여 상기 웹 문서를 분류할 수 있다.
본 발명의 다양한 실시예에 따른 URL 추출부 483은, 상기 전자 장치 101과 관련된 결제 이벤트가 발생되는 경우, 상기 결제 이벤트가 발생된 시점과 관련된 웹 페이지 이력을 추출할 수 있다. 예를 들어, 상기 전자 장치 101에 결제 관련 메시지가 수신되는 경우, 상기 URL 추출부 483은 상기 결제 관련 메시지가 수신된 시점에 기반하여 결정되는 시구간 동안 상기 전자 장치 101이 접속하였던 웹 페이지 이력을 추출할 수 있다.
본 발명의 다양한 실시예에 따른 상태 관리부(state manager) 490은, 상기 전자 장치 101에서 거래와 관련된 동작이 수행되는 경우, 상기 거래가 어떤 동작중에 있는지를 분석할 수 있다.
본 발명의 다양한 실시예에 따른 상태 관리부 490은 도메인 패턴 저장부(domain pattern repository) 491, URL 패턴 분류부(URL pattern classifier) 492, 상태 분석부(state analyzer) 493을 포함할 수 있다.
본 발명의 다양한 실시예에 따른 도메인 패턴 저장부 491은 거래와 관련된 웹 페이지들의 거래 동작 별 URL 패턴을 저장할 수 있다. 예를 들면, 상기 도메인 패턴 저장부 491은 "www.amegon.com/items"를 복수의 아이템들의 요약 정보를 제공하는 동작으로 저장하고, "www.amegon.com/detail"을 특정 아이템에 대한 상세 정보를 제공하는 동작으로 저장하고, "www.amegon.com/payment"를 특정 아이템을 결제하기 위한 동작으로 저장할 수 있다.
본 발명의 다양한 실시예에 따른 URL 패턴 분류부 492는, 상기 도메인 패턴 저장부 491에 저장되지 않은 URL에 상기 전자 장치 101이 접속한 경우, 상기 저장되지 않은 URL을 분석하여 거래 동작을 검출하는 기능을 수행할 수 있다. 예를 들어, 상기 전자 장치 101이 "www.adjghlei.com/detail"에 접속한 경우, 상기 전자 장치 101은 "www.adjghlei.com/detail"와 관련된 웹 문서를 파싱함으로써, "www.adjghlei.com/detail"이 거래와 관련됨을 확인하고, 특정 아이템에 대한 상세 정보를 제공하는 동작임을 검출할 수 있다.
본 발명의 다양한 실시예에 따른 상태 분석부 493은 상기 도메인 패턴 저장부 491 또는 상기 URL 패턴 분류부 492로부터 저장되거나 검출된 정보에 기반하여, 상기 전자 장치 101과 관련된 거래의 동작이 어떤 동작인지를 분석할 수 있다. 예를 들면, 상기 상태 분석부 493은 상기 도메인 패턴 저장부 491 또는 상기 URL 패턴 분류부 492로부터 제공 받은 정보에 기반하여 상기 전자 장치 101와 관련된 거래가 현재 상세 정보 조회 동작임을 확인하거나, 상기 전자 장치 101와 관련된 거래가 현재 결제 동작임을 확인할 수 있다.
본 발명의 다양한 실시예에 따른 로깅 프레임워크 410 또는 상기 아이템 결정부 450에 의해 수행되는 동작들은 후술되는 도 5 내지 도 17에 대한 설명을 통해 후술될 것이다.
또한, 본 문서에서 전자 장치 101을 주체로 하여 기술되는 동작들은 상기 전자 장치 101에 포함된 로깅 프레임워크 410 또는 상기 아이템 결정부 450에 의해 수행될 수 있음을 유의하여야 한다.
또한, 도 4에 도시된 상기 전자 장치 101의 기능적 구성은 설명을 위한 예시일 뿐 다른 변형된 포맷으로 구현될 수 있음을 유의하여야 한다. 예를 들면, 도 4와 달리, 상기 전자 장치 101은, 상기 전자 장치 101에 포함된 상기 프로세서 120, 상기 메모리 130, 또는 상기 통신 인터페이스 170을 통해 상기 도 4에 예시된 동작들을 수행할 수 있다.
다양한 실시 예들에 따른 전자 장치는, 하우징과, 상기 하우징의 일부를 통해 노출된 터치스크린 디스플레이와, 무선 통신 회로와, 상기 디스플레이 및 상기 통신 회로와 전기적으로 연결된 프로세서와, 상기 프로세서와 연결되고, 상기 통신 회로를 통해 제1 외부 서버에 거래 관련(transaction-related) 정보를 송신하도록 설정된 제1 어플리케이션 프로그램을 저장하고, 상기 전자 장치가 상기 통신 회로를 통해 접속하는 웹 주소(web address)들에 대한 제1 정보를 적어도 임시적으로 저장하고, 상기 제1 어플리케이션 프로그램을 이용하여 거래를 실행하기 위한 사용자 입력을 상기 디스플레이를 통해 수신하고, 상기 사용자 입력을 수신하면, 상기 통신 회로를 통해 상기 제1 외부 서버에게 상기 거래와 관련된 제2 정보를 송신하고, 상기 제2 정보를 송신하는 동작 직전 또는 직후에 상기 웹 주소들 중 하나와 관련된 웹 문서에 접근하고, 상기 거래와 관련된 적어도 하나의 아이템을 획득하기 위해 상기 웹 문서를 파싱(parsing)하고, 상기 통신 회로를 이용하여 상기 전자 장치 외부에 상기 적어도 하나의 아이템 또는 상기 웹 주소들 중 하나 중 하나 또는 그 이상에 대한 제3 정보를 송신하기 위해 상기 프로세서를 야기하는 명령어들을 더 저장하는 메모리를 포함할 수 있다.
일부 실시 예들에서, 상기 명령어들은, 상기 제1 외부 서버와 다른 제2 외부 서버에게 상기 제3 정보를 송신하기 위해 상기 프로세서를 야기할 수 있다.
일부 실시 예들에서, 상기 웹 문서는, HTML(hyper mark-up language) 포맷(format)일 수 있다.
일부 실시 예들에서, 상기 명령어들은, 룰 기반(rule-based) 기법 또는 머신 러닝 기반(machine-learning based) 기법을 이용하여 상기 웹 문서를 파싱하기 위해 상기 프로세서를 야기할 수 있다.
일부 실시 예들에서, 상기 제1 정보는, URL(uniform resource locator)를 포함할 수 있다.
일부 실시 예들에서, 상기 명령어들은, 상기 제1 어플리케이션 프로그램을 포함하는 복수의 전자 장치들로부터 수집되고 웹 주소들 및 아이템들과 관련된 데이터에 적어도 일부 기반하여 생성된 제4 정보를 상기 외부 서버로부터 상기 통신 회로를 통해 수신하고, 상기 제4 정보에 기반하여 상기 디스플레이에 알림(notification)을 제공하기 위해 상기 프로세서를 야기할 수 있다.
일부 실시 예들에서, 상기 명령어들은, 상기 전자 장치가 상기 통신 회로를 통해 접속하는 복수의 웹 주소들이 거래와 관련되는지 여부를 결정하고, 상기 복수의 웹 주소들 중에서 거래와 관련된 상기 웹 주소(web address)들에 대한 상기 제1 정보를 적어도 임시적으로 저장하기 위해 상기 프로세서를 야기할 수 있다.
다양한 실시 예들에 따른 전자 장치는, 명령어(instruction)들을 저장하는 메모리와, 무선 통신 회로(wireless communication circuit)와, 상기 메모리와 상기 무선 통신 회로와 전기적으로(electrically) 연결(coupled to)되고, 제1 외부 전자 장치로부터 제1 거래(transaction)가 완료됨(completed)을 나타내기 위한 제1 메시지를 수신하고, 상기 제1 메시지가 수신된 시점(timing)에 기반하여 결정되는 시구간(interval) 동안 상기 전자 장치가 접속하였던 복수의 웹 주소들 중에서 거래와 관련된 도메인 네임(domain name)을 포함하는 적어도 하나의 웹 주소를 결정하고, 상기 적어도 하나의 웹 주소와 관련된 적어도 하나의 웹 문서에 대한 데이터를 파싱하여 상기 제1 거래의 아이템(item)에 대한 정보를 결정하고, 상기 제1 거래의 아이템에 대한 정보를 상기 제1 외부 전자 장치 또는 제2 외부 전자 장치에게 송신하기 위해 상기 저장된 명령어들을 실행하도록 설정된 적어도 하나의 프로세서를 포함할 수 있다.
일부 실시 예들에서, 상기 적어도 하나의 프로세서는, 상기 전자 장치로부터 송신된 상기 아이템을 포함하는 복수의 아이템들에 대한 정보에 기반하여 결정된 적어도 하나의 참조 아이템(reference item)에 대한 정보를 상기 제2 외부 전자 장치로부터 수신하기 위해 상기 저장된 명령어들을 실행하도록 더 설정될 수 있다. 또한, 상기 적어도 하나의 프로세서는, 복수의 전자 장치들로부터 수집된 정보에 기반하여 결정된 특정 아이템(specific item)에 대한 정보를 포함하는 제2 메시지를 상기 제2 외부 전자 장치로부터 수신하기 위해 상기 저장된 명령어들을 실행하도록 더 설정될 수 있다. 또한, 상기 전자 장치는, 상기 적어도 하나의 프로세서와 전기적으로 연결된 디스플레이 유닛(unit)을 더 포함할 수 있고, 상기 적어도 하나의 프로세서는, 상기 특정 아이템이 상기 적어도 하나의 참조 아이템에 포함되는지 여부를 결정하고, 상기 특정 아이템이 상기 적어도 하나의 참조 아이템에 포함된 경우, 상기 특정 아이템에 대한 정보를 상기 디스플레이 유닛을 통해 표시하기 위해 상기 저장된 명령어들을 실행하도록 더 설정될 수 있다. 또한, 상기 표시된 특정 아이템에 대한 정보는, 상기 특정 아이템에 대한 제2 거래를 수립하기 위한 데이터를 포함할 수 있다. 또한, 상기 특정 아이템에 대한 제2 거래를 수립하기 위한 데이터는, 상기 특정 아이템을 제공하는 웹 주소를 나타내기 위한 데이터, 상기 특정 아이템과 관련된 이벤트를 나타내기 위한 데이터, 상기 특정 아이템의 가격(price)을 나타내기 위한 데이터, 또는 상기 특정 아이템의 이미지를 나타내기 위한 데이터 중 적어도 하나를 포함할 수 있다.
또한, 상기 적어도 하나의 프로세서는, 상기 표시된 특정 아이템에 대한 정보에 대한 입력을 검출하는 것에 기반하여, 상기 특정 아이템에 대한 거래를 위한 웹페이지에 접속하고, 상기 접속된 웹페이지를 표시하기 위해 상기 저장된 명령어들을 실행하도록 더 설정될 수 있다.
또한, 상기 제2 메시지는, 미리 결정된 주기 동안 상기 복수의 전자 장치들로부터 수집된 정보에 상기 특정 아이템이 포함되는 빈도가 기준치(reference value) 이상인 경우, 상기 제2 외부 전자 장치로부터 송신될 수 있다.
일부 실시 예들에서, 상기 적어도 하나의 프로세서는, 복수의 전자 장치들로부터 수집된 정보에 기반하여 결정된 특정 아이템에 대한 정보를 포함하는 제2 메시지를 상기 제2 외부 전자 장치로부터 수신하기 위해 상기 저장된 명령어들을 실행하도록 더 설정될 수 있고, 상기 제2 메시지는, 상기 특정 아이템이 상기 전자 장치로부터 송신된 상기 아이템을 포함하는 복수의 아이템들에 대한 정보에 기반하여 결정된 적어도 하나의 참조 아이템에 포함됨을 결정하는 것에 기반하여 상기 제2 외부 전자 장치로부터 상기 전자 장치에게 송신될 수 있다.
일부 실시 예들에서, 상기 적어도 하나의 프로세서는, 거래와 관련되고 상기 전자 장치에 미리 저장된 적어도 하나의 참조 도메인 네임과 상기 복수의 웹 주소들의 도메인 네임을 비교함으로써, 상기 복수의 웹 주소들 중에서 상기 적어도 하나의 참조 도메인 네임과 대응하는 도메인 네임을 가지는 상기 적어도 하나의 웹 주소를 결정하기 위해 상기 저장된 명령어들을 실행하도록 설정될 수 있다.
일부 실시 예들에서, 상기 적어도 하나의 프로세서는, 상기 복수의 웹 주소들의 복수의 도메인 네임들 각각에 포함된 문자들을 식별하고, 상기 식별된 문자들 중 적어도 하나를 조합함으로써 생성되는 용어(word)가 거래와 관련되고 상기 전자 장치에 미리 저장된 적어도 하나의 참조 용어에 포함되는지 여부를 결정하고, 상기 용어가 상기 적어도 하나의 참조 용어에 포함됨을 결정하는 것에 기반하여, 상기 용어에 포함된 적어도 하나의 문자를 포함하는 도메인 네임을 포함하는 웹 주소를 상기 적어도 하나의 웹 주소로 결정하기 위해 상기 저장된 명령어들을 실행하도록 설정될 수 있다.
일부 실시 예들에서, 상기 적어도 하나의 프로세서는, 상기 적어도 하나의 웹 문서에 대한 데이터를 파싱함으로써, 상기 웹 문서에 포함된 태그를 식별하고, 상기 식별된 태그에 포함된 정보에 기반하여 상기 제1 거래의 아이템에 대한 정보를 결정하기 위해 상기 저장된 명령어들을 실행하도록 설정될 수 있다.
다양한 실시 예들에 따른 서버는, 적어도 하나의 프로세서와, 상기 적어도 하나의 프로세서와 연결되고, 복수의 전자 장치들로부터 거래와 관련된 복수의 아이템들에 대한 정보를 수신하고, 미리 결정된 주기 동안 상기 복수의 전자 장치들로부터 수신되는 정보에 제1 아이템이 포함되는 빈도가 기준치(reference value) 이상인 경우, 상기 제1 아이템에 대한 정보를 송신하기 위해 상기 적어도 하나의 프로세서를 야기하는 명령어들을 저장하는 메모리를 포함할 수 있고, 상기 복수의 아이템들에 대한 정보는, 상기 복수의 전자 장치들 각각에서 상기 복수의 아이템들 각각에 대한 거래가 완료되는 것에 기반하여 상기 복수의 전자 장치들 각각으로부터 송신될 수 있다.
도 5는 다양한 실시 예들에 따라 거래를 수행하는 전자 장치를 포함하는 시스템의 예를 도시한다.
도 5를 참조하면, 시스템 500은 상기 전자 장치 101, 빅 데이터(big data) 서버 510, 결제 서버 520, 쇼핑몰 서버 530을 포함할 수 있다.
상기 전자 장치 101은 이동성(mobility)를 가지는 장치일 수 있다. 상기 전자 장치 101은, 실시 예들에 따라 모바일 스테이션(mobile station), 단말(terminal), STA(station), 사용자 장치(user equipment) 등으로 지칭될 수도 있다.
상기 전자 장치 101은 고정된(fixed) 장치일 수 있다. 예를 들면, 상기 전자 장치 101은 데스크탑 컴퓨터(desktop computer), 비디오 게임 콘솔(video game console), 스마트 TV(smart television), 통신 기능을 구비한 가정용 전자 기기(예: 냉장고, 보일러(boiler) 등) 또는 미러 디스플레이(mirror display) 등일 수 있다. 하지만, 이에 제한되지 않는다.
본 발명의 다양한 실시예에 따른 전자 장치 101은 다른 전자 장치 또는 다른 개체와 통신할 수 있다. 예를 들면, 상기 다른 개체는, 상기 빅 데이터 서버 510, 상기 결제 서버 520, 상기 쇼핑몰 서버 530 등과 같은 서버일 수 있다. 일부 실시 예들에서, 상기 전자 장치 101은 유선 통신 경로(wired communication path)를 통해, 상기 다른 전자 장치 또는 상기 다른 개체와 통신할 수 있다. 다른 일부 실시 예들에서, 상기 전자 장치 101은 무선 통신 경로(wireless communication path)를 통해, 상기 다른 전자 장치 또는 상기 다른 개체와 통신할 수 있다. 예를 들면, 상기 무선 통신 경로는, Wi-Fi(wireless-Fidelity) 경로, 셀룰러(cellular) 통신 경로, 블루투스 BLE 등과 같은 근접 통신을 위한 경로일 수 있다.
본 발명의 다양한 실시예에 따른 전자 장치 101은 상기 빅 데이터 서버 510, 상기 결제 서버 520, 상기 쇼핑몰 서버 530 등과 같은 다른 개체로부터 수신되는 정보를 상기 전자 장치 101의 상기 디스플레이 160에서 표시할 수 있다.
본 발명의 다양한 실시예에 따른 전자 장치 101은 거래와 관련된 다양한 동작들을 수행할 수 있다. 일부 실시 예들에서, 상기 전자 장치 101은 모바일 어플리케이션(예: 삼성 페이(samsung pay) 어플리케이션)을 실행하고, 외부 전자 장치(예: POS(point of sale) 장치)와 직접적으로 무선 연결을 설정하는 동안, 무선 통신 회로들 중 하나를 이용하여 상기 외부 전자 장치와 결제를 위한 통신을 수행할 수 있다. 예를 들면, 상기 전자 장치 101은 상기 NFC 모듈 225, 또는 상기 BT 모듈 223 중 적어도 하나를 통해 NFC 프로토콜(protocol)들, 블루투스 프로토콜들, 또는 MST 프로토콜들 중 하나를 이용하여 결제 관련 정보를 상기 외부 전자 장치에게 송신할 수 있다. 다만, 결제를 위한 통신 방식은 이에 제한되지 않는다.
다른 일부 실시 예들에서, 상기 전자 장치 101은 결제를 위한 통신 방식 이외에, 바코드(barcode) 또는 QR 코드(abbreviated from quick response code) 등을 이용한 비통신 방식(non-communication scheme)으로 결제 관련 정보를 상기 외부 전자 장치에게 송신할 수 있다.
여기서, 상기 결제 관련 정보는, 토큰(token) 정보 또는 암호 정보(예: cryptogram) 등을 포함할 수 있다.
일부 실시 예들에서, 상기 전자 장치 101은 모바일 결제 서비스를 이용하기 위하여 결제 인증을 수행할 수 있다. 예를 들면, 상기 전자 장치 101은, 상기 결제 인증을 수행하기 위해, 생체 정보(예: 지문 정보, 또는 홍채 정보 등), PIN(personal identification number) 정보, 또는 서명(signature) 정보 등을 위한 사용자 입력을 수신할 수 있다. 상기 전자 장치 101은 상기 수신된 정보에 적어도 일부 기반하여 거래에 대한 결제를 수행하기 위한 동작을 개시하기 전에 상기 결제 인증을 수행할 수 있다. 다만, 이에 제한되지 않는다. 상기 전자 장치 101이 모바일 결제 서비스를 이용하는 경우, 상기 결제 서버 520과 같이 결제 서비스를 제공하는 서버로부터 결제에 대한 정보를 수신할 수 있다. 다만, 이에 제한되지 않는다.
다른 일부 실시 예들에서, 상기 전자 장치 101은 모바일 결제가 수행되거나 모바일 결제가 수행되기 전 결제 인증이 수행된 경우, 결제가 수행되거나 결제 인증이 수행됨에 따른 정보를 획득할 수 있다.
또 다른 일부 실시 예들에서, 상기 전자 장치 101의 사용자가 카드(예: 실물 신용 카드 등)을 이용하여 오프라인에서 결제 행위를 수행한 경우, 상기 전자 장치 101은 상기 결제 서버 520 등과 같은 결제 서비스 서버(예: 카드사 서버 또는 금융 회사 서버)로부터 오프라인 결제에 대한 정보(또는 특정 아이템에 대한 거래가 완료됨을 나타내기 위한 메시지)를 수신할 수 있다. 예를 들면, 상기 전자 장치 101은 SMS(short messasge service) 메시지, MMS(multi-media message service), 또는 메신져(messenger) 어플리케이션의 채팅(chat) 메시지와 같은 포맷을 가지는 상기 결제에 대한 정보(또는 거래가 완료됨을 나타내기 위한 메시지)를 상기 결제 서버 520으로부터 수신할 수 있다. 다만, 상기 전자 장치 101의 시그널링 또는 동작은, 이에 제한되지 않는다.
본 발명의 다양한 실시예에 따른 전자 장치 101은 상기 전자 장치 101와 관련된 거래의 아이템이 무엇인지를 결정할 수 있다. 예를 들면, 상기 전자 장치 101은 상기 전자 장치 101이 접속하였던 복수의 웹들에 대한 정보에 적어도 일부 기반하여 상기 전자 장치 101에게 제공되는 복수의 아이템들 중에서 거래와 관련된 아이템을 특정할 수 있다. 다른 예를 들면, 상기 전자 장치 101은 상기 전자 장치 101에 의해 수집된 센싱 데이터(sensing data), 상기 전자 장치 101에 의해 결정되거나 또는 POI(point of interest)를 관리하는 POI 서버로부터 수신되는 POI 정보 등에 기반하여 상기 전자 장치 101의 사용자가 오프라인 매장에서 거래한 아이템을 특정할 수 있다. 상기 전자 장치 101이 상기 전자 장치 101과 관련된 거래의 아이템을 결정(또는 특정)하는 동작에 관한 상세한 내용은 이하에서 후술된다.
본 발명의 다양한 실시예에 따른 전자 장치 101은 상기 전자 장치 101에 의해 결정되거나 특정된 아이템에 대한 정보를 상기 빅 데이터 서버 510과 같은 다른 개체에게 송신할 수 있다. 상기 아이템에 대한 정보는, 상기 아이템의 이름, 상기 아이템의 이미지 등과 같이 상기 아이템이 무엇인지를 나타내는 데이터를 포함할 수 있다. 또한, 상기 아이템에 대한 정보는, 상기 아이템의 현재 판매 가격 등에 대한 데이터를 포함할 수 있다.
본 발명의 다양한 실시예에 따른 아이템에 대한 정보는 다양한 경로를 통해 상기 빅 데이터 서버 510에게 송신될 수 있다. 예를 들어, 상기 전자 장치 101이 상기 전자 장치 101에 저장된 삼성 페이 등과 같은 모바일 결제 어플리케이션을 통해 결제를 수행하는 경우, 상기 전자 장치 101은 결제 정보(또는 거래를 완료하기 위한 정보) 뿐 아니라 상기 전자 장치 101에 의해 선택된 아이템에 대한 정보를 상기 결제 서버 520에게 제공할 수 있다. 상기 아이템에 대한 정보는 상기 결제 정보와 함께 송신될 수도 있고, 상기 결제 정보를 나르는(carry) 메시지와 다른 별도의 메시지에 포함되어 송신될 수도 있다. 상기 아이템에 대한 정보를 수신한 상기 결제 서버 520은 상기 아이템에 대한 정보를 상기 빅 데이터 서버 510에게 제공 또는 전달할 수 있다.
다른 예를 들어, 상기 전자 장치 101의 사용자가 소지한 카드 등을 이용하여 결제를 수행하는 경우, 상기 전자 장치 101은 상기 전자 장치 101과 관련된 거래의 아이템에 대한 정보를 상기 빅 데이터 서버 510에게 제공할 수 있다.
본 발명의 다양한 실시예에 따른 결제 서버 520은, 결제 서비스를 제공하는 서버일 수 있다. 일부 실시 예들에서, 상기 결제 서버 520은 삼성 페이 등과 같은 모바일 결제 서비스를 제공하는 서버일 수 있다. 다른 일부 실시 예들에서, 상기 결제 서버 520은 실물 카드 또는 전자적 카드를 발급하는 은행 또는 금융회사에 의해 운영되는 서버일 수 있다. 또 다른 일부 실시 예들에서, 상기 결제 서버 520은 상점에 결제된 카드 거래에 대한 전표를 매입하는 은행 또는 금융회사에 의해 운영되는 서버일 수 있다. 이러한 경우, 상기 결제 서버 520은 매입 서버 또는 VAN(value add network)로 지칭될 수 있다.
본 발명의 다양한 실시예에 따른 결제 서버 520은 카드의 카드 정보에 상응하는 토큰(token)을 생성하여 상기 전자 장치 510에게 제공할 수 있다. 또한, 상기 결제 서버 520은 거래 과정에서 상기 토큰과 관련된 카드 정보를 검색할 수 있다.
상기 결제 서버 520은 카드 등에 대한 신원 확인을 수행할 수 있다. 또한, 상기 결제 서버 520은 결제 시 카드에 대한 승인을 진행할 수 있다. 예를 들면, 상기 결제 서버 520은, 수신된 카드 정보가 유효한 정보인지 여부를 판단할 수 있다.
상기 결제 서버 520은, 아이템을 결제하기 위하여, 상기 전자 장치 101 또는 상기 전자 장치 101과 관련된 POS(point of sales) 장치로부터 결제 정보(또는 거래를 완료하기 위한 정보)를 수신할 수 있다. 상기 결제 정보를 수신한 상기 결제 서버 520은 인증 등을 수행한 후 상기 결제를 승인할 수 있다. 상기 결제를 승인한 상기 결제 서버 520은 상기 쇼핑몰 서버 530에게 결제가 완료됨을 나타내는 메시지를 송신할 수 있다.
본 발명의 다양한 실시예에 따른 쇼핑몰 서버 530은, 사용자들에게 다양한 아이템들을 판매하는 쇼핑몰에 의해 운영되는 서버일 수 있다. 상기 쇼핑몰 서버 530은 상기 전자 장치 101 또는 상기 결제 서버 520과 연동하여(in association with) 거래와 관련된 다양한 동작들을 수행할 수 있다. 예를 들면, 상기 쇼핑몰 서버 530은, 상기 거래를 수립(establish)하기 위하여, 상기 전자 장치 101에게 상기 쇼핑몰에서 판매되는 다양한 아이템들에 대한 정보를 제공함으로써, 상기 전자 장치 101의 사용자의 구매를 유도할 수 있다. 다른 예를 들면, 상기 쇼핑몰 서버 530은, 상기 결제 서버 520에게 결제가 요구되는 아이템의 가격 정보 등을 제공할 수 있다. 또 다른 예를 들면, 상기 쇼핑몰 서버 530은, 상기 결제 서버 520으로부터 아이템에 대한 결제 또는 아이템에 대한 거래가 완료됨을 나타내는 정보를 제공 받을 수 있다. 하지만, 이에 제한되지 않는다.
본 발명의 다양한 실시예에 따른 빅 데이터 서버 510은, 상기 전자 장치 101, 상기 결제 서버 520, 또는 상기 쇼핑몰 서버 530 중 적어도 하나와 관련된 거래에 의해 야기되는 정보를 처리할 수 있다. 예를 들면, 상기 빅 데이터 서버 510은 상기 전자 장치 101 또는 상기 결제 서버 520로부터 제공 받은 아이템에 대한 정보를 저장하거나 업데이트할 수 있다.
본 발명의 다양한 실시예에 따른 아이템에 대한 정보는, 상기 아이템의 이름, 상기 아이템의 상표, 상기 아이템의 이미지 등과 같은 상기 아이템에 무엇인지를 결정할 수 있는 데이터를 포함할 수 있다. 또한, 상기 아이템에 대한 정보는, OOO 쇼핑몰, XX 마트 등과 같은 상기 아이템을 판매하고 있는 출처에 대한 데이터를 포함할 수 있다. 또한, 상기 아이템에 대한 정보는, 상기 아이템의 가격에 대한 데이터를 포함할 수 있다. 또한, 상기 아이템에 대한 정보는, 상기 아이템에 대한 프로모션이 진행되는 기간 등에 대한 정보를 포함할 수 있다.
일부 실시 예들에서, 상기 빅 데이터 서버 510은 상기 저장되거나 업데이트된 정보에 기반하여 상기 전자 장치 101의 사용자의 선호도에 대한 정보를 결정할 수 있다. 상기 저장되거나 업데이트된 정보는, 상기 전자 장치 101과 같은 사용자의 전자 장치로부터 송신되는 상기 아이템에 대한 정보에 기반하여 결정되기 때문에, 상기 빅 데이터 서버 510은 특정 판매자(예: XX 쇼핑몰, OO 마트 등)에 국한되지 않고, 상기 전자 장치 101의 사용자의 선호도에 대한 정보를 결정할 수 있다. 다시 말해, 상기 빅 데이터 서버 510은, 상기 전자 장치 101의 사용자의 진정한 선호도에 대한 정보를 생성할 수 있다.
일부 실시 예들에서, 상기 빅 데이터 서버 510은 상기 결정된 사용자의 선호도에 대한 정보에 기반하여 상기 전자 장치 101의 사용자가 선호하는 아이템을 결정하고 저장할 수 있다. 또한, 상기 빅 데이터 서버 510은 상기 전자 장치 101의 사용자가 선호하는 아이템에 대한 정보를 상기 전자 장치 101, 상기 결제 서버 520, 또는 상기 쇼핑몰 서버 530 중 적어도 하나에게 제공할 수 있다.
일부 실시 예들에서, 상기 빅 데이터 서버 510은 상기 결제 서버 520 또는 상기 전자 장치 101로부터 수신되는 아이템에 대한 정보를 모니터링 또는 분석할 수 있다. 상기 빅 데이터 서버 510은, 상기 모니터링 또는 분석 결과에 따라, 상기 전자 장치 101에게 알림 메시지를 송신할 수 있다. 예를 들면, 상기 빅 데이터 서버 510은, 상기 모니터링 또는 상기 분석에 기반하여, 미리 결정된 시구간 동안 동일한 아이템에 대한 수신 빈도가 기준치 이상임을 결정할 수 있다. 상기 빅 데이터 서버 510은, 상기 빈도가 상기 기준치 이상임을 결정하는 것에 기반하여, 상기 전자 장치 101에게 기준치 이상의 수신 빈도를 가지는 아이템에 대한 정보를 포함하는 알림 메시지를 송신할 수 있다. 다른 예를 들면, 상기 빅 데이터 서버 510은 상기 모니터링 또는 상기 분석에 기반하여, 특정 아이템의 현재 가격과 상기 특정 아이템의 이전 가격 사이의 차이가 기준치 이상임을 결정할 수 있다. 상기 빅 데이터 서버 510은, 상기 차이가 기준치 이상임을 결정하는 것에 기반하여, 상기 전자 장치 101에게 상기 특정 아이템에 대한 정보를 포함하는 알림 메시지를 송신할 수 있다. 하지만, 상기 빅 데이터 서버 510에 의해 수행되는 알림 메시지의 송신 동작은, 이에 한정되지 않는다. 실시 예들에 따라, 상기 알림 메시지는, 멀티캐스트(multicast)될 수도 있고, 전자 장치들 각각 별로 유니캐스트(unicast)될 수도 있다.
실시 예들에 따라, 상기 빅 데이터 서버 510과 상기 결제 서버 520은 하나의 장치(apparatus)로 구현될 수도 있다.
상술한 바와 같이, 다양한 실시 예들에 따른 상기 전자 장치 101은, 거래의 아이템에 대한 정보를 결정하고, 상기 빅 데이터 서버 510 등에게 상기 결정된 아이템에 대한 정보를 제공할 수 있다. 다시 말해, 상기 전자 장치 101은, 상기 아이템에 대한 정보를 결정하고 제공하는 동작을 통해, 보다 높은 활용성을 가지는 서비스를 사용자에게 제공할 수 있다.
또한, 다양한 실시 예들에 따른 상기 빅 데이터 서버 510은 상기 전자 장치 101과 같은 전자 장치들로부터 제공되는 아이템에 대한 정보를 저장하고 업데이트함으로써, 전자 장치들 각각의 사용자의 선호도를 파악할 수 있다. 또한, 상기 빅 데이터 서버 510은, 상기 사용자의 선호도에 대한 정보를 전자 장치들에게 제공할 수 있다. 또한, 상기 빅 데이터 서버 510은, 상기 전자 장치 101과 같은 전자 장치들로부터 제공되는 아이템에 대한 정보를 분석하거나 모니터링함으로써, 상기 전자 장치 101과 같은 전자 장치들 각각에게 실질적인 의미를 가지는 아이템에 대한 정보를 포함하는 알림 메시지를 제공할 수 있다.
도 6은 다양한 실시 예들에 따른 전자 장치의 동작의 예를 도시한다. 이러한 동작은, 도 1에 도시된 상기 전자 장치 101 또는 상기 프로세서 120 등과 같은 상기 전자 장치 101의 구성 요소에 의해 수행될 수 있다.
도 6을 참조하면, 동작 610에서, 상기 전자 장치 101(예:프로세서 120 등)은 완료된 거래의 아이템에 대한 정보를 결정할 수 있다. 상기 전자 장치 101의 사용자가 신용 카드 또는 상기 전자 장치 101의 모바일 결제 어플리케이션을 이용하여 온라인 사이트 또는 오프라인 매장에서 아이템을 거래하는 경우, 상기 전자 장치 101은 상기 결제 서버 520과 같은 제1 외부 전자 장치로부터 상기 아이템의 거래가 완료됨을 나타내기 위한 메시지를 수신할 수 있다. 상기 아이템의 거래가 완료됨을 나타내기 위한 메시지는, 상기 아이템에 대한 결제에 대한 정보(또는 상기 아이템에 대한 결제 결과에 대한 정보)를 포함할 수 있다. 예를 들면, 상기 아이템의 거래가 완료됨을 나타내기 위한 메시지는, 상기 아이템의 이름에 대한 데이터, 상기 아이템의 가격에 대한 데이터, 상기 아이템을 판매한 출처에 대한 데이터, 상기 거래가 완료된 일시에 대한 데이터, 상기 결제를 수행한 수단을 식별하기 위한 데이터(예: 결제를 수행한 카드 번호 중 일부 또는 전부), 상기 결제를 수행한 수단에 의해 설정된 기간(예: 한달 등) 동안 결제된 금액의 합계에 대한 데이터 등을 포함할 수 있다.
일부 실시 예들에서, 상기 전자 장치 101은, 상기 수신된 메시지에 포함된 데이터에 기반하여, 상기 거래의 아이템에 대한 정보를 결정할 수 있다. 예를 들면, 상기 전자 장치 101은, 상기 수신된 메시지에 포함된 데이터를 파싱함으로써, 상기 아이템을 판매한 출처(예: GOM 마트)에 대한 데이터, 상기 아이템의 가격(예: 17800원)에 대한 데이터, 상기 아이템의 이름(예: 매운 떡볶이)에 대한 데이터 등을 획득할 수 있다. 하지만, 상기 수신된 메시지에 포함된 데이터를 획득하는 방법은, 이에 한정되지 않는다.
상기 전자 장치 101은 상기 수신된 메시지에 기반하여 획득된 데이터를 이용하여 상기 거래의 아이템을 특정할 수 있는지 여부를 결정할 수 있다. 상기 획득된 데이터를 이용하여 상기 거래의 아이템을 특정할 수 있는 경우, 상기 전자 장치 101은 상기 획득된 데이터에 기반하여 상기 거래의 아이템을 특정함으로써, 상기 거래의 아이템에 대한 정보를 결정할 수 있다.
상기 획득된 데이터를 이용하여 상기 거래의 아이템을 특정할 수 없는 경우, 상기 전자 장치 101은 다양한 동작들을 통해 상기 거래의 아이템을 특정할 수 있다. 일부 실시 예들에서, 상기 획득된 데이터를 이용하여 상기 거래의 아이템을 특정할 수 없는 경우, 상기 전자 장치 101은 상기 획득된 데이터를 이용하여 웹 서치(web search)를 수행할 수 있다. 상기 전자 장치 101은 상기 수행된 웹 서치로부터 도출되는 정보에 기반하여 상기 거래의 아이템을 특정할 수 있다.
다른 일부 실시 예들에서, 상기 획득된 데이터를 이용하여 상기 거래의 아이템을 특정할 수 없는 경우, 상기 전자 장치 101은 상기 메시지가 수신된 시점(timing)에 기반하여 결정되는 시구간(interval) 동안 상기 전자 장치 101이 접속하였던 복수의 웹들에 대한 정보에 기반하여 상기 거래의 아이템을 특정할 수 있다. 예를 들어, 상기 메시지가 20XX년 1월 19일 오후 4시 23분에 수신된 경우, 상기 전자 장치 101은, 상기 전자 장치 101의 메모리 130 또는 상기 전자 장치 101의 버퍼(buffer)에 저장된 20XX년 1월 19일 오후 4시 13분부터 20XX년 1월 19일 오후 4시 23분까지 상기 전자 장치 101이 접속하였던 웹들에 대한 정보를 조회할 수 있다. 상기 전자 장치 101은, 상기 조회된 웹들에 대한 정보에 기반하여, 상기 거래의 아이템을 특정할 수 있다.
또 다른 일부 실시 예들에서, 상기 획득된 데이터를 이용하여 상기 거래의 아이템을 특정할 수 없는 경우, 상기 전자 장치 101은, POI(point of interest) 정보 또는 상기 전자 장치 101의 센서 모듈에 의해 수집된 센싱 정보(sensing information) 중 적어도 하나에 기반하여 상기 거래의 아이템을 특정할 수 있다.
일 실시 예에서, 상기 POI 정보는, 상기 전자 장치 101의 위치에 대응하는 장소에 대한 데이터를 포함할 수 있다. 예를 들면, 상기 POI 정보는 상기 전자 장치 101이 위치된 현재 영역 또는 장소(예: 상점, 기관, 시설, 또는 건물 등)에 대한 정보를 포함할 수 있다. 다른 예를 들면, 상기 POI 정보는 상기 전자 장치 101이 위치된 상점의 상호명에 대한 데이터를 포함할 수 있다. 다만, 상기 POI 정보에 포함되는 데이터는 이에 한정되지 않는다.
다른 실시 예에서, 상기 POI 정보는, 결제와 관련된 장소에 대한 데이터를 포함할 수 있다. 예를 들어, 상기 전자 장치 101이 모바일 결제 어플리케이션을 이용하여 결제를 수행하는 경우, 상기 POI 정보는 상기 결제를 수행한(또는, 상기 메시지를 수신한) 시점에서 상기 전자 장치 101이 위치된 장소에 대한 데이터를 포함할 수 있다. 다만, 상기 POI 정보에 포함되는 데이터는 이에 한정되지 않는다.
또 다른 실시 예에서, 상기 POI 정보는, 결제 발생 위치로부터 일정 범위(또는 거리) 이내의 위치에 대한 데이터를 포함할 수 있다. 예를 들면, 상기 POI 정보는 상기 전자 장치 101이 결제를 수행한 위치를 기준으로 반경 10 m 이내의 영역에 대한 데이터를 포함할 수 있다. 다만, 상기 POI 정보에 포함되는 데이터는 이에 한정되지 않는다.
일 실시 예에서, 상기 센싱 정보는, 상기 전자 장치 101이 위치된 장소에서 센싱되는 데이터를 포함할 수 있다. 예를 들면, 상기 센싱 정보는 상기 전자 장치 101이 위치된 장소에서 상기 전자 장치 101 내의 적어도 하나의 통신 회로 또는 상기 전자 장치 101 내의 적어도 하나의 센서 중 적어도 하나를 이용하여 센싱되는 데이터를 포함할 수 있다. 예를 들면, 상기 센싱 정보는, 상기 전자 장치 101이 위치된 장소에서 수신되는 셀룰러(cellular) 무선 신호, Wi-Fi 신호, 블루투스 신호, 또는 NFC(near field communication) 신호, 또는 기타 무선 신호 중 하나 이상을 이용하여 수집되는 데이터를 포함할 수 있다. 다른 예를 들면, 상기 센싱 정보는, 상기 전자 장치 101이 위치된 장소 내부에 위치된(또는 배치된) 장치(예: Wi-Fi 통신을 위한 AP, 비콘 등), 상기 전자 장치 101 인근에 위치된 장치(예: 기지국 등), 또는 GPS(global positioning system) 위성 등으로부터 수신되는 신호에 포함된 데이터를 포함할 수 있다. 다만, 상기 센싱 정보에 포함되는 데이터는 이에 한정되지 않는다.
실시 예들에 따라, 상기 전자 장치 101은 상기 결정된 거래의 아이템에 대한 정보를 상기 전자 장치 101에 저장(또는 임시적으로(temporarily) 저장)할 수 있다.
동작 620에서, 상기 전자 장치 101(예:프로세서 120 등)은 상기 결정된 아이템에 대한 정보를 다른 개체에게 제공할 수 있다. 상기 다른 개체는, 상기 빅 데이터 서버 510, 상기 결제 서버 520, 또는 상기 쇼핑몰 서버 530 중 적어도 하나를 포함할 수 있다.
상기 다른 개체에게 제공하는 상기 아이템에 대한 정보는, 상기 아이템을 특정(또는 식별)할 수 있는 데이터를 포함할 수 있다. 예를 들면, 상기 아이템에 대한 정보는, 상기 아이템의 이름에 대한 데이터, 상기 아이템의 상표명에 대한 데이터, 상기 아이템의 이미지, 상기 아이템의 현재 가격에 대한 데이터, 상기 아이템의 할인율에 대한 데이터, 상기 아이템의 프로모션 기간에 대한 데이터, 상기 아이템을 판매하는 출처에 대한 데이터 등을 포함할 수 있다. 하지만, 상기 아이템에 대한 정보에 포함되는 데이터는, 이에 한정되지 않는다.
상기 전자 장치 101은, 상기 전자 장치 101의 사용자의 선호도를 결정하기 위한 참조(reference) 데이터를 제공하기 위해, 상기 아이템에 대한 정보를 송신할 수 있다.
일부 실시 예들에서, 상기 전자 장치 101은, 상기 전자 장치 101의 사용자의 선호도를 결정하기 위한 참조 데이터를 제공하기 위해, 상기 결제 서버 520에게 상기 아이템에 대한 정보를 송신할 수 있다. 일 실시 예에서, 상기 아이템에 대한 정보는, 상기 전자 장치 101으로부터 상기 결제 서버 520에게 송신되고 상기 아이템을 결제하기 위해 이용되는 결제 정보를 포함하는 메시지에 함께 포함되어 송신될 수 있다. 다른 실시 예에서, 상기 아이템에 대한 정보는, 상기 전자 장치 101으로부터 상기 결제 서버 520에게 송신되는 결제 정보를 포함하는 메시지와 다른 별도의 메시지에 포함되어 송신될 수 있다. 이러한 경우, 상기 아이템에 대한 정보를 포함하는 메시지의 송신 시점은 다양하게 설정될(configured) 수 있다. 예를 들면, 상기 아이템에 대한 정보를 포함하는 메시지는, 상기 결제 정보를 포함하는 메시지의 송신 직전 또는 직후에 송신될 수 있다. 다른 예를 들면, 상기 아이템에 대한 정보를 포함하는 메시지는, 상기 결제 정보를 포함하는 메시지가 송신된 시점으로부터 상기 전자 장치 101에 의해 설정된(configured) 시간이 경과한 후 송신될 수 있다. 상기 아이템에 대한 정보를 수신한 상기 결제 서버 520은, 상기 아이템에 대한 정보를 상기 빅 데이터 서버 510에게 제공할 수 있다.
다른 일부 실시 예들에서, 상기 전자 장치 101은, 상기 전자 장치 101의 사용자의 선호를 결정하기 위한 참조 데이터를 제공하기 위해, 상기 빅 데이터 서버 510에게 상기 아이템에 대한 정보를 송신할 수 있다.
상기 아이템에 대한 정보를 수신한 상기 빅 데이터 서버 510은, 상기 아이템에 대한 정보와 상기 전자 장치 101로부터(또는 상기 결제 서버 520을 통해) 수신된 이전의 아이템에 대한 정보에 기반하여, 상기 전자 장치 101의 사용자의 선호 아이템을 결정할 수 있다. 상기 빅 데이터 서버 510은 상기 전자 장치 101에게 상기 결정된 선호 아이템에 대한 정보를 송신할 수 있다. 실시 예들에 따라 상기 선호 아이템에 대한 정보는, 참조 아이템에 대한 정보로 지칭될 수 있다. 일부 실시 예들에서, 상기 참조 아이템에 대한 정보는, 미리 결정된 주기마다 상기 전자 장치 101에게 송신될 수 있다. 다른 일부 실시 예들에서, 상기 참조 아이템에 대한 정보는, 상기 참조 아이템이 변경될 때마다 상기 전자 장치 101에게 송신될 수 있다. 또 다른 일부 실시 예들에서, 상기 참조 아이템에 대한 정보는, 상기 전자 장치 101으로부터 요청 메시지를 수신하는 것에 기반하여 송신될 수도 있다.
상기 전자 장치 101은, 상기 빅 데이터 서버 510으로부터 상기 참조 아이템에 대한 정보를 수신할 수 있다. 또한, 상기 전자 장치 101은 상기 참조 아이템에 대한 정보를 저장할 수 있다.
상기 전자 장치 101은, 상기 빅 데이터 서버 510이 현재 이슈가 되고 있는 아이템에 대한 정보를 포함하는 알림 메시지의 송신할 것인지 여부를 결정할 수 있도록, 상기 아이템에 대한 정보를 송신할 수 있다. 다시 말해, 상기 전자 장치 101은, 상기 빅 데이터 서버 510이 현재 결제가 급증하고 있는 아이템이 무엇인지 여부를 모니터링할 수 있도록, 상기 아이템에 대한 정보를 송신할 수 있다.
동작 630에서, 상기 전자 장치 101(예: 프로세서 120 등)은, 상기 빅 데이터 서버 510으로부터 알림 메시지를 수신할 수 있다.
상기 알림 메시지는 다양한 데이터를 포함할 수 있다. 예를 들면, 상기 알림 메시지는, 구매가 급증하고 있는 아이템의 식별 데이터(예: 아이템의 이름, 아이템의 브랜드명, 아이템의 상표, 아이템의 이미지 등), 구매가 급증하고 있는 아이템의 판매 출처를 나타내기 위한 데이터(예: 오프라인 매장 주소, 온라인 웹 사이트 주소 등), 구매가 급증하고 있는 아이템의 가격 데이터, 구매가 급증하고 있는 아이템의 할인율, 구매가 급증하고 있는 아이템의 프로모션 기간에 대한 데이터 등을 포함할 수 있다.
상기 알림 메시지는, 특정 조건(specific condition)이 만족(satisfy)되는 것에 기반하여 상기 빅 데이터 서버 510으로부터 상기 전자 장치 101에게 송신될 수 있다. 상기 특정 조건은 다양하게 설정될 수 있다. 예를 들면, 상기 빅 데이터 서버 510은 상기 전자 장치 101과 같은 전자 장치들 각각으로부터 수신되는 아이템에 대한 정보를 모니터링하거나 분석할 수 있다. 상기 모니터링 결과 미리 결정된 시구간 동안 동일한 아이템에 대한 수신 빈도가 기준치 이상인 경우, 상기 빅 데이터 서버 510은 상기 알림 메시지를 송신할 수 있다. 다른 예를 들면, 상기 빅 데이터 서버 510은 전자 장치로부터 수신되는 아이템에 대한 정보에 포함된 상기 아이템의 현재 가격 데이터와 상기 빅 데이터 서버 510에 저장된 상기 아이템의 이전 가격 데이터를 비교할 수 있다. 상기 현재 가격 데이터와 상기 이전 가격 데이터 사이의 차이가 임계값 이상인 경우, 상기 빅 데이터 서버 510은, 상기 알림 메시지를 송신할 수 있다. 또 다른 예를 들면, 상기 빅 데이터 서버 510은 특정 아이템에 대한 정보의 이전 수신 빈도와 상기 특정 아이템에 대한 정보의 현재 수신 빈도를 비교할 수 있다. 상기 이전 수신 빈도와 상기 현재 수신 빈도 사이의 차이가 임계치 이상인 경우, 상기 빅 데이터 서버 510은 상기 알림 메시지를 송신할 수 있다. 하지만, 상기 알림 메시지의 송신 조건은 이에 한정되지 않는다.
상기 알림 메시지는, 다양한 전송 방식을 통해 송신될 수 있다. 일부 실시 예들에서, 상기 알림 메시지는, 전자 장치들 각각 별로 유니캐스트될 수 있다. 상기 알림 메시지가 상기 전자 장치 101에게 유니캐스트되는 경우, 상기 전자 장치 101은 상기 알림 메시지를 상기 전자 장치 101의 상기 디스플레이 160에서 표시할 수 있다. 또한, 상기 알림 메시지를 표시한 상기 전자 장치 101은, 상기 표시된 알림 메시지에 대한 사용자의 입력을 검출하는 것에 대응하여, 상기 알림 메시지에 포함된 아이템의 출처를 나타내기 위한 데이터에 기반하여 상기 아이템을 구매하기 위한 정보를 제공하는 화면을 상기 디스플레이 160에서 표시할 수 있다. 다시 말해, 상기 전자 장치 101은, 상기 표시된 알림 메시지에 대한 사용자의 입력을 검출하는 것에 대응하여, 상기 알림 메시지에 포함된 아이템을 판매하는 웹 사이트 등에 접속할 수 있다.
다른 일부 실시 예들에서, 상기 알림 메시지는, 상기 빅 데이터 서버 510과 관련된 전자 장치들에게 방송(또는 멀티캐스트)될 수 있다. 상기 알림 메시지가 멀티캐스트되는 경우, 상기 전자 장치 101은, 상기 알림 메시지가 유니캐스트되는 경우와 달리, 수신된 알림 메시지를 처리하기 위한 추가 동작을 수행할 수 있다. 예를 들면, 상기 전자 장치 101은, 상기 알림 메시지에 포함된 아이템에 대한 데이터와 상기 전자 장치 101에 저장된 참조 데이터을 비교함으로써, 상기 알림 메시지에 포함된 아이템이 상기 전자 장치 101에 저장된 참조 데이터에 대응하는지 여부를 결정할 수 있다. 상기 알림 메시지에 포함된 아이템이 상기 참조 데이터에 대응하는 경우(또는 상기 알림 메시지에 포함된 아이템이 상기 참조 데이터에 포함되는 경우), 상기 전자 장치 101은, 상기 알림 메시지를 상기 디스플레이 160에 표시할 수 있다. 이와 달리, 상기 알림 메시지에 포함된 아이템이 상기 참조 데이터에 대응하지 않는 경우(또는 상기 알림 메시지에 포함된 아이템이 상기 참조 데이터에 포함되지 않은 경우), 상기 전자 장치 101은 상기 알림 메시지를 상기 디스플레이 160에 표시하지 않을 수 있다. 상기 알림 메시지를 상기 디스플레이 160에 표시하지 않는 경우, 상기 전자 장치 101은 상기 알림 메시지에 대한 정보를 처리하기 위한 추가적인 동작을 수행할 수 있다. 예를 들면, 상기 전자 장치 101은 상기 알림 메시지에 대한 정보를 상기 전자 장치 101 내에 임시적으로 저장하거나, 상기 알림 메시지를 폐기할 수 있다. 하지만, 상기 알림 메시지에 대한 정보를 처리하는 상기 전자 장치 101의 추가 동작은, 이에 한정되지 않는다.
상술한 바와 같이, 다양한 실시 예들에 따른 상기 전자 장치 101은 상기 전자 장치 101의 사용자가 구매한 아이템이 무엇인지를 특정하고, 특정된 아이템에 대한 정보(또는, 특정된 아이템을 식별하기 위한 정보)를 다른 개체에게 제공할 수 있다.
또한, 다양한 실시 예들에 따른 상기 빅 데이터 서버 510은 상기 전자 장치 101 등과 같은 복수의 전자 장치들로부터 수신되는 아이템에 대한 정보에 기반하여 상기 복수의 전자 장치들 각각의 사용자의 선호도를 인지할 수 있다. 또한, 상기 빅 데이터 서버 510은, 상기 인지된 사용자의 선호도에 대한 정보를 참조 데이터로 상기 복수의 전자 장치들 각각에게 제공할 수 있다. 또한, 상기 빅 데이터 서버 510은, 상기 복수의 전자 장치들로부터 수신되는 아이템에 대한 정보에 기반하여, 특정 출처에 제한 받지 않고, 현재 구매가 급증하고 있는 아이템이 무엇인지를 파악하거나, 이벤트를 진행하고 있는 아이템이 무엇인지를 파악할 수 있다. 상기 빅 데이터 서버 510은, 상기 복수의 전자 장치들 각각의 사용자가 아이템에 대한 쇼핑을 수행할 수 있도록, 이러한 아이템에 대한 정보를 포함하는 알림 메시지를 상기 빅 데이터 서버 510과 연관된 상기 복수의 전자 장치들에게 송신할 수 있다. 또한, 상기 빅 데이터 서버 510은, 상기 빅 데이터 서버 510과 연관되고, 아이템을 제공하거나 판매하는 출처(예를 들면, 쇼핑몰 사이트 등)에게 서비스를 제공할 수 있다.
도 7은, 다양한 실시 예들에 따라 웹 정보에 기반하여 아이템에 대한 정보를 결정하는 전자 장치의 동작의 예를 도시한다. 이러한 동작은, 도 1에 도시된 상기 전자 장치 101 또는 상기 프로세서 120 등과 같은 상기 전자 장치 101의 구성 요소에 의해 수행될 수 있다.
도 7을 참조하면, 동작 710에서, 상기 전자 장치 101(예:프로세서 120)은 상기 전자 장치 101이 접속하는 복수의 웹들에 대한 정보를 저장할 수 있다.
일부 실시 예들에서, 상기 전자 장치 101은 상기 전자 장치 101이 접속하는 복수의 웹들에 대한 정보를 임시적으로 저장할 수 있다. 일 실시 예에서, 상기 전자 장치 101은, 상기 전자 장치 101이 접속하는 복수의 웹들에 대한 정보를 미리 결정된 주기 동안 상기 전자 장치 101의 상기 메모리 130 등에 저장할 수 있다. 상기 미리 결정된 주기는, 상기 전자 장치 101의 설정(configuration)에 따라 서로 다른 길이를 가질 수 있다. 예를 들면, 상기 전자 장치 101은, 상기 전자 장치 101이 처리하고 있는 로드(load)의 양에 대응하는 길이로 상기 미리 결정된 주기의 길이를 설정할 수 있다. 다른 예를 들면, 상기 전자 장치 101은, 상기 미리 결정된 주기의 길이를 상기 전자 장치 101의 사용자에 의해 설정된 길이로 설정할 수 있다. 하지만, 상기 미리 결정된 주기의 길이를 설정하는 방법은, 이에 제한되지 않는다. 다른 실시 예에서, 상기 전자 장치 101은, 상기 전자 장치 101이 접속하는 복수의 웹들에 대한 정보를 사용자의 설정(setting)에 따라 상기 메모리 130 등에 저장할 수 있다. 예를 들어, 상기 전자 장치 101의 사용자가 상기 전자 장치 101이 상기 전자 장치 101의 상태가 특정 상태(예: 웹 브라우저를 종료하는 상태, 상기 전자 장치 101을 리부팅하거나 상기 전자 장치 101을 종료하는 상태)에 부합하는 경우 상기 전자 장치 101에 저장된 상기 복수의 웹들에 대한 정보를 폐기하는 것으로 설정한 경우, 상기 전자 장치 101은 상기 전자 장치 101의 상태가 상기 특정 상태에 부합하는 것에 대응하여, 상기 전자 장치 101에 저장된 상기 복수의 웹들에 대한 정보를 폐기(또는 삭제)할 수 있다. 하지만, 상기 전자 장치 101에 저장된 상기 복수의 웹들에 대한 정보를 처리하는 방법은, 이에 제한되지 않는다.
일부 실시 예들에서, 상기 전자 장치 101은, 상기 복수의 웹들에 대한 정보를 웹이 제공하는 서비스의 유형에 따라 분류하여 저장할 수 있다. 일 실시 예에서, 상기 전자 장치 101은 상기 복수의 웹들 중 거래와 관련된 서비스를 제공하는 웹에 대한 정보를 다른 서비스를 제공하는 웹에 대한 정보와 구분하여 저장할 수 있다. 예를 들면, 상기 전자 장치 101은 거래와 관련된 서비스를 제공하는 웹들의 주소에 대한 정보를 상기 전자 장치 101에 미리 저장할 수 있다. 이러한 경우, 상기 전자 장치 101은 상기 미리 저장된 정보와 상기 전자 장치 101이 접속하는 웹의 주소를 비교할 수 있다. 상기 전자 장치 101은, 상기 미리 저장된 정보에 상기 전자 장치 101이 접속하는 웹의 주소가 포함된 경우, 상기 전자 장치 101이 접속하는 웹에 대한 정보를 거래와 관련되지 않은 서비스를 제공하는 다른 웹에 대한 정보와 구분하여 저장할 수 있다. 하지만, 상기 전자 장치 101이 상기 전자 장치 101이 접속하는 웹에 대한 정보를 저장하는 방법은, 이에 한정되지 않는다.
동작 720에서, 상기 전자 장치 101(예:프로세서 120)은 상기 결제 서버 520 등과 같은 다른 개체로부터 거래가 완료됨을 나타내기 위한 메시지를 수신할 수 있다. 달리 표현하면, 상기 전자 장치 101은, 상기 다른 개체로부터 결제에 대한 정보를 수신할 수 있다. 상기 결제에 대한 정보는, 상기 전자 장치 101을 통해 거래된 아이템의 이름에 대한 데이터, 상기 아이템의 가격에 대한 데이터, 상기 아이템을 판매한 출처를 식별하기 위한 데이터, 상기 거래가 완료된 일시에 대한 데이터, 상기 결제를 수행한 수단을 식별하기 위한 데이터, 상기 결제를 수행한 수단에 의해 설정된 기간 동안 결제된 금액의 합계에 대한 데이터 등을 포함할 수 있다.
동작 730에서, 상기 전자 장치 101(예: 프로세서 120 등)은 상기 메시지가 수신된 시점에 기반하여 결정되는 시구간 동안 상기 전자 장치 101이 접속하였던 후보 웹들에 대한 정보에 기반하여 상기 거래의 아이템에 대한 정보를 결정할 수 있다. 상기 시구간의 종료점은, 상기 메시지가 수신된 시점 직전 또는 직후일 수 있고, 상기 시수간의 시작점은, 상기 시구간의 시작점보다 특정 시간 이전의 지점일 수 있다. 여기서, 상기 특정 시간은, 상기 시구간의 길이일 수 있다.
일부 실시 예들에서, 상기 시구간의 길이는 설정에 따라 서로 다른 값을 가질 수 있다. 일 실시 예에서, 상기 시구간의 길이는 사용자의 설정에 의해 결정될 수 있다. 예를 들어, 상기 전자 장치 101의 사용자가 상기 시구간의 길이를 상기 메시지가 수신된 시점보다 10분 이전의 시점부터 상기 메시지가 수신된 시점까지로 설정한 경우, 상기 전자 장치 101은 상기 메시지를 수신하는 것에 기반하여, 동작 710에서 저장된 복수의 웹들에 대한 정보 내에서 상기 메시지가 수신된 시점보다 10분 이전의 시점부터 상기 메시지가 수신된 시점까지 상기 전자 장치 101이 접속한 후보 웹들에 대한 정보를 조회할 수 있다. 상기 전자 장치 101이 상기 조회된 후보 웹들에 대한 정보에 기반하여 상기 거래의 아이템에 대한 정보를 결정할 수 있다. 다른 실시 예에서, 상기 시구간의 길이는, 상기 전자 장치 101이 학습한 통계 데이터에 기반하여 결정될 수 있다. 예를 들어, 상기 전자 장치 101의 사용자가 통상적으로 거래와 관련된 웹에 접속한 시점부터 15분이 경과된 시점 사이에 상기 접속된 웹을 통한 거래를 완료하는 경우, 상기 전자 장치 101은, 상기 전자 장치 101의 사용자가 거래와 관련된 웹을 이용하는 패턴을 학습(learn)할 수 있다. 상기 전자 장치 101은, 상기 학습된 통계 데이터에 기반하여 상기 시구간의 길이를 설정할 수 있다. 하지만, 상기 전자 장치 101이 상기 시구간의 길이를 결정하는 방법은, 이에 한정되지 않는다.
상기 후보 웹들은 상기 전자 장치 101의 설정 또는 동작 방법에 따라 서로 다르게 설정될 수 있다. 일부 실시 예들에서, 상기 후보 웹들은, 상기 전자 장치 101이 접속하였던 복수의 웹들 중에서, 상기 시구간 동안 상기 전자 장치 101이 접속하였던 웹들일 수 있다. 다른 일부 실시 예들에서, 상기 후보 웹들은, 상기 전자 장치 101이 접속하였던 복수의 웹들 중에서 구분하여 저장된 거래와 관련된 웹들 중 상기 시구간 동안 상기 전자 장치 101이 접속하였던 웹들일 수 있다. 다시 말해, 상기 전자 장치 101은, 상기 전자 장치 101에 저장된 정보에 포함된 모든 웹들이 아닌, 상기 전자 장치 101이 접속하였던 거래와 관련된 웹들 중에서 상기 시구간 동안 상기 전자 장치 101이 접속하였던 웹들만을 조회할 수 있다.
상기 전자 장치 101은, 조회된 후보 웹들에 정보에 포함된 상기 후보 웹들 중 적어도 하나의 도메인 네임에 대한 데이터, 상기 후보 웹들 중 적어도 하나의 웹 문서들에 대한 데이터에 기반하여, 상기 거래의 아이템에 대한 정보를 결정할 수 있다.
상기 도메인 네임은, 상기 전자 장치 101이 접속할 수 있고 웹 서비스를 제공하는 다양한 서버들을 구분하기 위한 IP(internet protocol) 주소의 낮은 접근성(accessibility)을 보완하기 위한 정보일 수 있다. 다시 말해, 상기 도메인 네임은, 상기 서버들 각각의 고유한 주소(예: IP 주소 등)에 대응하는 값을 가지는 데이터일 수 있다. 상기 도메인 네임은, 의미를 가지는 단어 또는 단어들의 조합으로 설정될 수 있다. 상기 도메인 네임은, 의미를 가지는 단어 또는 단어들의 조합으로 설정되기 때문에, 상기 도메인 네임을 이용하는 사용자는 보다 용이하고 직관적으로 상기 도메인 네임을 이용하여 인터넷에 접속할 수 있다. 상기 도메인 네임은, FQDN(fully qualified domain name)으로 지칭될 수도 있다.
상기 웹 문서는, 상기 전자 장치 101이 접속하는 웹을 위해 이용되는 문서일 수 있다. 예를 들면, 상기 전자 장치 101은 상기 웹 문서에 포함된 데이터에 적어도 일부 기반하여 상기 전자 장치 101이 접속한 웹에 대한 정보 또는 데이터를 상기 디스플레이 160에 표시할 수 있다. 다른 예를 들면, 상기 전자 장치 101은 상기 웹 문서에 기반하여 상기 웹에 포함된 다양한 컨텐츠들이 무엇인지를 파악할 수 있다. 예를 들면, 상기 전자 장치 101은, 상기 표시된 웹에 기재된 문자가 무엇인지, 상기 표시된 웹에 첨부된 이미지가 무엇인지, 상기 표시된 웹에 기재된 동영상이 무엇인지, 상기 표시된 웹과 연동된 다른 웹이 무엇인지 등을 파악할 수 있다. 상기 웹 문서는, HTML(hypertext markup language) 문서 또는 CSS(cascading style sheets) 문서일 수 있다. 상기 웹 문서는, DOM(document object model) 트리(tree) 포맷(format)을 가질 수 있다.
상기 전자 장치 101은, 상기 후보 웹들의 주소와 상기 전자 장치 101에 미리 저장된 거래와 관련된 웹들의 주소를 비교함으로써, 상기 후보 웹들 중에서 거래와 관련된 적어도 하나의 웹을 결정할 수 있다. 또한, 상기 전자 장치 101은 상기 결정된 적어도 하나의 웹의 웹 문서에 포함된 데이터를 분석함으로써(또는 파싱함으로써), 상기 수신된 메시지와 관련된 거래의 아이템이 무엇인지를 특정할 수 있다.
상술한 도 7에 대한 설명은, 상기 전자 장치 101이 도 7에 도시된 동작들을 수행하는 것을 예시하고 있지만, 이는 설명을 위한 예시일 뿐이다. 도 7에 도시된 동작들 중 적어도 일부는 상기 빅 데이터 서버 510과 같은 다른 개체에 의해 수행될 수 있다. 이러한 경우, 상기 전자 장치 101은 상기 빅 데이터 서버 510에게 상기 동작들 중 적어도 일부를 수행하기 위한 기준(criterion) 또는 정보를 제공할 수 있다.
상술한 바와 같이, 다양한 실시 예들에 따른 상기 전자 장치 101은, 거래가 완료됨을 나타내기 위한 메시지를 수신하는 것에 기반하여, 상기 완료된 거래의 아이템을 특정할 수 있다. 상기 전자 장치 101은, 상기 거래의 아이템을 특정하기 위해, 상기 전자 장치 101이 접속하였던 모든 웹들이 아닌, 상기 메시지가 수신된 시점에 기반하여 결정되는 시구간 동안 상기 전자 장치 101이 접속하였던 후보 웹들에 대한 처리만을 수행함으로써, 상기 전자 장치 101의 부하량(load amount)을 감소시킬 수 있다.
도 8은, 다양한 실시 예들에 따라 웹 정보에 기반하여 아이템에 대한 정보를 결정하는 전자 장치의 다른 동작의 예를 도시한다. 이러한 동작은, 도 1에 도시된 상기 전자 장치 101 또는 상기 프로세서 120 등과 같은 상기 전자 장치 101의 구성 요소에 의해 수행될 수 있다.
도 8을 참조하면, 동작 810에서, 상기 전자 장치 101(프로세서 120 등)은 완료된 거래의 아이템에 대한 정보가 수신된 메시지에 포함되어 있는지 여부를 결정하거나 식별할 수 있다. 상기 메시지는, 상기 결제 서버 520 등으로부터 상기 전자 장치 101에 수신되는 메시지일 수 있다. 상기 메시지는, 상기 전자 장치 101과 관련된 거래가 완료됨을 나타내기 위한 정보를 포함할 수 있다.
일부 실시 예들에서, 상기 전자 장치 101은 상기 메시지에 포함된 데이터를 파싱할 수 있다. 상기 전자 장치 101은, 상기 파싱된 데이터에 기반하여 상기 전자 장치 101과 관련된 거래의 아이템이 특정 가능한지 여부를 식별(identify)할 수 있다. 예를 들어, 상기 파싱된 데이터에 상기 아이템을 식별하기 위한 정보가 포함되어 있는 경우, 상기 전자 장치 101은, 상기 파싱된 데이터에 기반하여 상기 아이템을 결정할 수 있다. 이와 달리, 상기 파싱된 데이터에 상기 아이템을 식별하기 위한 정보가 포함되어 있지 않은 경우, 상기 전자 장치 101은, 상기 아이템을 결정하기 위한 다른 동작들을 수행할 수 있다. 다시 말해, 상기 완료된 거래의 아이템에 대한 정보가 수신된 메시지에 포함되어 있는 경우, 상기 전자 장치 101은 동작 820을 수행할 수 있다. 이와 달리, 상기 완료된 거래의 아이템에 대한 정보가 수신된 메시지에 포함되어 있지 않은 경우, 상기 전자 장치 101은 동작 830을 수행할 수 있다.
동작 820에서, 상기 완료된 거래의 아이템에 대한 정보가 수신된 메시지에 포함된 경우, 상기 전자 장치 101(예: 프로세서 120 등)은 상기 수신된 메시지에 기반하여 완료된 거래의 아이템을 결정할 수 있다. 상기 전자 장치 101은 상기 메시지에 포함된 데이터를 파싱할 수 있다. 일부 실시 예들에서, 상기 전자 장치 101은 상기 파싱된 데이터만을 이용하여 상기 완료된 거래의 아이템을 결정할 수 있다. 다른 일부 실시 예들에서, 상기 전자 장치 101은, 상기 파싱된 데이터만을 이용하여 결정된 거래의 아이템에 대한 정보를 보다 보완하기 위해, 상기 파싱된 데이터에 기반하여 도출되는 웹에 접속하거나 상기 빅 데이터 서버 510에 접속할 수 있다. 이러한 경우, 상기 전자 장치 101은, 상기 접속된 웹에 포함된 데이터, 상기 빅 데이터 서버 510에 포함된 데이터, 또는 상기 파싱된 데이터를 적어도 일부 조합하여, 상기 완료된 거래의 아이템을 결정할 수 있다. 하지만, 상기 전자 장치 101의 방법은 이에 한정되지 않는다.
동작 830에서, 상기 완료된 거래의 아이템에 대한 정보가 수신된 메시지에 포함되지 않은 경우, 상기 전자 장치 101(예: 프로세서 120 등)은 상기 완료된 거래가 오프라인 기반 거래인지 여부를 식별하거나 결정할 수 있다. 일부 실시 예들에서, 상기 전자 장치 101은 상기 동작 810에서 파싱된 데이터에 기반하여 상기 완료된 거래가 오프라인 기반 거래인지 여부를 식별할 수 있다. 예를 들면, 상기 전자 장치 101은, 상기 파싱된 데이터에 포함된 상기 거래의 아이템에 대한 출처 정보(예: XX 식당, YY 온라인 마트 등)에 기반하여 상기 완료된 거래가 오프라인 기반 거래인지 또는 온라인 기반 거래인지 여부를 식별할 수 있다. 다른 예를 들면, 상기 전자 장치 101은, 상기 파싱된 데이터, 상기 빅 데이터 서버 510 또는 상기 POI 서버 등으로부터 획득되는 학습 데이터, 또는 상기 전자 장치 101이 학습한 데이터 중 적어도 하나에 기반하여 상기 완료된 거래가 오프라인 기반 거래인지 또는 온라인 기반 거래인지 여부를 식별할 수 있다. 상기 상기 완료된 거래가 오프라인 기반 거래인 경우, 상기 전자 장치 101은 동작 840을 수행할 수 있다. 이와 달리, 상기 완료된 거래가 온라인 기반 거래인 경우, 상기 전자 장치 101은 동작 860을 수행할 수 있다.
동작 840에서, 상기 완료된 거래가 오프라인 기반 거래인 경우, 상기 전자 장치 101(예: 프로세서 120 등)은 수신된 메시지에 포함된 데이터와 상기 전자 장치 101의 센서에 의해 검출된 정보에 기반하여 상기 완료된 거래와 관련된 POI에 대한 정보를 결정할 수 있다.
일부 실시 예들에서, 상기 전자 장치 101은 상기 동작 810에서 파싱된 데이터를 이용하여 상기 완료된 거래의 아이템에 대한 개략적인 정보를 결정할 수 있다. 예를 들면, 상기 전자 장치 101은 상기 파싱된 데이터를 이용하여, "상기 거래의 아이템의 가격이 10000원이라는 것", 상기 아이템의 거래 장소가 "강남구의 Y 커피 전문점이라는 것" 등을 특정할 수 있다.
일부 실시 예들에서, 상기 전자 장치 101은 상기 전자 장치 101의 센서 또는 상기 전자 장치 101의 무선 통신 인터페이스를 이용하여 센싱 정보를 결정할 수 있다. 예를 들면, 상기 센싱 정보는, 상기 전자 장치 101의 GPS에 의해 획득된 상기 전자 장치 101이 위치된 지점의 좌표 데이터일 수 있다. 다른 예를 들면, 상기 센싱 정보는, 상기 전자 장치 101의 무선 통신 인터페이스를 통해 수신된 신호에 포함된 데이터일 수 있다. 상기 센싱 정보에 포함된 데이터는, 상기 수신된 신호에 포함된 다른 전자 장치(예: 기지국, AP(access point), 블루투스 신호 송신 장치 등)의 MAC(meidum access control) 주소에 대한 데이터 또는 상기 다른 전자 장치를 식별하기 위한 데이터(예: 상기 다른 전자 장치의 ID(identifier) 등)일 수 있다. 상기 전자 장치 101은 상기 센싱 정보에 기반하여 상기 완료된 거래에 관한 정보를 구체화할 수 있다. 예를 들면, 상기 전자 장치 101은, 상기 전자 장치 101과 관련된 POI 서버에게 상기 센싱 정보를 송신할 수 있다. 또한, 상기 전자 장치 101은 상기 센싱 정보와 관련된 POI 정보를 요청할 수 있다. 상기 POI 서버는, 상기 POI 서버에 저장된 데이터를 이용하여 상기 센싱 정보와 관련된 POI 정보를 결정하고, 결정된 POI 정보를 상기 전자 장치 101에게 송신할 수 있다. 예를 들면, 상기 POI 서버는, 상기 센싱 정보에 포함된 MAC 주소에 데이터와 상기 POI 서버에 저장된 정보를 비교할 수 있다. 상기 POI 서버는 상기 비교에 기반하여 상기 전자 장치 101이 위치된 장소가 "강남구 Y 커피 2호점"이라는 것을 결정할 수 있다. 상기 POI 서버는 상기 전자 장치 101이 위치된 장소가 "강남구 Y 커피 2호점"이는 것을 나타내기 위한 데이터를 상기 전자 장치 101에게 송신할 수 있다. 하지만, 상기 전자 장치 101의 방법은, 이에 한정되지 않는다.
상기 전자 장치 101은, 상기 파싱된 데이터, 상기 POI 서버로부터 수신된 데이터, 또는 이들의 조합에 적어도 일부 기반하여 상기 완료된 거래와 관련된 POI에 대한 정보를 결정할 수 있다.
동작 850에서, 상기 전자 장치 101(예: 프로세서 120 등)은 상기 결정된 POI에 대한 정보에 기반하여 상기 완료된 거래의 아이템에 대한 정보를 결정할 수 있다. 상술한 예시에 따르면, 상기 전자 장치 101이 상기 결정된 POI에 대한 정보를 분석함으로써, 상기 완료된 거래가 "강남구 Y 커피 2호점"이라는 것과 "상기 거래의 아이템의 가격이 10000원"이라는 것을 파악할 수 있다. 상기 전자 장치 101은 상기 파악된 정보에 기반하여 상기 완료된 거래의 아이템이 강남구 Y 커피 2호점에서 판매되는 10000원의 가격을 가지는 유일한 아이템인 "아이리쉬 커피"라는 것을 결정할 수 있다. 또한, 상기 전자 장치 101은 상기 파악된 정보에 기반하여 상기 완료된 거래의 아이템이 강남구 Y 커피 2호점에서 판매된 10000원의 가격을 가지는 아이템인 "그린티 프라푸치노" 또는 "화이트 초콜릿 모카"라는 것을 결정할 수 있다. 이러한 경우, 상기 전자 장치 101은 상기 완료된 거래의 아이템이 "그린티 프라푸치노" 및 "화이트 초콜릿 모카" 중 어느 것인지 여부를 문의하기 위한 메시지를 상기 디스플레이 160에 표시할 수 있다. 상기 전자 장치 101은 "그린티 프라푸치노" 및 "화이트 초콜릿 모카" 중 "그린티 프라푸치노"를 선택하기 위한 사용자의 입력을 검출하는 것에 기반하여, 상기 거래의 아이템을 "그린티 프라푸치노"로 결정할 수 있다.
다시 말해, 상기 전자 장치 101은 결제 서버 등으로부터 수신되는 메시지, 상기 전자 장치 101에 의해 수집된 정보, 또는 POI 서버로부터 수신되는 정보 중 적어도 하나를 이용하여 상기 완료된 거래가 오프라인 기반 거래인 경우에도 상기 완료된 거래의 아이템을 결정할 수 있다.
동작 860에서, 상기 완료된 거래가 오프라인 기반 거래가 아닌 경우, 상기 전자 장치 101(예: 프로세서 120 등)은 상기 메시지가 수신된 시점에 기반하여 결정되는 시구간 동안 상기 전자 장치 101이 접속하였던 복수의 웹들의 주소들 중 거래와 관련된 적어도 하나의 참조 주소에 대응하는 적어도 하나의 주소를 결정할 수 있다.
상기 참조 주소는, 상기 전자 장치 101에 미리 저장된 주소일 수 있다. 상기 참조 주소는, 복수의 웹 주소들 중에서 거래와 관련된 웹 주소가 무엇인지를 식별하기 위해 이용될 수 있다. 예를 들면, 상기 참조 주소는, "www.gomarket.com", "www.aemegon.com", "www.taubau.com", "www.alibabo.com" 등일 수 있다. 상기 참조 주소는, 상기 전자 장치 101의 출시 과정 또는 업데이트 과정에서 상기 전자 장치 101에 저장되거나, 상기 빅 데이터 서버 510 으로부터 수신되어 저장되거나, 상기 전자 장치 101의 학습에 의해 저장될 수 있다. 예를 들면, 다수의 사용자들에게 주지 저명한 쇼핑몰의 주소는, 상기 전자 장치 101의 출시 과정 또는 업데이트 과정에서 상기 참조 주소로 상기 전자 장치 101에 저장될 수 있다. 다른 예를 들면, 다수의 사용자들에게 주지 저명하지 않은 쇼핑몰의 주소는, 상기 전자 장치 101의 학습에 의해 상기 참조 주소로 상기 전자 장치 101에 저장되거나 상기 빅 데이터 서버 510의 학습에 의해 상기 참기 참조 주소로 상기 전자 장치 101에 저장될 수 있다. 하지만, 상기 참조 주소를 저장하거나 결정하는 방법은, 이에 한정되지 않는다.
상기 전자 장치 101은, 상기 전자 장치 101이 접속하였던 복수의 웹들의 주소들 중에서 상기 시구간 동안 상기 전자 장치 101이 접속하였던 웹들의 주소들을 선택하고, 상기 선택된 웹들의 주소들과 상기 적어도 하나의 참조 주소를 비교함으로써, 거래와 관련된 적어도 하나의 웹의 주소를 결정할 수 있다. 예를 들면, 상기 전자 장치 101은, 상기 전자 장치 101이 접속하였던 복수의 웹들의 주소들 A(1), ... , A(k), ... , A(n) 중에서 상기 시구간 동안 상기 전자 장치 101이 접속하였던 웹들의 주소들 A(1), A(k-1), A(k), A(k+1), A(n-1), A(n)을 선택하고, 상기 선택된 A(1), A(k-1), A(k), A(k+1), A(n-1), A(n)과 상기 전자 장치 101에 저장된 참조 주소들 B(1), B(2), B(3), B(4)를 비교할 수 있다. 상기 전자 장치 101은, A(k-1), A(k), A(k+1)이 상기 참조 주소들 B(1), B(2), B(3), B(4) 중 적어도 하나와 대응하고, A(1), A(n-1), A(n)은 상기 참조 주소들 B(1), B(2), B(3), B(4) 모두와 대응하지 않음을 결정할 수 있다. 다시 말해, 상기 전자 장치 101은, 상기 A(k-1), A(k), A(k+1)을 거래와 관련된 주소로 결정할 수 있다.
동작 870에서, 상기 전자 장치 101(예: 프로세서 120 등)은, 상기 결정된 적어도 하나의 주소와 관련된 적어도 하나의 웹 문서에 포함된 데이터를 파싱할 수 있다.
일부 실시 예들에서, 상기 웹 문서는 DOM 트리 포맷을 가질 수 있다. 상기 전자 장치 101은, 룰(rule) 기반 파싱 기법(파서 툴(parser tool)이나 라이브러리(library) 등을 이용하는 기법) 또는 학습 기반(machine learning 기반) 기법을 이용하여 상기 적어도 하나의 웹 문서에 포함된 데이터를 파싱할 수 있다.
상기 파싱된 데이터는, 공통 태그(common tag)를 포함할 수 있다.
일부 실시 예들에서, 상기 전자 장치 101은, 상기 결정된 적어도 하나의 주소와 관련된 적어도 하나의 웹 문서를 조회하기 이전에 상기 결정된 적어도 하나의 주소를 더 필터링할 수 있다. 예를 들면, 상기 전자 장치 101은, 상기 결정된 적어도 하나의 주소(예를 들면, URL(uniform resource locator))를 파싱함으로써, 상기 결정된 적어도 하나의 주소를 복수의 동작(action)들 또는 경로(path)들로 분류할 수 있다. 예를 들면, 상기 전자 장치 101은 상기 결정된 적어도 하나의 주소를 아이템 검색 동작의 주소, 아이템 상세 정보 표시 동작의 주소, 아이템 구매 동작의 주소로 분류할 수 있다. 상술한 예시에 따르면, 상기 전자 장치 101은, 상기 결정된 적어도 하나의 주소 A(k-1), A(k), A(k+1) 중 A(k-1)를 아이템 검색 동작의 주소로, A(k)를 아이템 상세 정보 표시 동작의 주소로, A(k+1)를 아이템 구매 동작의 주소로 분류할 수 있다. 이러한 경우, 상기 전자 장치 101은, 상기 완료된 거래의 아이템을 특정하기 위한 데이터를 상대적으로 많이 포함할 확률이 큰 A(k) 및 A(k+1)과 관련된 웹 문서만을 조회하고, 상기 조회된 웹 문서에 포함된 데이터만을 파싱할 수 있다.
동작 880에서, 상기 전자 장치 101(예: 프로세서 120 등)은, 상기 파싱된 데이터에 기반하여 상기 료된 거래의 아이템에 대한 정보를 결정할 수 있다. 예를 들면, 상기 전자 장치 101은 상기 파싱된 데이터에서 공통 태그를 추출할 수 있다. 상기 공통 태그는, 상기 완료된 거래의 이미지에 대한 데이터, 상기 완료된 거래의 출처에 대한 데이터, 상기 완료된 거래의 아이템의 가격에 대한 데이터, 상기 완료된 거래의 아이템의 이름, 상표, 브랜드, 용량 등에 대한 데이터 등을 포함할 수 있다. 하지만, 상기 공통 태그에 포함된 데이터는, 이에 한정되지 않는다. 상기 전자 장치 101은 상기 공통 태그에 포함된 데이터와 상기 수신된 메시지에 포함된 데이터를 비교함으로써, 상기 완료된 거래의 아이템에 대한 정보를 결정할 수 있다.
도 8에 도시하지 않았지만, 일부 실시 예들에서, 상기 전자 장치 101은 상기 결정된 거래의 아이템에 대한 정보를 더 처리할 수 있다. 예를 들면, 상기 전자 장치 101은 상기 결정된 거래의 아이템에 대한 정보를 처리함으로써, 상기 아이템의 이미지, 상기 아이템의 가격, 상기 아이템의 출처, 상기 아이템의 프로모션 기간 등을 정리하여 저장하거나, 다른 개체에게 송신할 수 있다.
상술한 도 8에 대한 설명은, 상기 전자 장치 101이 도 8에 도시된 동작들을 수행하는 것을 예시하고 있지만, 이는 설명을 위한 예시일 뿐이다. 도 8에 도시된 동작들 중 적어도 일부는 상기 빅 데이터 서버 510과 같은 다른 개체에 의해 수행될 수 있다. 이러한 경우, 상기 전자 장치 101은 상기 빅 데이터 서버 510에게 상기 동작들 중 적어도 일부를 수행하기 위한 기준(criterion) 또는 정보를 제공할 수 있다.
상술한 바와 같이, 다양한 실시 예들에 따른 상기 전자 장치 101은, 수신된 메시지, POI 데이터, 또는 웹 문서에 대한 파싱 데이터 중 적어도 하나에 기반하여 완료된 거래의 아이템을 결정할 수 있다. 또한, 상기 전자 장치 101은, 수신된 메시지, POI 데이터, 또는 웹 문서에 대한 파싱 데이터 중 적어도 하나에 기반하여 완료된 거래의 아이템을 결정함으로써, 완료된 거래의 유형이 오프라인 기반 거래인지 온라인 기반 거래인지에 관계 없이 완료된 거래의 아이템을 결정할 수 있다.
도 9는, 다양한 실시 예들에 따라 복수의 웹들의 주소들 중에서 거래와 관련된 웹 주소를 결정하는 방법을 설명하기 위한 개념도이다.
도 9를 참조하면, 개념도 900은 상기 결제 서버 520 등으로부터 거래과 완료됨을 나타내기 위한 메시지를 수신한 직전 또는 직후에 상기 전자 장치 101이 접속하였던 복수의 웹들의 주소를 나타내는 데이터 910, 상기 전자 장치 101에 미리 저장된 참조 주소들에 대한 데이터 925, 및/또는 상기 전자 장치 101에 의해 결정된 거래와 관련된 주소들에 대한 데이터 930을 포함할 수 있다. 상기 데이터 910, 상기 데이터 925, 상기 데이터 930은 상기 전자 장치 101의 상기 메모리 130에 저장된(또는 임시적으로 저장된) 데이터일 수 있다.
상기 데이터 910은, 상기 전자 장치 101이 웹 페이지에 접속한 시각을 나타내기 위한 "TIME STAMP"와 상기 웹 페이지의 주소를 나타내기 위한 "URL"에 기반하여 분류될 수 있다. 상기 전자 장치 101은 상기 데이터 910에서 상기 결제 서버 520 등으로부터 수신된 메시지의 수신 시점보다 미리 결정된 시간 이전의 데이터(즉, 상기 메시지의 수신 시점에 기반하여 결정된 시구간 동안 상기 전자 장치 101이 접속한 웹 페이지의 URL)를 분류할 수 있다. 예를 들면, 상기 전자 장치 101은, 데이터 920에 포함된 "1470298564421", "1470298672139", "1470298771377". 및 "1470298892342"의 TIME STAMP 값을 가지는 URL을 상기 메시지의 수신 시점에 기반하여 결정된 시구간 동안 상기 전자 장치 101이 접속한 웹페이지의 URL로 결정할 수 있다.
상기 전자 장치 101은, 상기 데이터 920과 상기 데이터 925를 비교할 수 있다. 예를 들면, 상기 전자 장치 101은, 상기 데이터 920에서 상기 데이터 925에 포함되지 않은 "1470298564421"의 TIME STAMP 값을 가지는 URL을 제외한 나머지 URL들을 거래와 관련된 웹 주소로 결정할 수 있다. 다시 말해, 상기 전자 장치 101은, 상기 데이터 920에서 상기 데이터 925에 포함된 ID 3에 대응하는 "gomarket"과 관련된 URL과 동일한 URL이 포함된 상기 데이터 930을 상기 거래와 관련된 URL로 결정할 수 있다.
상술한 바와 같이, 다양한 실시 예들에 따른 전자 장치 101은 상기 전자 장치 101이 접속한 복수의 웹 주소들을 참조 주소와 메시지의 수신 시점에 기반하여 필터링함으로써, 거래와 관련된 웹 페이지의 주소를 추출할 수 있다.
도 10은 다양한 실시 예들에 따라 웹 주소를 동작 별로 분류하는 방법을 설명하기 위한 개념도이다.
도 10을 참조하면, 개념도 1000은, 거래와 관련된 웹 페이지의 주소에 대한 데이터 930 및 웹 주소가 나타내는 동작(또는 경로)를 구분하기 위한 참조 데이터 1010을 포함할 수 있다. 상기 데이터 930과 상기 참조 데이터 1010은 상기 전자 장치 101의 상기 메모리 130에 저장될 수 있다.
도 10에 도시된 상기 데이터 930은, 도 9에 도시된 상기 데이터 930에 대응할 수 있다. 또한, 상기 데이터 1030은, 도 8의 860 동작에 의해 결정된 데이터일 수 있다.
상기 참조 데이터 1010은 서비스 종류를 식별하기 위한 ID, 검색 경로, 상세 경로(아이템의 상세 정보를 제공하는 경로), 구매 경로(또는 주문 경로)로 분류되어 저장될 수 있다.
상기 전자 장치 101은, 상기 데이터 930과 상기 참조 데이터 1010을 비교함으로써, 상기 데이터 930에 상기 참조 데이터 1010에 포함된 데이터가 있는지 여부를 확인할 수 있다. 예를 들면, 상기 전자 장치 101은, "1470298672139", "1470298771377", 및 "1470298892342"의 TIME STAMP 값을 가지는 URL이 상기 데이터 1010의 ID 1의 상세 경로의 "item", "detailview"을 포함함을 확인할 수 있다. 상기 전자 장치 101은 상기 확인에 기반하여 상기 데이터 930에 포함된 URL을 거래와 관련된 웹 페이지의 주소로 결정할 수 있다.
상술한 바와 같이, 다양한 실시 예들에 따른 전자 장치 101은, 웹 문서에 포함된 데이터를 파싱하는 동작을 간소화시키기 위하여, 필터링된 웹 페이지를 경로 별로 한 번 더 필터링할 수 있다.
도 11은 다양한 실시 예들에 따라 파싱된 데이터에 포함된 공통 태그의 예를 설명하기 위한 개념도이다.
도 11을 참조하면, 상기 전자 장치 101은 도 8의 동작 860 등에 따라 결정된 적어도 하나의 웹 주소와 관련된 적어도 하나의 웹 문서에 포함된 데이터를 도 8의 동작 870 등에 따라 파싱함으로써, 데이터 1100과 같은 공통 태그를 추출할 수 있다. 예를 들면, 상기 데이터 1100은 도 10에 도시된 상기 데이터 930에 포함된 URL들 중 하나의 URL과 관련된 웹 문서를 파싱함으로써 추출된 공통 태그일 수 있다.
상기 전자 장치 101은, 상기 데이터 1100을 분석할 수 있다. 예를 들면, 상기 전자 장치 101은 상기 데이터 1100을 파싱함으로써, 상기 데이터 1100 내에서 다양한 정보들을 획득할 수 있다. 예를 들면, 상기 전자 장치 101은, 상기 데이터 1100 내의 "content="XX F&B 참치캔 14,900원"을 통해 상기 완료된 거래의 아이템의 종류가 "참치캔"이라는 것, 상기 거래의 아이템의 생산자가 "XX"라는 것, 상기 거래의 아이템의 판매자가 "에프엔비"라는 것, 상기 거래의 아이템의 가격이 "14,900"이라는 것을 확인할 수 있다. 또한, 상기 전자 장치 101은, 상기 데이터 1100 내의 "content="[XX에프엔비] YY 참치 100gx12/150gx12/고추참치/꽁치고등어"를 통해 상기 완료된 거래의 아이템의 이름이 "YY 참치"이고, 상기 완료된 거래의 아이템 하나의 용량이 "100g"이고 "12개 묶음"이라는 것, 상기 아이템의 종류가 "고추참치"라는 것, 상기 아이템과 세트로 판매되는 아이템이 "꽁치고등어"라는 것을 식별할 수 있다.
상기 전자 장치 101은 상기 확인된 정보를 조합하여, 상기 완료된 거래의 아이템에 대한 정보에 "아이템의 생산자: XX", "아이템의 판매자: 에프엔비", "아이템의 종류: YY 고추참치와 꽁치고등어", "아이템의 가격: 14900원", "아이템의 판매 수량: 고추참치 100g x 12, 꽁치고등어 150g x 12"라는 정보를 포함시킴으로써, 상기 완료된 거래의 아이템에 대한 정보를 확정할 수 있다.
나아가, 상기 전자 장치 101은 상기 확정된 거래의 아이템에 대한 정보를 다른 개체에게 송신하고, 상기 확정된 거래의 아이템에 대한 정보를 상기 전자 장치 101의 상기 디스플레이 160에 표시할 수 있다.
도 12는 다양한 실시 예들에 따라 참조 아이템에 대한 정보를 결정하는 전자 장치의 동작의 예를 도시한다. 이러한 동작은, 도 1에 도시된 상기 전자 장치 101 또는 상기 프로세서 120 등과 같은 상기 전자 장치 101의 구성 요소에 의해 수행될 수 있다.
도 12를 참조하면, 동작 1200에서, 상기 전자 장치 101(예: 프로세서 120 등)은 완료된 거래의 아이템에 대한 정보를 결정하였는지 여부를 확인할 수 있다. 상기 전자 장치 101은, 상기 전자 장치 101에 저장되어 있는 참조 아이템(또는 선호 아이템)에 대한 정보를 업데이트하기 위하여, 완료된 거래의 아이템에 대한 정보를 결정하였는지 여부를 확인할 수 있다. 일부 실시 예들에서, 상기 참조 아이템은 상기 전자 장치 101의 사용자의 선호 아이템을 나타낼 수 있다. 일부 실시 예들에서, 상기 참조 아이템(또는 선호 아이템)은, 하나의 독립적인 아이템(예: 특정 상품 정보)일 수 있다. 다른 일부 실시 예들에서, 상기 참조 아이템(또는 선호 아이템)은, 완료된 거래의 아이템이 포함된 상품 카테고리일 수 있다. 예를 들어, 상기 완료된 거래의 아이템이 "XX 브랜드의 스니커즈"인 경우, 상기 참조 아이템은, 신발, XX 브랜드, 또는 스니커즈 중 적어도 하나를 나타낼 수도 있다.
완료된 거래의 아이템에 대한 정보를 결정한 경우, 상기 전자 장치 101은 동작 1210을 수행할 수 잇다. 이와 달리, 완료된 거래의 아이템에 대한 정보를 결정하지 않은 경우, 상기 전자 장치 101은 상기 동작 1200을 반복적으로 수행할 수 있다. 다시 말해, 완료된 거래의 아이템에 대한 정보를 결정하지 않은 경우, 상기 전자 장치 101은 완료된 거래의 아이템에 대한 정보를 결정하는지 여부를 지속적으로 모니터링할 수 있다.
동작 1210에서, 완료된 거래의 아이템에 대한 정보를 결정하는 것에 대응하여, 상기 전자 장치 101(예: 프로세서 120 등)은 결정된 아이템에 대한 정보를 저장(또는 임시적으로 저장)할 수 있다. 상기 전자 장치 101은 상기 전자 장치 101에 저장된 참조 아이템에 대한 정보를 업데이트하기 위하여, 상기 결정된 아이템에 대한 정보를 저장할 수 있다.
동작 1220에서, 상기 전자 장치 101(예: 프로세서 120 등)은 상기 저장된 참조 아이템에 대한 정보와 동작 1210에서 저장된 상기 아이템에 대한 정보에 기반하여 적어도 하나의 참조 아이템에 대한 정보를 결정할 수 있다. 다시 말해, 상기 전자 장치 101이 상기 전자 장치 101에 저장된 누적 데이터와 상기 전자 장치 101에서 새롭게 생성된 데이터를 조합함으로써, 상기 적어도 하나의 참조 아이템에 대한 정보를 결정할 수 있다.
동작 1230에서, 상기 전자 장치 101(예: 프로세서 120 등)은 상기 결정된 적어도 하나의 참조 아이템에 대한 정보에 기반하여 이전에 저장된 참조 아이템에 대한 정보를 업데이트할 수 있다. 예를 들면, 상기 전자 장치 101은 이전에 저장된 참조 아이템 A, B, C에 동작 1220을 통해 결정된 참조 아이템 D를 부가함으로써, 상기 참조 아이템에 대한 정보를 업데이트할 수 있다. 다른 예를 들면, 상기 전자 장치 101은 이전에 저장된 참조 아이템 A, B, C 중 참조 아이템 B를 폐기(또는 삭제)하고, 동작 1220을 통해 결정된 참조 아이템 D를 부가함으로써, 상기 참조 아이팀에 대한 정보를 업데이트할 수 있다.
상술한 바와 같이, 다양한 실시 예들에 따른 상기 전자 장치 101은, 상기 전자 장치 101의 사용자의 선호도를 반영하기 위하여, 참조 아이템을 결정하고, 업데이트할 수 있다. 또한, 상기 전자 장치 101은, 상기 빅 데이터 서버 510 등과 같은 다른 개체로부터 수신되는 알림 메시지의 표시 여부를 결정하기 위하여, 상기 참조 아이템을 결정하고 업데이트할 수 있다.
도 13은 다양한 실시 예들에 따라 참조 아이템에 대한 정보를 결정하는 빅 데이터 서버와 전자 장치 사이의 신호 흐름의 예를 도시한다. 이러한 신호 흐름은, 도 1에 도시된 전자 장치 101, 상기 프로세서 120 등과 같은 상기 전자 장치 101의 구성 요소, 도 5에 도시된 상기 빅 데이터 서버 510, 또는 상기 빅 데이터 서버 510의 구성 요소에 의해 야기될 수 있다.
도 13을 참조하면, 동작 1310에서, 상기 전자 장치 101(예: 프로세서 120 등)은, 완료된 거래의 아이템에 대한 정보를 상기 빅 데이터 서버 510에게 송신할 수 있다. 일부 실시 예들에서, 상기 아이템에 대한 정보는, 상기 전자 장치 101이 상기 완료된 거래의 아이템에 대한 정보를 결정할 때마다 상기 빅 데이터 서버 510에게 송신될 수 있다. 다른 일부 실시 예들에서, 상기 아이템에 대한 정보는, 상기 전자 장치 101, 상기 빅 데이터 서버 510, 또는 상기 전자 장치 101 및 상기 빅 데이터 서버 510 사이의 협상에 의해 결정된 주기마다 상기 빅 데이터 서버 510에게 송신될 수 있다. 상기 결정된 주기 동안 상기 전자 장치 101에 의해 상기 아이템에 대한 정보가 결정되지 않은 경우, 상기 전자 장치 101은 상기 아이템에 대한 정보를 송신하지 않거나, 상기 아이템에 대한 정보에 NULL 값을 나타내는 데이터를 포함하여 송신할 수 있다. 또 다른 일부 실시 예들에서, 상기 아이템에 대한 정보는, 상기 전자 장치 101의 동작 상태가 특정 상태에 도달하는 것에 기반하여 상기 빅 데이터 서버 510에게 송신될 수 있다. 예를 들어, 상기 전자 장치 101의 부하량이 임계치 미만인 경우, 상기 전자 장치 101은 상기 아이템에 대한 정보를 상기 빅 데이터 서버 510에게 송신할 수 있다. 하지만, 상기 아이템에 대한 정보가 송신될 조건은 이에 한정되지 않는다. 상기 빅 데이터 서버 510은 상기 전자 장치 101로부터 상기 아이템에 대한 정보를 수신할 수 있다.
동작 1320에서, 상기 빅 데이터 서버 510(예: 빅 데이터 서버 510 내의 프로세서 등)은 상기 수신된 아이템에 대한 정보를 저장할 수 있다. 상기 빅 데이터 서버 510은, 상기 전자 장치 101의 사용자의 선호도를 파악하기 위해 또는 상기 전자 장치 101을 위한 참조 데이터에 대한 정보를 결정하기 위해, 상기 수신된 아이템에 대한 정보를 저장할 수 있다.
동작 1330에서, 상기 빅 데이터 서버 510(예: 빅 데이터 서버 510 내의 프로세서 등)은 상기 저장된 정보에 기반하여 상기 전자 장치 101을 위한 적어도 하나의 참조 아이템에 대한 정보를 결정할 수 있다. 상기 전자 장치 101을 위해 이전에 상기 빅 데이터 서버 510 내에 저장된 참조 아이템에 대한 정보가 있는 경우, 상기 빅 데이터 서버 510은 상기 이전에 저장된 참조 아이템에 대한 정보와 상기 저장된 아이템에 대한 정보에 기반하여 상기 전자 장치 101을 위한 적어도 하나의 참조 아이템을 결정할 수 있다. 다시 말해, 상기 빅 데이터 서버 510은, 상기 빅 데이터 서버 510에 기존에 저장된 정보와 상기 빅 데이터 서버 510에 새롭게 유입된 정보에 기반하여 상기 전자 장치 101을 위한 적어도 하나의 참조 데이터를 결정할 수 있다.
동작 1340에서, 상기 빅 데이터 서버 510(예: 빅 데이터 서버 510 내의 프로세서 등)은 상기 결정된 적어도 하나의 참조 아이템에 대한 정보를 상기 전자 장치 101에게 송신할 수 있다. 일부 실시 예들에서, 상기 적어도 하나의 참조 아이템에 대한 정보는 상기 적어도 하나의 참조 아이템에 대한 정보의 업데이트가 발생할 때마다 상기 빅 데이터 서버 510으로부터 상기 전자 장치 101에게 송신될 수 있다. 다른 일부 실시 예들에서, 상기 적어도 하나의 참조 아이템에 대한 정보는, 상기 전자 장치 101, 상기 빅 데이터 서버 510, 상기 전자 장치 101 또는 상기 빅 데이터 서버 510 사이의 협상에 기반하여 결정된 주기마다 상기 빅 데이터 서버 510으로부터 상기 전자 장치 101에게 송신될 수 있다. 또 다른 일부 실시 예들에서, 상기 적어도 하나의 참조 아이템에 대한 정보는, 시간대 별로 송신될 수 있다. 예를 들면, 상기 빅 데이터 서버 510은 상기 전자 장치 101의 로드량이 상대적으로 적은 새벽 시간대에 상기 적어도 하나의 참조 아이템에 대한 정보를 송신할 수 있다. 하지만, 상기 적어도 하나의 참조 아이템에 대한 정보의 송신 조건은 이에 제한되지 않는다.
상기 전자 장치 101(예: 프로세서 120 등)은 상기 빅 데이터 서버 510으로부터 상기 적어도 하나의 참조 아이템에 대한 정보를 수신할 수 있다.
실시 예들에 따라, 동작 1330 및/또는 동작 1340은 생략될 수 있다. 예를 들어, 상기 빅 데이터 서버 510으로부터 송신되는 알림 메시지가 유니캐스트 형식으로 송신되는 경우, 상기 빅 데이터 서버 510은 상기 동작 동작 1330 및/또는 동작 1340을 수행하지 않을 수 있음을 유의하여야 한다.
동작 1350에서, 상기 전자 장치 101(예: 프로세서 120 등)은, 상기 수신된 적어도 하나의 참조 아이템에 대한 정보를 상기 전자 장치 101의 상기 메모리 130 등에 저장(또는 임시적으로 저장)할 수 있다. 상기 저장된 적어도 하나의 참조 아이템에 대한 정보는 상기 알림 메시지의 표시 여부를 결정하기 위한 기준으로 이용될 수 있다.
상술한 바와 같이, 다양한 실시 예들에 따른 상기 빅 데이터 서버 510은 상기 전자 장치 101을 위한 참조 아이템에 대한 정보를 결정할 수 있다. 이러한 동작을 통해, 상기 빅 데이터 서버 510은 특정 쇼핑몰에 제한받지 않고 상기 전자 장치 101의 사용자의 특성 또는 선호도를 파악할 수 있다.
도 14는 다양한 실시 예들에 따라 참조 아이템에 대한 정보를 결정하는 빅 데이터 서버, 결제 서버, 및 전자 장치 사이의 신호 흐름의 예를 도시한다. 이러한 신호 흐름은, 도 1에 도시된 전자 장치 101, 상기 프로세서 120 등과 같은 상기 전자 장치 101의 구성 요소, 도 5에 도시된 상기 결제 서버 520, 상기 결제 서버 520의 구성 요소, 도 5에 도시된 상기 빅 데이터 서버 510, 또는 상기 빅 데이터 서버 510의 구성 요소에 의해 야기될 수 있다.
도 14를 참조하면, 동작 1410에서, 상기 전자 장치 101(예: 프로세서 120 등)은 상기 결제 서버 520에게 아이템에 대한 정보를 포함하는 결제 정보를 송신할 수 있다. 달리 표현하면, 상기 전자 장치 101은 상기 결제 서버 520에게 상기 아이템에 대한 정보를 포함하는 거래를 완료하기 위한 메시지를 송신할 수 있다. 상기 결제 정보는, 상기 전자 장치 101에 저장된 모바일 결제 서비스를 위한 어플리케이션을 통해 송신될 수 있다. 예를 들면, 상기 결제 정보는 상기 전자 장치 101에 저장된 모바일 결제 어플리케이션을 통해 송신될 수 있다.
상기 결제 서버 520(예: 상기 결제 서버 520 내의 프로세서 등)은 상기 전자 장치 101로부터 상기 아이템에 대한 정보를 포함하는 결제 정보를 수신할 수 있다.
동작 1410은 상기 아이템에 대한 정보가 상기 결제 정보에 포함되어 송신되는 시그널링을 예시하고 있지만, 이는 설명을 위한 예시일 뿐이다. 상기 아이템에 대한 정보는 상기 결제 정보의 송신 절차와 다른 별도의 송신 절차를 통해 송신될 수도 있다.
동작 1420에서, 상기 결제 서버 520(예: 상기 결제 서버 520 내의 프로세서 등)은 상기 수신된 아이템에 대한 정보를 상기 빅 데이터 서버 510에게 제공할 수 있다. 다시 말해, 상기 결제 서버 520은 상기 수신된 아이템에 대한 정보를 상기 빅 데이터 서버 510에게 송신할 수 있다. 일부 실시 예들에서, 상기 결제 서버 520은 상기 수신된 아이템에 대한 정보를 더 처리하여 상기 빅 데이터 서버 510에게 송신할 수도 있다. 상기 빅 데이터 서버 510은 상기 아이템에 대한 정보를 상기 결제 서버 520으로부터 수신할 수 있다.
동작 1430 내지 동작 1460은 도 13에 도시된 동작 1320 내지 동작 1350에 대응할 수 있다.
상술한 바와 같이, 다양한 실시 예들에 따른 상기 전자 장치 101이 모바일 결제 서비스를 위한 어플리케이션을 이용하여 거래를 수행하는 경우, 다양한 실시 예들에 따른 상기 빅 데이터 서버 510은 상기 결제 서버 520 등을 통해 상기 거래의 아이템에 대한 정볼르 수신함으로써, 상기 전자 장치 101을 위한 참조 아이템에 대한 정보를 결정할 수 있다. 이러한 동작을 통해, 상기 빅 데이터 서버 510은 특정 쇼핑몰에 제한받지 않고, 상기 전자 장치 101의 사용자의 특성 또는 선호도를 파악할 수 있다.
도 15는 다양한 실시 예들에 따라 알림 메시지를 수신하는 전자 장치, 빅 데이터 서버, 결제 서버 사이의 신호 흐름의 예를 도시한다. 이러한 신호 흐름은, 도 1에 도시된 전자 장치 101, 상기 프로세서 120 등과 같은 상기 전자 장치 101의 구성 요소, 도 5에 도시된 상기 결제 서버 520, 상기 결제 서버 520의 구성 요소, 도 5에 도시된 상기 빅 데이터 서버 510, 또는 상기 빅 데이터 서버 510의 구성 요소에 의해 야기될 수 있다.
도 15를 참조하면, 동작 1501에서 전자 장치 1500-1 내지 전자 장치 1500-N 각각(예: 전자 장치 1500-1 내지 전자 장치 1500-N 내의 프로세서 등)은 전자 장치 1500-1 내지 전자 장치 1500-N 각각의 사용자가 구매하고자 하는 아이템에 대한 정보를 포함하는 거래를 완료하기 위한 정보를 상기 결제 서버 520에게 송신할 수 있다. 다시 말해, 상기 전자 장치 1500-1 내지 전자 장치 1500-N 각각은 동작 610 등에 의해 결정된 상기 아이템에 대한 정보를 포함하는 결제 정보를 상기 결제 서버 520에게 송신할 수 있다. 상기 결제 서버 520은 상기 아이템에 대한 정보를 포함하는 상기 결제 정보를 상기 전자 장치 1500-1 내지 전자 장치 1500-N 각각으로부터 수신할 수 있다.
동작 1502에서, 상기 결제 서버 520(예: 상기 결제 서버 520 내의 프로세서 등)은 상기 수신된 아이템에 대한 정보를 상기 빅 데이터 서버 510에게 제공할 수 있다. 상기 빅 데이터 서버 510은 상기 아이템에 대한 정보를 상기 결제 서버 520으로부터 수신할 수 있다.
동작 1503에서, 상기 결제 서버 520(예: 상기 결제 서버 520 내의 프로세서 등)은 상기 전자 장치 1500-1 내지 전자 장치 1500-N 각각에게 상기 거래가 완료됨을 나타내기 위한 메시지를 송신할 수 있다. 다시 말해, 상기 결제 서버 520은 상기 전자 장치 1500-1 내지 전자 장치 1500-N 각각에게 상기 거래에 대한 정보를 송신할 수 있다. 상기 전자 장치 1500-1 내지 전자 장치 1500-N 각각은 상기 결제 서버 520으로부터 상기 거래에 대한 정보(또는 상기 거래가 완료됨을 나타내기 위한 메시지)를 수신할 수 있다.
도 15는 동작 1502 이후에 동작 1503이 수행됨을 예시하고 있지만, 이는 설명을 위한 것이다. 실시 예들에 따라, 동작 1502 및 동작 1503은 동시에 수행될 수도 있고, 순서와 관계없이 수행될 수도 있다.
동작 1510에서, 상기 빅 데이터 서버 510(예: 상기 빅 데이터 서버 510 내의 프로세서 등)은 동작 1502 등을 통해 수집된 정보에 기반하여 알림 메시지를 송신할 것을 결정할 수 있다.
일부 실시 예들에서, 상기 빅 데이터 서버 510은 상기 수집된 정보에 기반하여 상기 알림 메시지를 송신할 것인지 여부를 결정할 수 있다. 일 실시 예에서, 상기 빅 데이터 서버 510은, 일정 주기 동안 수신되는 정보에 공통된 아이템이 포함되어 있는 빈도가 임계치 이상이라는 것을 확인할 수 있다. 상기 빅 데이터 서버 510은 상기 확인에 기반하여, 상기 알림 메시지를 송신할 것을 결정할 수 있다. 하지만, 상기 빅 데이터 서버 510의 알림 메시지의 송신 조건은, 이에 한정되지 않는다. 다른 실시 예에서, 상기 빅 데이터 서버 510은, 상기 수집된 정보에 기반하여 아이템 A의 프로모션 기간이 2017. 01. 10부터 2017. 01.20까지임을 인지할 수 있다. 상기 빅 데이터 서버 510은 상기 인지에 기반하여 상기 알림 메시지를 송신할 것을 결정할 수 있다. 하지만, 상기 빅 데이터 서버 510의 알림 메시지의 송신 조건은, 이에 한정되지 않는다.
다른 일부 실시 예들에서, 상기 빅 데이터 서버 510은 새롭게 수신되는 아이템에 대한 정보와 이전에 저장된 아이템에 대한 정보를 비교할 수 있다. 또한, 상기 빅 데이터 서버 510은 상기 비교 결과에 기반하여, 상기 알림 메시지를 송신할 것을 결정할 수 있다. 예를 들면, 상기 빅 데이터 서버 510은 상기 빅 데이터 서버 510에 이미 저장된 정보로부터 아이템 A의 가격이 15000원이라는 것을 파악하고, 상기 수집된(새롭게 수신된) 정보로부터 상기 아이템 A의 9000원이라는 것을 파악할 수 있다. 상기 빅 데이터 서버 510은 상기 아이템 A의 이전 가격과 현재 가격의 차이가 6000원임을 인지할 수 있다. 또한, 상기 빅 데이터 서버 510은 상기 가격의 차이가 미리 저장된 상기 아이템 A의 임계치 5000원보다 크다는 것을 인지할 수 있다. 이러한 경우, 상기 빅 데이터 서버 510은 상기 알림 메시지를 송신할 것을 결정할 수 있다. 상술한 예시를 이용하여 다른 예를 들면, 상기 빅 데이터 서버 510은 상기 아이템이 40% 할인 중임을 인지할 수 있다. 또한, 상기 빅 데이터 서버 510은 상기 아이템의 할인율(40%)이 상기 아이템의 임계 할인율(30%)보다 크다는 것을 인지할 수 있다. 이러한 경우, 상기 빅 데이터 서버 510은 상기 알림 메시지를 송신할 것을 결정할 수 있다. 하지만, 상기 빅 데이터 서버 510의 알림 메시지의 송신 조건은, 이에 한정되지 않는다.
동작 1511에서, 상기 빅 데이터 서버 510(예: 상기 빅 데이터 서버 510 내의 프로세서 등)은 상기 알림 메시지를 송신할 것을 결정하는 것에 기반하여, 상기 전자 장치 101 및 상기 전자 장치 1500-1 내지 1500-N에게 알림 메시지를 송신할 수 있다. 다시 말해, 상기 빅 데이터 서버 510은 상기 알림 메시지를 브로트캐스트 또는 멀티캐스트할 수 있다. 상기 알림 메시지는, 상기 수집된 정보에 기반하여 결정된 적어도 하나의 아이템에 대한 정보를 포함할 수 있다. 상기 전자 장치 101 및 상기 전자 장치 1500-1 내지 1500-N은 상기 빅 데이터 서버 510으로부터 상기 알림 메시지를 수신할 수 있다.
일부 실시 예들에서, 상기 빅 데이터 서버 510이 상기 알림 메시지를 방송하는 동작 1511과 달리, 상기 알림 메시지를 유니캐스트할 수 있다. 이러한 경우, 상기 빅 데이터 서버 510은 상기 빅 데이터 서버 510에 저장된 각 전자 장치 별 참조 아이템에 대한 정보와 상기 알림 메시지에 포함될 아이템에 대한 정보를 비교할 수 있다. 상기 빅 데이터 서버 510은, 상기 비교 결과에 기반하여, 상기 빅 데이터 서버 510에 포함된 복수의 전자 장치들 중에서 상기 알림 메시지에 포함될 아이템에 대응하는 참조 아이템을 가지는 전자 장치를 결정할 수 있다. 상기 빅 데이터 서버 510은, 상기 결정된 전자 장치에게 상기 알림 메시지를 유니캐스트할 수 있다.
동작 1512에서, 상기 전자 장치 101(예: 프로세서 120 등)은 상기 알림 메시지에 포함된 아이템이 상기 전자 장치를 위한 적어도 하나의 참조 아이템에 대응하는지 여부를 결정할 수 있다. 상기 적어도 하나의 참조 아이템은 도 12에 도시된 방법, 도 13에 도시된 방법, 또는 도 14에 도시된 방법에 의해 결정될 수 있다. 상기 전자 장치 101은 상기 알림 메시지에 포함된 아이템이 상기 전자 장치 101과 관련되는(또는 상기 전자 장치 101의 사용자의 선호도에 부합하는) 아이템인지 여부를 결정하기 위하여, 상기 알림 메시지에 포함된 아이템이 상기 전자 장치를 위한 적어도 하나의 참조 아이팀에 대응하는지 여부를 결정할 수 있다. 상기 아이템이 상기 전자 장치를 위한 적어도 하나의 참조 아이템에 대응하는 경우, 상기 전자 장치 101은 동작 1513을 수행할 수 있다. 이와 달리, 상기 아이템이 상기 전자 장치를 위한 적어도 하나의 참조 아이템에 대응하지 않는 경우, 상기 전자 장치 101은 동작 1514를 수행할 수 있다.
동작 1513에서, 상기 아이템이 상기 전자 장치를 위한 적어도 하나의 참조 아이템에 대응하는 경우, 상기 전자 장치 101(예: 프로세서 120 등)은, 상기 알림 메시지를 표시할 수 있다. 상기 표시된 알림 메시지는 이벤트가 발생한 아이템에 대한 정보를 포함할 수 있다. 상기 전자 장치 101의 사용자는 상기 표시된 알림 메시지를 통해, 어떤 아이템이 현재 얼마나 할인된 가격으로 어디서 판매되고 있는지, 상기 어떤 아이템의 프로모션 기간이 언제까지인지, 상기 어떤 아이템의 재고량이 얼마나 남아 있는지 등을 인지할 수 있다. 실시 예들에 따라, 상기 전자 장치 101은, 상기 표시된 알림 메시지에 포함된 아이콘 또는 객체에 대한 입력을 검출하는 것에 기반하여, 상기 아이템을 구매하기 위한 서버에 접속할 수 있다. 예를 들면, 상기 전자 장치 101은 상기 객체에 대한 입력을 검출하는 것에 기반하여, 상기 아이템을 판매하는 판매자가 제공하는 웹 페이지를 상기 전자 장치 101의 상기 디스플레이 160에서 디스플레이할 수 있다. 다른 예를 들면, 상기 전자 장치 101은 상기 객체에 대한 입력을 검출하는 것에 기반하여, 상기 아이템을 판매하는 판매자로부터 제공되는 어플리케이션을 실행시키고, 상기 실행된 어플리케이션을 위한 사용자 인터페이스(UI, user interface)를 표시할 수 있다.
상기 알림 메시지는, 다양한 방법들에 의해 상기 전자 장치 101의 사용자의 주의를 환기시킬 수 있다. 예를 들면, 상기 알림 메시지는, 햅틱, 소리, 인디케이터의 점등 등의 형태로 제공될 수도 있다. 하지만, 상기 알림 메시지를 제공하기 위한 방법은, 이에 한정되지 않는다.
동작 1514에서, 상기 아이템이 상기 전자 장치를 위한 적어도 하나의 참조 아이템에 대응하지 않는 경우, 상기 전자 장치 101(예: 프로세서 120 등)은, 상기 알림 메시지를 폐기(discard)할 수 있다. 상기 아이템이 상기 전자 장치 101을 위한 적어도 하나의 참조 아이템에 대응하지 않는다는 것은 상기 아이템과 상기 전자 장치 101의 사용자의 선호도 사이의 관계가 연관성이 없다는 것을 나타낼 수 있다. 따라서, 상기 전자 장치 101은, 상기 알림 메시지를 폐기할 수 있다. 일부 실시 예들에서, 상기 전자 장치 101은, 도 15의 도시와 달리, 상기 알림 메시지를 미리 결정된 주기 동안 저장한 후 폐기할 수도 있다, 또한 다른 일부 실시 예들에서, 상기 전자 장치 101은, 도 15의 도시와 달리, 상기 전자 장치 101의 상기 디스플레이 160에서 상기 알림 메시지를 표시할 수도 있다.
상술한 바와 같이, 다양한 실시 예들에 따른 상기 빅 데이터 서버 510은, 복수의 전자 장치들로부터 수집되는 정보를 모니터링함으로써, 아이템의 현재 거래 상황에 부합하는 정보를 상기 전자 장치 101 등과 같은 전자 장치들에게 제공할 수 있다. 다시 말해, 상기 빅 데이터 서버 510은, 광고성을 가지는 메시지가 아닌 사용자 별 또는 상황 별 맞춤형 정보를 상기 알림 메시지를 통해 사용자들에게 제공할 수 있다.
또한, 다양한 실시 예들에 따른 상기 전자 장치 101은 상기 빅 데이터 서버 510으로부터 수신되는 알림 메시지에 포함된 아이템과 상기 전자 장치 101의 참조 아이템을 비교함으로써, 상기 전자 장치 101의 사용자에 의미를 가지는 정보만을 표시할 수 있다. 다시 말해, 상기 전자 장치 101은 상기 전자 장치 101의 사용자에게 보다 개선된 쇼핑 환경을 제공할 수 있다.
도 16은 다양한 실시 예들에 따라 알림 메시지를 수신하는 전자 장치, 빅 데이터 서버, 결제 서버 사이의 신호 흐름의 다른 예를 도시한다. 이러한 신호 흐름은, 도 1에 도시된 전자 장치 101, 상기 프로세서 120 등과 같은 상기 전자 장치 101의 구성 요소, 도 5에 도시된 상기 결제 서버 520, 상기 결제 서버 520의 구성 요소, 도 5에 도시된 상기 빅 데이터 서버 510, 또는 상기 빅 데이터 서버 510의 구성 요소에 의해 야기될 수 있다.
도 16을 참조하면, 동작 1601에서, 전자 장치 1600-1 내지 전자 장치 1600-N 각각(예: 전자 장치 1600-1 내지 전자 장치 1600-N 내의 프로세서 등)은 상기 전자 장치 1600-1 내지 전자 장치 1600-N 각각의 사용자가 구매하고자 하는 아이템에 대한 거래를 완료하기 위한 정보를 상기 결제 서버 520에게 송신할 수 있다. 다시 말해, 상기 전자 장치 1600-1 내지 전자 장치 1600-N 각각은 특정 아이템에 대한 결제 정보를 상기 결제 서버 520에게 송신할 수 있다. 상기 결제 서버 520은 상기 결제 정보를 상기 전자 장치 1600-1 내지 전자 장치 1600-N 각각으로부터 수신할 수 있다.
동작 1602에서, 상기 전자 장치 1600-1 내지 전자 장치 1600-N 각각(예: 전자 장치 1600-1 내지 전자 장치 1600-N 내의 프로세서 등)은 상기 전자 장치 1600-1의 사용자가 구매하고자 하는 아이템에 대한 정보를 상기 빅 데이터 서버 510에게 송신할 수 있다. 다시 말해, 상기 전자 장치 1600-1 내지 전자 장치 1600-N 각각은 동작 610 등에 의해 결정된 상기 아이템에 대한 정보를 상기 빅 데이터 서버 510에게 송신할 수 있다. 상기 빅 데이터 서버 510은 상기 전자 장치 1600-1 내지 전자 장치 1600-N 각각으로부터 상기 아이템에 대한 정보를 수신할 수 있다.
도 16은 동작 1601 이후에 동작 1602가 수행되는 것을 예시하고 있지만 이는 설명을 위한 것이다. 동작 1601 및 동작 1602는 동시에 수행될 수 있으며, 순서에 관계없이 수행될 수도 있음을 유의하여야 한다.
동작 1603에서, 상기 결제 정보를 수신한 상기 결제 서버 520(예: 상기 결제 서버 520 내의 프로세서 등)은, 상기 전자 장치 1600-1 내지 전자 장치 1600-N 각각에게 상기 거래가 완료됨을 나타내기 위한 메시지를 송신할 수 있다. 다시 말해, 상기 결제 서버 520은 상기 전자 장치 1600-1 내지 전자 장치 1600-N 각각에게 상기 결제에 대한 정보를 송신할 수 있다.
동작 1610에서, 상기 빅 데이터 서버 510(예: 상기 빅 데이터 서버 510 내의 프로세서 등)은 동작 1602 등을 통해 수집된 정보에 기반하여 결정된 이벤트와 관련된 아이템을 결정할 수 있다. 예를 들면, 동작 1610에서 상기 빅 데이터 서버 510은 도 15에 도시된 동작 1510에 대응하는 동작을 수행할 수 있다.
동작 1611에서, 상기 빅 데이터 서버 510(예: 상기 빅 데이터 서버 510 내의 프로세서 등)은 동작 1610에서 결정된 아이템이 상기 전자 장치 101을 위한 적어도 하나의 참조 아이템에 대응하는지 여부를 결정할 수 있다. 상기 빅 데이터 서버 510은 각 전자 장치 별로 알림 메시지를 유니캐스트하기 위하여 또는 각 전자 장치 별 사용자의 선호도를 파악하기 위한 각 전자 장치를 위한 적어도 하나의 참조 아이템에 대한 정보를 저장하고 있을 수 있다. 상기 적어도 하나의 참조 아이템에 대한 정보는, 동작 1602 등을 통해 수집되는 정보에 기반하여 결정될 수 있다.
상기 빅 데이터 서버 510은 상기 빅 데이터 서버 510에 저장된 상기 전자 장치 101을 위한 상기 적어도 하나의 참조 아이템에 대한 정보와 동작 1610에서 결정된 아이템에 대한 정보를 비교할 수 있다. 상기 빅 데이터 서버 510은, 상기 비교 결과에 기반하여, 상기 결정된 아이템이 상기 전자 장치 101을 위한 적어도 하나의 참조 아이템에 대응하는지 여부를 결정할 수 있다. 상기 결정된 아이템이 상기 전자 장치 101을 위한 적어도 하나의 참조 아이템에 대응하는 경우, 상기 빅 데이터 서버 510은 동작 1612를 수행할 수 있다.
동작 1612에서, 상기 결정된 아이템이 상기 전자 장치 101을 위한 적어도 하나의 참조 아이템에 대응하는 경우, 상기 빅 데이터 서버 510(예: 상기 빅 데이터 서버 510 내의 프로세서 등)은 상기 결정된 아이템에 대한 정보를 포함하는 알림 메시지를 상기 전자 장치 101에게 송신할 수 있다. 다시 말해, 상기 빅 데이터 서버 510은 상기 결정된 아이템에 대한 정보를 포함하는 알림 메시지를 상기 전자 장치 101에게 유니캐스트할 수 있다. 상기 전자 장치 101은 상기 빅 데이터 서버 510으로부터 상기 결정된 아이템에 대한 정보를 포함하는 알림 메시지를 수신할 수 있다.
동작 1613에서, 상기 전자 장치 101(예: 프로세서 120 등)은 상기 수신된 알림 메시지를 표시할 수 있다. 동작 1613에서, 상기 전자 장치 101은 동작 1513에 대응하는 동작을 수행할 수 있다.
상술한 바와 같이, 다양한 실시 예들에 따른 상기 빅 데이터 서버 510은, 복수의 전자 장치들로부터 수집되는 정보를 모니터링함으로써, 아이템의 현재 거래 상황에 부합하고 상기 전자 장치 101의 사용자에게 부합하는 정보를 상기 전자 장치 101에게 제공할 수 있다. 다시 말해, 상기 빅 데이터 서버 510은, 광고성을 가지는 메시지가 아닌 사용자 별 및 상황 별 맞춤형 정보를 상기 알림 메시지를 통해 상기 전자 장치 101의 사용자에게 제공할 수 있다.
또한, 다양한 실시 예들에 따른 상기 전자 장치 101은 상기 전자 장치 101의 사용자가 쇼핑을 수행할 수 있도록, 상기 빅 데이터 서버 510으로부터 수신되는 알림 메시지를 표시할 수 있다. 다시 말해, 상기 전자 장치 101은 상기 전자 장치 101의 사용자에게 보다 개선된 쇼핑 환경을 제공할 수 있다.
도 17은 다양한 실시 예들에 따른 전자 장치에 표시된 알림 메시지의 화면(screen)의 예를 도시한다. 이러한 화면은, 도 1에 도시된 상기 전자 장치 101의 상기 디스플레이 160에서 표시될 수 있다.
도 17을 참조하면, 알림 메시지를 수신한 상기 전자 장치 101(예: 프로세서 120, 디스플레이 160 등)은 화면 1700을 표시할 수 있다. 화면 1700은 상기 알림 메시지에 포함된 특정 아이템에 대한 정보를 포함할 수 있다. 예를 들면, 상기 화면 1700은 "현재 OOO 쇼핑몰에서 아이템 AAA가 대폭 할인된 XXX 원으로 판매되고 있습니다"라는 문구와 상기 아이템 AAA을 구매하기 위한 페이지와 연동된 링크 "www.OOO.com/item/detailview/Item.aspx?goodscode=XYZABC"를 표시할 수 있다. 상기 전자 장치 101의 사용자는 상기 문구를 통해 OOO 쇼핑몰에 현재 방문할 경우 아이템 AAA가 평소보다 싼 가격인 XXX원으로 판매됨을 인지할 수 있다. 또한, 상기 전자 장치 101의 사용자는 상기 링크를 이용하여, 별도의 검색 없이 상기 아이템 AAA를 구매하기 위한 웹 페이지로 접속할 수 있다. 상기 전자 장치 101은, 상기 링크에 대한 입력을 검출하는 것에 기반하여, 상기 아이템 AAA를 구매하기 위한 상기 웹 페이지를 상기 전자 장치 101의 상기 디스플레이 160에서 표시할 수 있다. 일부 실시 예들에서, 상기 전자 장치 101은 상기 알림 메시지에 전부 또는 일부 중첩된 상기 웹 페이지를 표시될 수 있다. 다른 일부 실시 예들에서, 상기 전자 장치 101은 상기 알림 메시지를 표시하는 것을 중단하고, 상기 웹 페이지를 표시할 수 있다. 하지만, 상기 웹 페이지 또는 상기 알림 메시지의 표시 방법은, 이에 한정되지 않는다.
상술한 바와 같이, 다양한 실시 예들에 따른 상기 전자 장치 101은 높은 접근성을 가지는 알림 메시지를 사용자에게 제공함으로써, 사용자에게 보다 나은 구매 환경을 제공할 수 있다.
상술한 바와 같은 다양한 실시 예들에 따른 전자 장치의 방법은, 상기 전자 장치가 상기 전자 장치의 통신 회로를 통해 접속하는 웹 주소(web address)들에 대한 제1 정보를 적어도 임시적으로 저장하는 동작과, 상기 제1 어플리케이션 프로그램을 이용하여 거래를 실행하기 위한 사용자 입력을 상기 전자 장치의 디스플레이를 통해 수신하는 동작과, 상기 사용자 입력을 수신하면, 상기 통신 회로를 통해 상기 제1 외부 서버에게 상기 거래와 관련된 제2 정보를 송신하는 동작과, 상기 제2 정보를 송신하는 동작 직전 또는 직후에 상기 웹 주소들 중 하나와 관련된 웹 문서에 접근하는 동작과, 상기 거래와 관련된 적어도 하나의 아이템을 획득하기 위해 상기 웹 문서를 파싱(parsing)하는 동작과, 상기 통신 회로를 이용하여 상기 전자 장치 외부에 상기 적어도 하나의 아이템 또는 상기 웹 주소들 중 하나 중 하나 또는 그 이상에 대한 제3 정보를 송신하는 동작을 포함할 수 있다.
일부 실시 예들에서, 상기 제3 정보를 송신하는 동작은, 상기 제1 외부 서버와 다른 제2 외부 서버에게 상기 제3 정보를 송신하는 동작을 포함할 수 있다.
일부 실시 예들에서, 상기 웹 문서는, HTML(hyper mark-up language) 포맷(format)일 수 있다.
일부 실시 예들에서, 상기 파싱하는 동작은, 룰 기반(rule-based) 기법 또는 머신 러닝 기반(machine-learning based) 기법을 이용하여 상기 웹 문서를 파싱하는 동작을 포함할 수 있다.
일부 실시 예들에서, 상기 제1 정보는, URL(uniform resource locator)를 포함할 수 있다.
일부 실시 예들에서, 상기 방법은, 상기 제1 어플리케이션 프로그램을 포함하는 복수의 전자 장치들로부터 수집되고 웹 주소들 및 아이템들과 관련된 데이터에 적어도 일부 기반하여 생성된 제4 정보를 상기 외부 서버로부터 상기 통신 회로를 통해 수신하는 동작과, 상기 제4 정보에 기반하여 상기 디스플레이에 알림(notification)을 제공하는 동작을 포함할 수 있다.
일부 실시 예들에서, 상기 방법은, 상기 전자 장치가 상기 통신 회로를 통해 접속하는 복수의 웹 주소들이 거래와 관련되는지 여부를 결정하는 동작을 더 포함하고, 상기 임시적으로 저장하는 동작은, 상기 복수의 웹들 중에서 거래와 관련된 상기 웹 주소들에 대한 상기 제1 정보를 적어도 임시적으로 저장하는 동작을 포함할 수 있다.
상술한 바와 같은 다양한 실시 예들에 따른 전자 장치의 방법은 제1 외부 전자 장치로부터 제1 거래(transaction)가 완료됨(completed)을 나타내기 위한 제1 메시지를 수신하는 동작과, 상기 제1 메시지가 수신된 시점(timing)에 기반하여 결정되는 시구간(interval) 동안 상기 전자 장치가 접속하였던 복수의 웹 주소들 중에서 거래와 관련된 도메인 네임(domain name)을 포함하는 적어도 하나의 웹 주소를 결정하는 동작과, 상기 적어도 하나의 웹 주소와 관련된 적어도 하나의 웹 문서에 대한 데이터를 파싱하여 상기 제1 거래의 아이템(item)에 대한 정보를 결정하는 동작과, 상기 제1 거래의 아이템에 대한 정보를 상기 제1 외부 전자 장치 또는 제2 외부 전자 장치에게 송신하는 동작을 포함할 수 있다.
일부 실시 예들에서, 상기 방법은, 상기 전자 장치로부터 송신된 상기 아이템을 포함하는 복수의 아이템들에 대한 정보에 기반하여 결정된 적어도 하나의 참조 아이템(reference item)에 대한 정보를 상기 제2 외부 전자 장치로부터 수신하는 동작을 더 포함할 수 있다. 또한, 상기 방법은, 복수의 전자 장치들로부터 수집된 정보에 기반하여 결정된 특정 아이템(specific item)에 대한 정보를 포함하는 제2 메시지를 상기 제2 외부 전자 장치로부터 수신하는 동작을 더 포함할 수 있다. 또한, 상기 방법은, 상기 특정 아이템이 상기 적어도 하나의 참조 아이템에 포함되는지 여부를 결정하는 동작과, 상기 특정 아이템이 상기 적어도 하나의 참조 아이템에 포함된 경우, 상기 특정 아이템에 대한 정보를 표시하는 동작을 더 포함할 수 있다. 또한, 상기 표시된 특정 아이템에 대한 정보는, 상기 특정 아이템에 대한 제2 거래를 수립하기 위한 데이터를 포함할 수 있다. 또한, 상기 특정 아이템에 대한 제2 거래를 수립하기 위한 데이터는, 상기 특정 아이템을 제공하는 웹 주소를 나타내기 위한 데이터, 상기 특정 아이템과 관련된 이벤트를 나타내기 위한 데이터, 상기 특정 아이템의 가격(price)을 나타내기 위한 데이터, 또는 상기 특정 아이템의 이미지를 나타내기 위한 데이터 중 적어도 하나를 포함할 수 있다.
또한, 상기 방법은, 상기 표시된 특정 아이템에 대한 정보에 대한 입력을 검출하는 것에 기반하여, 상기 특정 아이템에 대한 거래를 위한 웹페이지에 접속하는 동작과, 상기 접속된 웹페이지를 표시하는 동작을 더 포함할 수 있다.
일부 실시 예들에서, 상기 제2 메시지는, 미리 결정된 주기 동안 상기 복수의 전자 장치들로부터 수집된 정보에 상기 특정 아이템이 포함되는 빈도가 기준치(reference value) 이상인 경우, 상기 제2 외부 전자 장치로부터 송신될 수 있다.
일부 실시 예들에서, 상기 방법은, 복수의 전자 장치들로부터 수집된 정보에 기반하여 결정된 특정 아이템에 대한 정보를 포함하는 제2 메시지를 상기 제2 외부 전자 장치로부터 수신하는 동작을 더 포함하고, 상기 제2 메시지는, 상기 특정 아이템이 상기 전자 장치로부터 송신된 상기 아이템을 포함하는 복수의 아이템들에 대한 정보에 기반하여 결정된 적어도 하나의 참조 아이템에 포함됨을 결정하는 것에 기반하여 상기 제2 외부 전자 장치로부터 상기 전자 장치에게 송신될 수 있다.
일부 실시 예들에서, 상기 적어도 하나의 웹 주소를 결정하는 동작은, 거래와 관련되고 상기 전자 장치에 미리 저장된 적어도 하나의 참조 도메인 네임과 상기 복수의 웹 주소들의 도메인 네임을 비교함으로써, 상기 복수의 웹 주소들 중에서 상기 적어도 하나의 참조 도메인 네임과 대응하는 도메인 네임을 가지는 상기 적어도 하나의 웹 주소를 결정하는 동작을 포함할 수 있다.
일부 실시 예들에서, 상기 적어도 하나의 웹 주소를 결정하는 동작은, 상기 복수의 웹 주소들의 복수의 도메인 네임들 각각에 포함된 문자들을 식별하는 동작과, 상기 식별된 문자들 중 적어도 하나를 조합함으로써 생성되는 용어(word)가 거래와 관련되고 상기 전자 장치에 미리 저장된 적어도 하나의 참조 용어에 포함되는지 여부를 결정하는 동작과, 상기 용어가 상기 적어도 하나의 참조 용어에 포함됨을 결정하는 것에 기반하여, 상기 용어에 포함된 적어도 하나의 문자를 포함하는 도메인 네임을 포함하는 웹 주소를 상기 적어도 하나의 웹 주소로 결정하는 동작을 포함할 수 있다.
일부 실시 예들에서, 상기 제1 거래의 아이템에 대한 정보를 결정하는 동작은, 상기 적어도 하나의 웹 문서에 대한 데이터를 파싱함으로써, 상기 웹 문서에 포함된 태그를 식별하는 동작과, 상기 식별된 태그에 포함된 정보에 기반하여 상기 제1 거래의 아이템에 대한 정보를 결정하는 동작을 포함할 수 있다.
상술한 바와 같이, 다양한 실시 예들에 따른 서버의 방법은, 복수의 전자 장치들로부터 거래와 관련된 복수의 아이템들에 대한 정보를 수신하는 동작과, 미리 결정된 주기 동안 상기 복수의 전자 장치들로부터 수신되는 정보에 제1 아이템이 포함되는 빈도가 기준치(reference value) 이상인 경우, 상기 제1 아이템에 대한 정보를 송신하는 동작을 포함하고, 상기 복수의 아이템들에 대한 정보는, 상기 복수의 전자 장치들 각각에서 상기 복수의 아이템들 각각에 대한 거래가 완료되는 것에 기반하여 상기 복수의 전자 장치들 각각으로부터 송신될 수 있다.
본 개시의 청구항 또는 명세서에 기재된 실시 예들에 따른 방법들은 하드웨어, 소프트웨어, 또는 하드웨어와 소프트웨어의 조합의 형태로 구현될(implemented) 수 있다.
소프트웨어로 구현하는 경우, 하나 이상의 프로그램(소프트웨어 모듈)을 저장하는 컴퓨터 판독 가능 저장 매체가 제공될 수 있다. 컴퓨터 판독 가능 저장 매체에 저장되는 하나 이상의 프로그램은, 전자 장치(device) 내의 하나 이상의 프로세서에 의해 실행 가능하도록 구성된다(configured for execution). 하나 이상의 프로그램은, 전자 장치로 하여금 본 개시의 청구항 또는 명세서에 기재된 실시 예들에 따른 방법들을 실행하게 하는 명령어(instructions)를 포함한다.
이러한 프로그램(소프트웨어 모듈, 소프트웨어)은 랜덤 액세스 메모리 (random access memory), 플래시(flash) 메모리를 포함하는 불휘발성(non-volatile) 메모리, 롬(ROM: Read Only Memory), 전기적 삭제가능 프로그램가능 롬(EEPROM: Electrically Erasable Programmable Read Only Memory), 자기 디스크 저장 장치(magnetic disc storage device), 컴팩트 디스크 롬(CD-ROM: Compact Disc-ROM), 디지털 다목적 디스크(DVDs: Digital Versatile Discs) 또는 다른 형태의 광학 저장 장치, 마그네틱 카세트(magnetic cassette)에 저장될 수 있다. 또는, 이들의 일부 또는 전부의 조합으로 구성된 메모리에 저장될 수 있다. 또한, 각각의 구성 메모리는 다수 개 포함될 수도 있다.
또한, 상기 프로그램은 인터넷(Internet), 인트라넷(Intranet), LAN(Local Area Network), WLAN(Wide LAN), 또는 SAN(Storage Area Network)과 같은 통신 네트워크, 또는 이들의 조합으로 구성된 통신 네트워크를 통하여 접근(access)할 수 있는 부착 가능한(attachable) 저장 장치(storage device)에 저장될 수 있다. 이러한 저장 장치는 외부 포트를 통하여 본 개시의 실시 예를 수행하는 장치에 접속할 수 있다. 또한, 통신 네트워크상의 별도의 저장장치가 본 개시의 실시 예를 수행하는 장치에 접속할 수도 있다.
상술한 본 개시의 구체적인 실시 예들에서, 개시에 포함되는 구성 요소는 제시된 구체적인 실시 예에 따라 단수 또는 복수로 표현되었다. 그러나, 단수 또는 복수의 표현은 설명의 편의를 위해 제시한 상황에 적합하게 선택된 것으로서, 본 개시가 단수 또는 복수의 구성 요소에 제한되는 것은 아니며, 복수로 표현된 구성 요소라 하더라도 단수로 구성되거나, 단수로 표현된 구성 요소라 하더라도 복수로 구성될 수 있다.
한편 본 개시의 상세한 설명에서는 구체적인 실시 예에 관해 설명하였으나, 본 개시의 범위에서 벗어나지 않는 한도 내에서 여러 가지 변형이 가능함은 물론이다. 그러므로 본 개시의 범위는 설명된 실시 예에 국한되어 정해져서는 아니 되며 후술하는 특허청구의 범위뿐만 아니라 이 특허청구의 범위와 균등한 것들에 의해 정해져야 한다.

Claims (22)

  1. 전자 장치(electronic device)에 있어서,
    하우징과,
    상기 하우징의 일부를 통해 노출된 터치스크린 디스플레이와,
    무선 통신 회로와,
    상기 디스플레이 및 상기 통신 회로와 전기적으로 연결된 프로세서와,
    상기 프로세서와 전기적으로 연결된 메모리를 포함하고,
    상기 메모리는,
    상기 통신 회로를 통해 제1 외부 서버에 거래 관련(transaction-related) 정보를 송신하도록 설정된 제1 어플리케이션 프로그램을 저장하고,
    상기 메모리는 , 실행시에, 상기 프로세서가,
    상기 전자 장치가 상기 통신 회로를 통해 접속하는 웹 주소(web address)들에 대한 제1 정보를 적어도 임시적으로 저장하고,
    상기 제1 어플리케이션 프로그램을 이용하여 거래를 실행하기 위한 사용자 입력을 상기 디스플레이를 통해 수신하고,
    상기 사용자 입력을 수신하면, 상기 통신 회로를 통해 상기 제1 외부 서버에게 상기 거래와 관련된 제2 정보를 송신하고,
    상기 제2 정보를 송신하는 동작 직전 또는 직후에 상기 웹 주소들 중 하나와 관련된 웹 문서에 접근하고,
    상기 거래와 관련된 적어도 하나의 아이템을 획득하기 위해 상기 웹 문서를 파싱(parsing)하고,
    상기 통신 회로를 이용하여 상기 전자 장치 외부에 상기 적어도 하나의 아이템 또는 상기 웹 주소들 중 하나 또는 그 이상에 대한 제3 정보를 송신하기 위한 명령어들을 더 저장하는 전자 장치.
  2. 청구항 1에 있어서, 상기 명령어들은, 상기 프로세서가,
    상기 제1 외부 서버와 다른 제2 외부 서버에게 상기 제3 정보를 송신하기 하는 전자 장치.
  3. ◈청구항 3은(는) 설정등록료 납부시 포기되었습니다.◈
    청구항 1에 있어서, 상기 웹 문서는,
    HTML(hyper mark-up language) 포맷(format)인 전자 장치.
  4. ◈청구항 4은(는) 설정등록료 납부시 포기되었습니다.◈
    청구항 1에 있어서, 상기 명령어들은, 상기 프로세서가,

    룰 기반(rule-based) 기법 또는 머신 러닝 기반(machine-learning based) 기법을 이용하여 상기 웹 문서를 파싱하는 전자 장치.
  5. ◈청구항 5은(는) 설정등록료 납부시 포기되었습니다.◈
    청구항 1에 있어서, 상기 제1 정보는,
    URL(uniform resource locator)를 포함하는 전자 장치.
  6. 청구항 1에 있어서, 상기 명령어들은, 상기 프로세서가,
    상기 제1 어플리케이션 프로그램을 포함하는 복수의 전자 장치들로부터 수집되고 웹 주소들 및 아이템들과 관련된 데이터에 적어도 일부 기반하여 생성된 제4 정보를 상기 외부 서버로부터 상기 통신 회로를 통해 수신하고,
    상기 제4 정보에 기반하여 상기 디스플레이에 알림(notification)을 제공하는 전자 장치.
  7. 청구항 1에 있어서, 상기 명령어들은,
    상기 전자 장치가 상기 통신 회로를 통해 접속하는 복수의 웹 주소들이 거래와 관련되는지 여부를 결정하고,
    상기 복수의 웹 주소들 중에서 거래와 관련된 상기 웹 주소(web address)들에 대한 상기 제1 정보를 적어도 임시적으로 저장하기 위해 상기 프로세서를 야기하는 전자 장치.
  8. 명령어(instruction)들을 저장하는 메모리와,
    무선 통신 회로(wireless communication circuit)와,
    상기 메모리와 상기 무선 통신 회로와 전기적으로(electrically) 연결(coupled to)되고,
    제1 외부 전자 장치로부터 제1 거래(transaction)가 완료됨(completed)을 나타내기 위한 제1 메시지를 수신하고,
    상기 제1 메시지가 수신된 시점(timing)에 기반하여 결정되는 시구간(interval) 동안 상기 전자 장치가 접속하였던 복수의 웹 주소들 중에서 거래와 관련된 도메인 네임(domain name)을 포함하는 적어도 하나의 웹 주소를 결정하고,
    상기 적어도 하나의 웹 주소와 관련된 적어도 하나의 웹 문서에 대한 데이터를 파싱하여 상기 제1 거래의 아이템(item)에 대한 정보를 결정하고,
    상기 제1 거래의 아이템에 대한 정보를 상기 제1 외부 전자 장치 또는 제2 외부 전자 장치에게 송신하기 위해 상기 저장된 명령어들을 실행하도록 설정된 적어도 하나의 프로세서를 포함하는 전자 장치.
  9. 청구항 8에 있어서, 상기 적어도 하나의 프로세서는,
    상기 전자 장치로부터 송신된 상기 아이템을 포함하는 복수의 아이템들에 대한 정보에 기반하여 결정된 적어도 하나의 참조 아이템(reference item)에 대한 정보를 상기 제2 외부 전자 장치로부터 수신하기 위해 상기 저장된 명령어들을 실행하도록 더 설정되는 전자 장치.
  10. 청구항 9에 있어서, 상기 적어도 하나의 프로세서는,
    복수의 전자 장치들로부터 수집된 정보에 기반하여 결정된 특정 아이템(specific item)에 대한 정보를 포함하는 제2 메시지를 상기 제2 외부 전자 장치로부터 수신하기 위해 상기 저장된 명령어들을 실행하도록 더 설정되는 전자 장치.
  11. 청구항 10에 있어서, 상기 전자 장치는,
    상기 적어도 하나의 프로세서와 전기적으로 연결된 디스플레이 유닛(unit)을 더 포함하고,
    상기 적어도 하나의 프로세서는,
    상기 특정 아이템이 상기 적어도 하나의 참조 아이템에 포함되는지 여부를 결정하고,
    상기 특정 아이템이 상기 적어도 하나의 참조 아이템에 포함된 경우, 상기 특정 아이템에 대한 정보를 상기 디스플레이 유닛을 통해 표시하기 위해 상기 저장된 명령어들을 실행하도록 더 설정되는 전자 장치.
  12. 청구항 11에 있어서, 상기 표시된 특정 아이템에 대한 정보는,
    상기 특정 아이템에 대한 제2 거래를 수립하기 위한 데이터를 포함하는 전자 장치.
  13. ◈청구항 13은(는) 설정등록료 납부시 포기되었습니다.◈
    청구항 12에 있어서, 상기 특정 아이템에 대한 제2 거래를 수립하기 위한 데이터는,
    상기 특정 아이템을 제공하는 웹 주소를 나타내기 위한 데이터, 상기 특정 아이템과 관련된 이벤트를 나타내기 위한 데이터, 상기 특정 아이템의 가격(price)을 나타내기 위한 데이터, 또는 상기 특정 아이템의 이미지를 나타내기 위한 데이터 중 적어도 하나를 포함하는 전자 장치.
  14. ◈청구항 14은(는) 설정등록료 납부시 포기되었습니다.◈
    청구항 11에 있어서, 상기 적어도 하나의 프로세서는,
    상기 표시된 특정 아이템에 대한 정보에 대한 입력을 검출하는 것에 기반하여, 상기 특정 아이템에 대한 거래를 위한 웹페이지에 접속하고,
    상기 접속된 웹페이지를 표시하기 위해 상기 저장된 명령어들을 실행하도록 더 설정되는 전자 장치.
  15. ◈청구항 15은(는) 설정등록료 납부시 포기되었습니다.◈
    청구항 10에 있어서, 상기 제2 메시지는,
    미리 결정된 주기 동안 상기 복수의 전자 장치들로부터 수집된 정보에 상기 특정 아이템이 포함되는 빈도가 기준치(reference value) 이상인 경우, 상기 제2 외부 전자 장치로부터 송신되는 전자 장치.
  16. ◈청구항 16은(는) 설정등록료 납부시 포기되었습니다.◈
    청구항 8에 있어서, 상기 적어도 하나의 프로세서는,
    복수의 전자 장치들로부터 수집된 정보에 기반하여 결정된 특정 아이템에 대한 정보를 포함하는 제2 메시지를 상기 제2 외부 전자 장치로부터 수신하기 위해 상기 저장된 명령어들을 실행하도록 더 설정되고,
    상기 제2 메시지는,
    상기 특정 아이템이 상기 전자 장치로부터 송신된 상기 아이템을 포함하는 복수의 아이템들에 대한 정보에 기반하여 결정된 적어도 하나의 참조 아이템에 포함됨을 결정하는 것에 기반하여 상기 제2 외부 전자 장치로부터 상기 전자 장치에게 송신되는 전자 장치.
  17. ◈청구항 17은(는) 설정등록료 납부시 포기되었습니다.◈
    청구항 8에 있어서, 상기 적어도 하나의 프로세서는,
    거래와 관련되고 상기 전자 장치에 미리 저장된 적어도 하나의 참조 도메인 네임과 상기 복수의 웹 주소들의 도메인 네임을 비교함으로써, 상기 복수의 웹 주소들 중에서 상기 적어도 하나의 참조 도메인 네임과 대응하는 도메인 네임을 가지는 상기 적어도 하나의 웹 주소를 결정하기 위해 상기 저장된 명령어들을 실행하도록 설정되는 전자 장치.
  18. ◈청구항 18은(는) 설정등록료 납부시 포기되었습니다.◈
    청구항 8에 있어서, 상기 적어도 하나의 프로세서는,
    상기 복수의 웹 주소들의 복수의 도메인 네임들 각각에 포함된 문자들을 식별하고,
    상기 식별된 문자들 중 적어도 하나를 조합함으로써 생성되는 용어(word)가 거래와 관련되고 상기 전자 장치에 미리 저장된 적어도 하나의 참조 용어에 포함되는지 여부를 결정하고,
    상기 용어가 상기 적어도 하나의 참조 용어에 포함됨을 결정하는 것에 기반하여, 상기 용어에 포함된 적어도 하나의 문자를 포함하는 도메인 네임을 포함하는 웹 주소를 상기 적어도 하나의 웹 주소로 결정하기 위해 상기 저장된 명령어들을 실행하도록 설정되는 전자 장치.
  19. ◈청구항 19은(는) 설정등록료 납부시 포기되었습니다.◈
    청구항 8에 있어서, 상기 적어도 하나의 프로세서는,
    상기 적어도 하나의 웹 문서에 대한 데이터를 파싱함으로써, 상기 웹 문서에 포함된 태그를 식별하고,
    상기 식별된 태그에 포함된 정보에 기반하여 상기 제1 거래의 아이템에 대한 정보를 결정하기 위해 상기 저장된 명령어들을 실행하도록 설정되는 전자 장치.
  20. 삭제
  21. 전자 장치(electronic device)의 방법에 있어서,
    제1 외부 전자 장치로부터 제1 거래(transaction)가 완료됨(completed)을 나타내기 위한 제1 메시지를 수신하는 동작과,
    상기 제1 메시지가 수신된 시점(timing)에 기반하여 결정되는 시구간(interval) 동안 상기 전자 장치가 접속하였던 복수의 웹 주소들 중에서 거래와 관련된 도메인 네임(domain name)을 포함하는 적어도 하나의 웹 주소를 결정하는 동작과,
    상기 적어도 하나의 웹 주소와 관련된 적어도 하나의 웹 문서에 대한 데이터를 파싱하여 상기 제1 거래의 아이템(item)에 대한 정보를 결정하는 동작과,
    상기 제1 거래의 아이템에 대한 정보를 상기 제1 외부 전자 장치 또는 제2 외부 전자 장치에게 송신하는 동작을 포함하는 방법.
  22. 삭제
KR1020170032571A 2017-03-15 2017-03-15 웹과 관련된 데이터에서 아이템을 검출하기 위한 전자 장치 및 방법 KR102381436B1 (ko)

Priority Applications (2)

Application Number Priority Date Filing Date Title
KR1020170032571A KR102381436B1 (ko) 2017-03-15 2017-03-15 웹과 관련된 데이터에서 아이템을 검출하기 위한 전자 장치 및 방법
US15/901,232 US20180268383A1 (en) 2017-03-15 2018-02-21 Electronic device and method for detecting item in data associated with web

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020170032571A KR102381436B1 (ko) 2017-03-15 2017-03-15 웹과 관련된 데이터에서 아이템을 검출하기 위한 전자 장치 및 방법

Publications (2)

Publication Number Publication Date
KR20180105464A KR20180105464A (ko) 2018-09-28
KR102381436B1 true KR102381436B1 (ko) 2022-04-01

Family

ID=63521309

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020170032571A KR102381436B1 (ko) 2017-03-15 2017-03-15 웹과 관련된 데이터에서 아이템을 검출하기 위한 전자 장치 및 방법

Country Status (2)

Country Link
US (1) US20180268383A1 (ko)
KR (1) KR102381436B1 (ko)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10796016B2 (en) * 2018-03-28 2020-10-06 Visa International Service Association Untethered resource distribution and management
US11810145B2 (en) * 2020-03-27 2023-11-07 Capital One Services, Llc Systems and methods for promoting transaction rewards
WO2021246816A1 (en) 2020-06-04 2021-12-09 Samsung Electronics Co., Ltd. Method for enhancing performance of electronic device
US11409829B2 (en) * 2020-12-21 2022-08-09 Capital One Services, Llc Methods and systems for redirecting a user from a third party website to a provider website

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101443158B1 (ko) 2013-07-11 2014-09-25 오드컨셉 주식회사 사용자 관심 기반의 상품정보 추천 시스템

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11514496B2 (en) * 2012-07-25 2022-11-29 Avalara, Inc. Summarization and personalization of big data method and apparatus
KR20140128559A (ko) * 2013-04-26 2014-11-06 남희옥 사용자 관심 자동 수집에 기반한 타겟정보 제공시스템 및 그 방법

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101443158B1 (ko) 2013-07-11 2014-09-25 오드컨셉 주식회사 사용자 관심 기반의 상품정보 추천 시스템

Also Published As

Publication number Publication date
KR20180105464A (ko) 2018-09-28
US20180268383A1 (en) 2018-09-20

Similar Documents

Publication Publication Date Title
CN108664829B (zh) 用于提供与图像中对象有关的信息的设备
US11068900B2 (en) Electronic device and electronic purchase method using same
US11792733B2 (en) Battery charge aware communications
US10034151B2 (en) Method for providing point of interest and electronic device thereof
KR102381436B1 (ko) 웹과 관련된 데이터에서 아이템을 검출하기 위한 전자 장치 및 방법
KR20170112569A (ko) 상품 결제 방법 및 이를 지원하는 전자 장치
US10972861B2 (en) Electronic device and system for providing point of interest information
US11394671B2 (en) Method for providing transaction history-based service and electronic device therefor
KR20210025690A (ko) 동적으로 구성 가능한 소셜 미디어 플랫폼
KR20220149624A (ko) 거래 피드백의 처리
US11127012B2 (en) Electronic device and method for performing plurality of payments
KR102559931B1 (ko) 전자 장치 및 이를 이용한 결제 방법
KR102490673B1 (ko) 어플리케이션에 대한 부가 정보 제공 방법 및 이를 지원하는 전자 장치
CN108141442B (zh) 重定向到信任设备的方法和系统
KR102392015B1 (ko) 통화 관련 정보를 표시하기 위한 전자 장치 및 그의 동작 방법
KR102362868B1 (ko) 사용자의 선호도에 따라 사용자에게 컨텐트들을 제공하는 방법 및 이를 위한 전자 장치
KR102369319B1 (ko) 전자 장치 및 전자 장치의 핸드오프 기능 제공 방법
US11521193B2 (en) Electronic payment method and electronic device for supporting the same
KR102310296B1 (ko) 중고의류의 복원 및 리세일를 위한 플랫폼을 운영하는 서버 및 그 동작 방법
KR102457006B1 (ko) 전자 장치의 정보 제공 방법 및 장치
KR102354729B1 (ko) 전자 장치의 연락처 관리 방법 및 그 전자 장치
CN108292318A (zh) 生成概念图
KR20220065625A (ko) 전자 문서에 기반하여 회원권 명의 변경을 지원하는 전자 시스템
KR20180047855A (ko) 전자 장치 및 그의 배송 정보 제공 방법
KR102347991B1 (ko) 온라인 플랫폼에서의 마케팅 및 상품 노출을 적응적으로 제어하는 방법 및 그 방법을 적용한 장치

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