KR20170058847A - 이종 플랫폼 간 통신 방법 및 장치 - Google Patents

이종 플랫폼 간 통신 방법 및 장치 Download PDF

Info

Publication number
KR20170058847A
KR20170058847A KR1020160131915A KR20160131915A KR20170058847A KR 20170058847 A KR20170058847 A KR 20170058847A KR 1020160131915 A KR1020160131915 A KR 1020160131915A KR 20160131915 A KR20160131915 A KR 20160131915A KR 20170058847 A KR20170058847 A KR 20170058847A
Authority
KR
South Korea
Prior art keywords
identification information
platform server
user identification
server
platform
Prior art date
Application number
KR1020160131915A
Other languages
English (en)
Other versions
KR101952925B1 (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 US15/353,953 priority Critical patent/US10476857B2/en
Publication of KR20170058847A publication Critical patent/KR20170058847A/ko
Application granted granted Critical
Publication of KR101952925B1 publication Critical patent/KR101952925B1/ko

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • H04L41/02Standardisation; Integration
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/02Details
    • H04L12/12Arrangements for remote connection or disconnection of substations or of equipment thereof
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • H04L41/28Restricting access to network management systems or functions, e.g. using authorisation function to access network configuration

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Telephonic Communication Services (AREA)

Abstract

이종 플랫폼 간 통신 방법 및 장치가 개시된다. 개시된 서로 다른 플랫폼을 제공하는 제1 플랫폼 서버 및 제2 플랫폼 서버를 연동시키는 연동 서버의 통신 방법은 제1 플랫폼 서버로부터 제1 플랫폼 서버에 등록된 제1 사용자 식별정보를 포함하는 토큰 요청을 수신하고, 제1 사용자 식별정보에 대응하는 통합 사용자 식별정보로부터 생성된 토큰을 제1 플랫폼 서버로 전송하고, 제1 플랫폼 서버로부터 제2 플랫폼 서버로 전달된 토큰이 유효한지 여부에 대한 확인 요청을 제2 플랫폼 서버로부터 수신하며, 토큰이 유효한 경우, 통합 사용자 식별정보에 대응하고 제2 플랫폼 서버에 등록된 제2 사용자 식별정보를 제2 플랫폼 서버로 전달한다.

Description

이종 플랫폼 간 통신 방법 및 장치{METHOD AND APPARATUS FOR COMMUNICATING BETWEEN HETEROGENEOUS PLATFORMS}
아래의 설명은 이종 플랫폼 간 통신 방법 및 장치에 관한 것으로, 보다 구체적으로는 서로 다른 플랫폼을 제공하는 제1 플랫폼 서버 및 제2 플랫폼 서버를 연동시키는 연동 서버, 제1 플랫폼 서버, 제2 플랫폼 서버 및 상기 서버의 통신 방법에 관한 것이다.
최근 통신기술의 보급율이 높아지고 스마트 폰이 대중화되면서, IoT(Internet of things)에 대한 기대가 점차 증가하고 있으며, IoT 구현을 위한 다양한 기술이 개발되고 있다. IoT를 통해, 가정에서 사용되는 모든 가전기기 및 통신기기가 인터넷으로 연결되어 다양한 정보를 수집하고 분석하여 사용자에게 필요한 정보를 제공할 수 있을 것으로 기대되고 있다.
그러나, 가전기기 및 통신기기는 일반적으로 해당 제조사가 제공하는 플랫폼을 통해서 제어가 가능하기 때문에, 만약 가정에서 사용되는 가전기기 및 통신기기의 제조사가 다른 경우, 다른 제조사의 가전기기 및 통신기기를 제어하기가 어렵다.
본 발명은 서로 다른 플랫폼을 제공하는 플랫폼 서버들을 연동시킴으로써, 제조사가 다르더라도 효과적으로 가정에서 사용되는 가전기기 또는 통신기기를 제어할 수 있다.
본 발명은 시간에 따라 통합 사용자 식별정보를 변경하고, 제1 플랫폼 서버로부터 토큰이 요청된 경우에만 통합 사용자 식별정보에 기초하여 토큰을 생성함으로써, 서로 다른 플랫폼을 제공하는 플랫폼 서버들을 연동시키더라도 높은 보안성을 유지할 수 있다.
일실시예에 따른 서로 다른 플랫폼을 제공하는 제1 플랫폼 서버 및 제2 플랫폼 서버를 연동시키는 연동 서버의 통신 방법은 상기 제1 플랫폼 서버로부터 상기 제1 플랫폼 서버에 등록된 제1 사용자 식별정보를 포함하는 토큰 요청을 수신하는 단계; 상기 제1 사용자 식별정보에 대응하는 통합 사용자 식별정보로부터 생성된 토큰을 상기 제1 플랫폼 서버로 전송하는 단계; 상기 제1 플랫폼 서버로부터 상기 제2 플랫폼 서버로 전달된 토큰이 유효한지 여부에 대한 확인 요청을 상기 제2 플랫폼 서버로부터 수신하는 단계; 및 상기 토큰이 유효한 경우, 상기 통합 사용자 식별정보에 대응하고 상기 제2 플랫폼 서버에 등록된 제2 사용자 식별정보를 상기 제2 플랫폼 서버로 전달하는 단계를 포함한다.
일실시예에 따른 연동 서버의 통신 방법에서 상기 통합 사용자 식별정보로부터 생성된 토큰은, 시간에 따라 변경되는 통합 사용자 식별정보가 암호화됨으로써 생성될 수 있다.
일실시예에 따른 연동 서버의 통신 방법에서 상기 제1 사용자 식별정보 및 상기 제2 사용자 식별정보 각각은, 상기 제1 플랫폼 서버 및 상기 제2 플랫폼 서버에 가입한 동일한 사용자를 식별하는 정보이고, 상기 통합 사용자 식별정보는, 상기 제1 사용자 식별정보 및 상기 제2 사용자 식별정보에 맵핑될 수 있다.
일실시예에 따른 연동 서버의 통신 방법은 상기 제1 플랫폼 서버로부터 상기 제1 사용자 식별정보를 포함하는 타 플랫폼 연동 요청을 수신하는 단계; 상기 제1 플랫폼 서버에 연동될 수 있는 플랫폼 리스트 및 상기 통합 사용자 식별정보에 기초하여 생성된 트랜잭션 식별정보를 상기 제1 플랫폼 서버로 전송하는 단계; 상기 플랫폼 리스트를 통해 상기 제2 플랫폼 서버에 성공적으로 로그인한 경우, 상기 제2 플랫폼 서버로부터 상기 제2 사용자 식별정보 및 상기 트랜잭션 식별정보를 수신하는 단계; 및 상기 트랜잭션 식별정보가 유효한 경우, 상기 제2 사용자 식별정보를 상기 통합 사용자 식별정보 및 상기 제1 사용자 식별정보에 맵핑하는 단계를 더 포함할 수 있다.
일실시예에 따른 연동 서버의 통신 방법에서 상기 제2 사용자 식별정보를 상기 통합 사용자 식별정보 및 상기 제2 사용자 식별정보에 맵핑하는 단계는, 상기 트랜잭션 식별정보에 대한 유효시간이 만료되기 전에 상기 제2 플랫폼 서버로부터 상기 트랜잭션 식별정보를 수신하여 상기 트랜잭션 식별정보가 유효한 것으로 판단된 경우, 상기 제2 사용자 식별정보를 상기 통합 사용자 식별정보 및 상기 제2 사용자 식별정보에 맵핑할 수 있다.
일실시예에 따른 연동 서버의 통신 방법에서 상기 플랫폼 리스트는, 상기 제1 플랫폼 서버에 연동되는 플랫폼에 로그인할 수 있는 인터페이스를 제공하는 Federation URL을 포함할 수 있다.
일실시예에 따른 연동 서버를 통해 서로 다른 플랫폼을 제공하는 제2 플랫폼 서버에 연동되는 제1 플랫폼 서버의 통신 방법은 상기 연동 서버로 상기 제1 플랫폼 서버에 등록된 제1 사용자 식별정보를 포함하는 토큰 요청을 전송하는 단계; 상기 제1 사용자 식별정보에 대응하는 통합 사용자 식별정보로부터 생성된 토큰을 상기 연동 서버로부터 수신하는 단계; 상기 제2 플랫폼 서버로 상기 토큰 및 상기 제2 플랫폼 서버에 등록된 디바이스에 대한 요청을 전송하는 단계; 및 상기 제2 플랫폼 서버로부터 상기 디바이스에 대한 요청의 처리 결과를 수신하는 단계를 포함하고, 상기 제2 플랫폼 서버는, 상기 제1 플랫폼 서버로부터 상기 제2 플랫폼 서버로 전달된 토큰을 유효한 것으로 판단한 상기 연동 서버로부터 상기 통합 사용자 식별정보에 대응하고 상기 제2 플랫폼 서버에 등록된 제2 사용자 식별정보를 수신한 경우, 상기 디바이스에 대한 요청에 따른 처리 결과를 상기 제1 플랫폼 서버로 전송한다.
일실시예에 따른 제1 플랫폼 서버의 통신 방법에서 상기 디바이스에 대한 요청은, 상기 제2 플랫폼 서버에 등록된 디바이스 리스트, 상기 디바이스에 대한 제어, 상기 디바이스에 대한 이벤트 구독 중 적어도 하나에 대한 요청을 포함할 수 있다.
일실시예에 따른 제1 플랫폼 서버의 통신 방법은 상기 연동 서버로 상기 제1 사용자 식별정보를 포함하는 타 플랫폼 연동 요청을 전송하는 단계; 상기 연동 서버로부터 상기 제1 플랫폼 서버와 연동될 수 있는 플랫폼 리스트 및 상기 통합 사용자 식별정보에 기초하여 생성된 트랜잭션 식별정보를 수신하는 단계; 및 상기 플랫폼 리스트를 통해 상기 제2 플랫폼 서버에 대한 로그인 정보 및 상기 트랜잭션 식별정보를 전송하는 단계를 더 포함하고, 상기 로그인 정보에 포함된 제2 사용자 식별정보는, 상기 제2 플랫폼 서버에 성공적으로 로그인한 경우, 상기 제2 플랫폼 서버로부터 상기 연동 서버로 전송되어 상기 통합 사용자 식별정보 및 상기 제1 플랫폼 사용자 식별정보에 맵핑될 수 있다.
일실시예에 따른 제1 플랫폼 서버의 통신 방법에서 상기 통합 사용자 식별정보로부터 생성된 토큰은, 시간에 따라 변경되는 상기 통합 사용자 식별정보를 암호화함으로써 생성될 수 있다.
일실시예에 따른 제1 플랫폼 서버의 통신 방법에서 상기 제1 사용자 식별정보 및 상기 제2 사용자 식별정보 각각은, 상기 제1 플랫폼 서버 및 상기 제2 플랫폼 서버에 가입한 동일한 사용자를 식별하는 정보이고, 상기 통합 사용자 식별정보는, 상기 제1 사용자 식별정보 및 상기 제2 사용자 식별정보에 맵핑될 수 있다.
일실시예에 따른 연동 서버를 통해 서로 다른 플랫폼을 제공하는 제1 플랫폼 서버에 연동되는 제2 플랫폼 서버의 통신 방법은 상기 제1 플랫폼 서버로부터 토큰 및 상기 제2 플랫폼 서버에 등록된 디바이스에 대한 요청을 수신하는 단계 -토큰은, 상기 제1 플랫폼 서버의 요청에 응답하여 상기 제1 플랫폼 서버에 등록된 제1 사용자 식별정보에 대응하는 통합 사용자 식별정보로부터 생성됨 -; 상기 연동 서버로 상기 토큰이 유효한지 여부에 대한 확인 요청을 전송하는 단계; 상기 토큰을 유효한 것으로 판단한 상기 연동 서버로부터 상기 통합 사용자 식별정보에 대응하고 제2 플랫폼 서버에 등록된 제2 사용자 식별정보를 수신하는 단계를 포함한다.
일실시예에 따른 제2 플랫폼 서버의 통신 방법에서 상기 통합 사용자 식별정보로부터 생성된 토큰은, 시간에 따라 변경되는 통합 사용자 식별정보가 암호화됨으로써 생성될 수 있다.
일실시예에 따른 제2 플랫폼 서버의 통신 방법에서 상기 디바이스에 대한 요청은, 상기 제2 플랫폼 서버에 등록된 디바이스 리스트, 상기 디바이스에 대한 제어, 상기 디바이스에 대한 이벤트 구독 중 적어도 하나에 대한 요청을 포함할 수 있다.
일실시예에 따른 제2 플랫폼 서버의 통신 방법은 상기 디바이스에 대한 요청의 처리 결과를 상기 디바이스 식별정보 및 상기 제2 플랫폼 서버 식별정보와 함께 상기 제1 플랫폼 서버로 전송하는 단계를 더 포함한다.
일실시예에 따른 제2 플랫폼 서버의 통신 방법은 타 플랫폼 연동을 요청한 상기 제1 플랫폼 서버로부터 상기 제2 플랫폼 서버에 대한 로그인 정보 및 상기 통합 사용자 식별정보에 대응하는 트랜잭션 식별정보를 수신하는 단계; 및 상기 로그인 정보에 기초한 제2 플랫폼 서버에 성공적으로 로그인한 경우, 상기 트랜잭션 식별정보 및 상기 제2 사용자 식별정보를 상기 연동 서버로 전송하는 단계를 더 포함하고, 상기 제2 사용자 식별정보는, 상기 제2 플랫폼 서버로부터 수신된 상기 트랜잭션 식별정보가 유효한 것으로 판단한 상기 연동 서버에 의해 상기 통합 사용자 식별정보 및 상기 제1 플랫폼 사용자 식별정보에 맵핑될 수 있다.
일실시예에 따른 제2 플랫폼 서버의 통신 방법에서 상기 제1 사용자 식별정보 및 상기 제2 사용자 식별정보 각각은, 상기 제1 플랫폼 서버 및 상기 제2 플랫폼 서버에 가입한 동일한 사용자를 식별하는 정보이고, 상기 통합 사용자 식별정보는, 상기 제1 사용자 식별정보 및 상기 제2 사용자 식별정보에 맵핑될 수 있다.
일실시예에 따른 서로 다른 플랫폼을 제공하는 제1 플랫폼 서버 및 제2 플랫폼 서버 간의 연동을 위한 연동 서버는 통신 방법이 저장된 메모리; 및 상기 통신 방법을 수행하는 프로세서를 포함하고, 상기 프로세서는, 상기 제1 플랫폼 서버로부터 상기 제1 플랫폼 서버에 등록된 제1 사용자 식별정보를 포함하는 토큰 요청을 수신하고, 상기 제1 사용자 식별정보에 대응하는 통합 사용자 식별정보로부터 생성된 토큰을 상기 제1 플랫폼 서버로 전송하고, 상기 제1 플랫폼 서버로부터 상기 제2 플랫폼 서버로 전달된 토큰이 유효한지 여부에 대한 확인 요청을 상기 제2 플랫폼 서버로부터 수신하며, 상기 토큰이 유효한 경우, 상기 통합 사용자 식별정보에 대응하고 상기 제2 플랫폼 서버에 등록된 제2 사용자 식별정보를 상기 제2 플랫폼 서버로 전달한다.
일실시예에 따르면, 서로 다른 플랫폼을 제공하는 플랫폼 서버들을 연동시킴으로써, 제조사가 다르더라도 가정에서 사용되는 가전기기 또는 통신기기를 효과적으로 제어할 수 있다.
일실시예에 따르면, 시간에 따라 통합 사용자 식별정보를 변경하고, 제1 플랫폼 서버로부터 토큰이 요청된 경우에만 통합 사용자 식별정보에 기초하여 토큰을 생성함으로써, 서로 다른 플랫폼을 제공하는 플랫폼 서버들을 연동시키더라도 높은 보안성을 유지할 수 있다.
도 1은 일실시예에 따라 제1 플랫폼 서버, 제2 플랫폼 서버 및 연동 서버로 구성되는 홈 네트워크 시스템을 설명하기 위한 도면이다.
도 2는 일실시예에 따라 제1 플랫폼 서버, 제2 플랫폼 서버 및 연동 서버의 세부 구성을 나타낸 도면이다.
도 3은 다른 일실시예에 따라 제1 플랫폼 서버, 제2 플랫폼 서버 및 연동 서버의 세부 구성을 나타낸 도면이다.
도 4는 일실시예에 따라 인증 서버에 플랫폼 서버를 등록하는 과정을 설명하기 위한 도면이다.
도 5는 일실시예에 따라 제1 플랫폼 서버 및 제2 플랫폼 서버를 연동시키는 과정을 설명하기 위한 도면이다.
도 6은 일실시예에 따라 타 플랫폼 서버에 등록된 디바이스 리스트를 요청하는 과정을 설명하기 위한 도면이다.
도 7은 일실시예에 따라 타 플랫폼 서버에 등록된 디바이스에 대한 제어를 요청하는 과정을 설명하기 위한 도면이다.
도 8은 일실시예에 따라 타 플랫폼 서버에 등록된 디바이스에 대한 이벤트 구동을 요청하는 과정을 설명하기 위한 도면이다.
도 9는 일실시예에 따라 연동 서버의 통신 방법을 나타낸 도면이다.
도 10은 일실시예에 따라 제1 플랫폼 서버의 통신 방법을 나타낸 도면이다.
도 11은 일실시예에 따라 제2 플랫폼 서버의 통신 방법을 나타낸 도면이다.
도 12는 일실시예에 따른 연동 서버를 나타낸 도면이다.
실시예들에 대한 특정한 구조적 또는 기능적 설명들은 단지 예시를 위한 목적으로 개시된 것으로서, 다양한 형태로 변경되어 실시될 수 있다. 따라서, 실시예들은 특정한 개시형태로 한정되는 것이 아니며, 본 명세서의 범위는 기술적 사상에 포함되는 변경, 균등물, 또는 대체물을 포함한다.
제1 또는 제2 등의 용어를 다양한 구성요소들을 설명하는데 사용될 수 있지만, 이런 용어들은 하나의 구성요소를 다른 구성요소로부터 구별하는 목적으로만 해석되어야 한다. 예를 들어, 제1 구성요소는 제2 구성요소로 명명될 수 있고, 유사하게 제2 구성요소는 제1 구성요소로도 명명될 수 있다.
어떤 구성요소가 다른 구성요소에 "연결되어" 있다고 언급된 때에는, 그 다른 구성요소에 직접적으로 연결되어 있거나 또는 접속되어 있을 수도 있지만, 중간에 다른 구성요소가 존재할 수도 있다고 이해되어야 할 것이다.
단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다. 본 명세서에서, "포함하다" 또는 "가지다" 등의 용어는 설명된 특징, 숫자, 단계, 동작, 구성요소, 부분품 또는 이들을 조합한 것이 존재함으로 지정하려는 것이지, 하나 또는 그 이상의 다른 특징들이나 숫자, 단계, 동작, 구성요소, 부분품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.
다르게 정의되지 않는 한, 기술적이거나 과학적인 용어를 포함해서 여기서 사용되는 모든 용어들은 해당 기술 분야에서 통상의 지식을 가진 자에 의해 일반적으로 이해되는 것과 동일한 의미를 가진다. 일반적으로 사용되는 사전에 정의되어 있는 것과 같은 용어들은 관련 기술의 문맥상 가지는 의미와 일치하는 의미를 갖는 것으로 해석되어야 하며, 본 명세서에서 명백하게 정의하지 않는 한, 이상적이거나 과도하게 형식적인 의미로 해석되지 않는다.
하기에서 설명될 실시예들은 서로 다른 플랫폼을 제공하는 제1 플랫폼 서버 및 제2 플랫폼 서버를 서로 연동시키는 데 사용될 수 있다. 이하, 제1 플랫폼 서버 및 제2 플랫폼 서버를 서로 연동시키는 동작에는 제1 플랫폼 서버 및 제2 플랫폼 서버를 연동시키는 연동 서버의 동작뿐만 아니라 제1 플랫폼 서버 및 제2 플랫폼 서버 각각의 동작, 제1 플랫폼 서버 또는 제2 플랫폼 서버에 등록된 디바이스의 동작도 포함될 수 있다. 이하, 실시예들을 첨부된 도면을 참조하여 상세하게 설명한다. 각 도면에 제시된 동일한 참조 부호는 동일한 부재를 나타낸다.
도 1은 일실시예에 따라 제1 플랫폼 서버, 제2 플랫폼 서버 및 연동 서버로 구성되는 홈 네트워크 시스템을 설명하기 위한 도면이다.
일실시예에 따른 홈 네트워크 시스템(100)은 하나 이상의 가전기기 및/또는 통신기기(이하, 디바이스라고 지칭함)를 포함할 수 있으며, 디바이스는 미리 결정된 플랫폼을 통해 서로 간에 통신을 수행할 수 있다. 이 때, 홈 네트워크 시스템(100)에는 서로 다른 플랫폼을 이용하는 디바이스들이 존재할 수 있으며, 이 경우 디바이스들 간의 통신을 위해 서로 다른 플랫폼을 연동시키는 작업이 선행될 필요가 있다.
이하에서는, 서로 다른 2개의 플랫폼들이 서로 연동되는 케이스를 기준으로 본 발명을 설명한다. 다만, 하기의 설명이 연동되는 플랫폼의 개수를 제한하지 않으며, 3개 이상의 플랫폼들을 연동시키는 경우에도 마찬가지로 적용될 수 있다.
도 1을 참조하면, 홈 네트워크 시스템(100)은 제1 플랫폼 서버(110), 제1 디바이스(111), 제2 플랫폼 서버(120), 제2 디바이스(121), 연동 서버(130)를 포함할 수 있다.
제1 플랫폼 서버(110) 및 제2 플랫폼 서버(120)는 서로 다른 플랫폼을 제공하는 서버이다. 제1 플랫폼 서버(110)에는 하나 이상의 제1 디바이스(111)가 등록될 수 있다. 제1 디바이스(111)는 제1 플랫폼 서버(110)를 통해 다른 제1 디바이스와 통신을 수행할 수 있다. 제1 디바이스(111)는 제1 플랫폼 서버(110)를 통해 통신을 수행할 수 있는 장치로서, 예를 들어, 퍼스널 컴퓨터, 랩톱 컴퓨터, 태블릿 컴퓨터, 스마트 폰, 스마트 가전 기기(예컨대, 스마트 텔레비전, 스마트 냉장고, 스마트 조명기기, 스마트 에어컨(air conditioner), 스마트 세탁기, 스마트 로봇청소기, 스마트 온도센서 등), 지능형 자동차, 웨어러블 장치 등 다양한 형태의 제품으로 구현될 수 있다. 이 때, 제1 플랫폼 서버(110)를 통해 통신을 수행하는 복수의 제1 디바이스들은 제1 플랫폼 서버(110)에 등록된 동일한 사용자 식별정보에 연결된 장치일 수 있다. 사용자 식별정보는 사용자 ID(user identification)를 의미하고, 아래 설명에서는 설명의 편의를 위해 식별정보와 ID는 서로 혼용될 수 있다.
제2 플랫폼 서버(120)에는 하나 이상의 제2 디바이스(121)가 등록될 수 있다. 제2 디바이스(121)는 제2 플랫폼 서버(120)를 통해 다른 제2 디바이스와 통신을 수행할 수 있는 장치로서, 예를 들어, 퍼스널 컴퓨터, 랩톱 컴퓨터, 태블릿 컴퓨터, 스마트 폰, 스마트 가전 기기, 지능형 자동차, 웨어러블 장치 등 다양한 형태의 제품으로 구현될 수 있다. 마찬가지로, 제2 플랫폼 서버(120)를 통해 통신을 수행하는 복수의 제2 디바이스들은 제2 플랫폼 서버(120)에 등록된 동일한 사용자 식별정보에 연결된 장치일 수 있다.
다만, 제1 디바이스(111) 및 제2 디바이스(121)는 서로 다른 플랫폼 서버에 연결되기 때문에, 제1 플랫폼 서버(110) 및 제2 플랫폼 서버(120) 중 어느 하나의 서버만을 이용해서는 통신이 불가능하다. 따라서, 제1 디바이스(111) 및 제2 디바이스(121) 간의 통신을 위해서는 제1 플랫폼 서버(110) 및 제2 플랫폼 서버(120)을 모두 이용해야 하고, 이를 위해 제1 플랫폼 서버(110) 및 제2 플랫폼 서버(120)를 연동시키는 연동 서버(130)가 요구된다.
연동 서버(130)는 서로 다른 플랫폼을 제공하는 제1 플랫폼 서버(110) 및 제2 플랫폼 서버(120)를 연동시키는 서버로서, 제1 플랫폼 서버(110) 및 제2 플랫폼 서버(120)를 연동시킴으로써 제1 플랫폼 서버(110)에 등록된 제1 디바이스(111)와 제2 플랫폼 서버(120)에 등록된 제2 디바이스(121) 간의 통신이 가능할 수 있다. 다시 말해, 연동 서버(130)를 통해, 제1 디바이스(111)가 제2 디바이스(121)를 제어하는 것이 가능하게 될 수 있다. 예를 들어, 사용자는 제1 디바이스(예컨대, 스마트 폰)(111)를 통해 제2 디바이스(예컨대, 스마트 텔레비전, 스마트 에어컨 등)(121)가 온(On) 또는 오프(Off)되었는지 여부 등 상태를 체크하거나 특정 동작을 수행하도록 제어할 수 있다. 이 때, 제1 플랫폼 서버(110)에서 제1 디바이스(111)가 등록된 사용자 식별정보와 제2 플랫폼 서버(120)에서 제2 디바이스(121)가 등록된 사용자 식별정보는 서로 대응될 수 있다.
도 2는 일실시예에 따라 제1 플랫폼 서버, 제2 플랫폼 서버 및 연동 서버의 세부 구성을 나타낸 도면이다.
도 2를 참조하면, 제1 플랫폼 서버(210), 연동 서버(220) 및 제2 플랫폼 서버(230)가 도시된다.
제1 플랫폼 서버(210)는 플랫폼을 제공하기 위한 장치로서, 예를 들어, DM(Device Manager), 미들웨어(middleware), RM(Resource Manager), DB(Data Base), 오픈 API(open application programming interface), 어댑터 라이브러리(adapter library) 및 데이터 포맷 변환부 등을 포함할 수 있다. 여기서, DM은 제1 플랫폼 서버(210)에 등록되는 디바이스를 관리하기 위한 매니저이며, 미들웨어는 홈 네트워크를 통해 디바이스를 발견, 제어 및 센싱을 위한 프로토콜이며, RM은 디바이스에서 발생하는 정보들을 관리하기 위한 매니저일 수 있다. 또한, DB는 디바이스에서 발생하는 정보에 대한 데이터를 저장하기 위한 장치이고, 오픈 API는 해당 플랫폼에서 각 디바이스를 제어하거나 사용자를 관리하기 위한 것일 수 있다.
어댑터 라이브러리는 제1 플랫폼 서버(210)에서 이용하는 메시지를 제1 플랫폼 서버(210)와 연동 서버(220)가 공통으로 사용하는 스탠다드 메시지(standard message)로 변환하거나, 스탠다드 메시지를 제1 플랫폼 서버(210)에서 이용하는 메시지로 변환하는 라이브러리일 수 있다. 어댑터 라이브러리에서 메시지가 변환될 때, 제1 플랫폼 서버(210)에 등록된 제1 사용자 식별정보 및 제1 디바이스 식별정보도 변환될 수도 있다.
데이터 포맷 변환부는 데이터의 포맷을 변환할 수 있다. 예를 들어, 제1 플랫폼 서버(210) 및 제1 디바이스 사이에서 사용되는 데이터 포맷은 제1 플랫폼 서버(210) 및 연동 서버(220) 사이에서 사용되는 데이터 포맷과 다를 수 있다. 따라서, 데이터 포맷 변환부는 제1 디바이스로부터 수신한 데이터를 연동 서버(220)로 전달하거나 연동 서버(220)로부터 수신한 데이터를 제1 디바이스로 전달하는 경우에 데이터를 변환할 수 있다.
연동 서버(220)는 서로 다른 플랫폼을 제공하는 제1 플랫폼 서버(210) 및 제2 플랫폼 서버(230)을 서로 연동시키기 위한 인증 동작 및 라우팅 동작을 수행할 수 있다. 연동 서버(220)는 제1 플랫폼 서버(210)에 등록된 제1 사용자 식별정보 및 제2 플랫폼 서버(230)에 등록된 제2 사용자 식별정보를 서로 매칭시켜 관리할 수 있다. 예를 들어, 연동 서버(220)는 통합 사용자 식별정보를 생성하고, 생성된 통합 사용자 식별정보에 제1 사용자 식별정보 및 제2 사용자 식별정보에 맵핑시킴으로써, 제1 사용자 식별정보 및 제2 사용자 식별정보를 통합하여 관리할 수 있다.
또한, 연동 서버(220)는 라우팅 동작을 통해, 제1 플랫폼 서버(210) 및 제2 플랫폼 서버(230) 간의 데이터 송수신을 지원할 수 있다.
제2 플랫폼 서버(230)는 제1 플랫폼 서버(210)와 상이한 플랫폼을 제공하는 장치로서, 세부 구성에 대해서는 앞서 설명한 제1 플랫폼 서버(210)에 대한 내용이 마찬가지로 적용될 수 있다.
도 3은 다른 일실시예에 따라 제1 플랫폼 서버, 제2 플랫폼 서버 및 연동 서버의 세부 구성을 나타낸 도면이다.
도 3을 참조하면, 다른 일실시예에 따른 제1 플랫폼 서버(310), 제1 어댑터(320), 연동 서버(330), 제2 어댑터(340), 제2 플랫폼 서버(350)가 도시된다.
실시예에 따라서는, 도 2의 제1 플랫폼 서버(210)에 포함된 어댑터 라이브러리, 데이터 포맷 변환부가 제1 플랫폼 서버(310)와 구별되는 별도의 장치로 구현될 수 있다. 다시 말해, 제1 플랫폼 서버(310)와 구별되는 제1 어댑터(320)는 도 2에서 설명한 어댑터 라이브러리, 데이터 포맷 변환부의 동작을 수행할 수 있다. 마찬가지로, 제2 플랫폼 서버(350)와 제2 어댑터(340)도 별도의 장치로 구성될 수 있다.
또한, 연동 서버(330)는 별도의 인증 서버와 라우팅 서버로 구성될 수도 있다. 다시 말해, 도 2에서 설명한 연동 서버(220)의 인증 동작은 인증 서버가 수행하고, 연동 서버(220)의 라우팅 동작은 라우팅 서버가 수행할 수 있다.
이하, 도 4 및 도 5에서는 도 2의 경우와 같이 플랫폼 서버 내에 어댑터 라이브러리가 포함되고, 연동 서버 내에 인증 서버 및 라우팅 서버가 포함되는 케이스를 기준으로 설명하고, 도 6 내지 도 8에서는 도 3의 경우와 같이 플랫폼 서버와 어댑터가 구별되고, 연동 서버가 인증 서버와 라우팅 서버로 나누어지는 케이스를 기준으로 설명한다. 다만, 이는 설명의 편의를 위한 것으로 도 2의 경우를 기준으로 한 설명과 도 3의 경우를 기준으로 한 설명은 다른 경우에도 마찬가지로 적용될 수 있다.
도 4는 일실시예에 따라 인증 서버에 플랫폼 서버를 등록하는 과정을 설명하기 위한 도면이다.
도 4를 참조하면, 서로 다른 플랫폼 서버를 연동시키기에 앞서 플랫폼 서버를 연동 서버(420)에 등록시키는 동작을 설명하기 위한 흐름도가 도시된다.
단계(401)에서, 제1 플랫폼 서버(410)는 연동 서버(420)로 등록을 요청할 수 있다. 예를 들어, 제1 플랫폼 서버(410)는 제1 플랫폼 서버(410)에 대한 설명 및 Federation URL를 연동 서버(420)로 전송함으로써, 등록을 요청할 수 있다. 여기서, Federation URL은 제1 플랫폼 서버(410)에서 제공하는 플랫폼을 이용하는 사용자를 인증하기 위한 URL로서, Federation URL를 통해 해당 플랫폼에 로그인할 수 있는 인터페이스가 제공될 수 있다. 또한, 제1 플랫폼 서버(410)에 대한 설명은 제1 플랫폼 서버(410)를 운영하는 기업에 대한 정보, 제1 플랫폼 서버(410)에서 사용되는 통신방식, 데이터 구조에 대한 정보 등을 포함할 수 있다.
단계(402)에서, 연동 서버(420)는 제1 플랫폼 서버(410)의 등록 요청에 기초하여 제1 플랫폼 서버(410)를 등록할 수 있다. 예를 들어, 연동 서버(420)는 미리 결정된 테이블에 Platform_ID, 설명, Federation URL, Platform_Key를 저장할 수 있다. 여기서, Platform_ID는 플랫폼을 지시하는 플랫폼 식별정보이고, 설명은 해당 플랫폼을 제공하는 기업에 대한 정보, 해당 플랫폼에서 사용하는 통신방식, 데이터 구조에 대한 정보 등을 포함하고, Platform_Key는 플랫폼 인증을 위한 키로서, 해당 플랫폼을 최초로 등록할 때 이용될 수 있다. 연동 서버(420)는 테이블에 등록된 정보를 관리하고 유지할 수 있다.
단계(403)에서, 연동 서버(420)는 제1 플랫폼 서버(410)가 등록되었다는 응답을 전송할 수 있다. 예를 들어, 연동 서버(420)는 제1 플랫폼 서버(410)과 데이터를 주고 받을 수 있는 세션키를 제1 플랫폼 서버(410)로 전달할 수 있다.
도 5는 일실시예에 따라 제1 플랫폼 서버 및 제2 플랫폼 서버를 연동시키는 과정을 설명하기 위한 도면이다.
도 5를 참조하면, 제1 디바이스(510)에 입력된 사용자의 요청에 따라 제1 플랫폼 서버(520)와 제2 플랫폼 서버(540)를 연동시키는 동작을 설명하기 위한 흐름도가 도시된다.
단계(501)에서, 제1 디바이스(510)는 사용자로부터 입력된 타 플랫폼 연동 요청을 제1 플랫폼 서버(520)로 전송할 수 있다. 예를 들어, 사용자는 제1 디바이스(510)의 터치 스크린에 미리 결정된 터치를 입력하거나 제1 디바이스(510)의 버튼을 눌음으로써 타 플랫폼 연동 요청에 대한 명령을 입력할 수 있고, 제1 디바이스(510)는 사용자의 제어에 기초하여 제1 플랫폼 서버(520)로 타 플랫폼 연동 요청을 전송할 수 있다.
단계(502)에서, 제1 플랫폼 서버(520)는 연동 서버(530)로 타 플랫폼 연동 요청을 전달할 수 있다. 예를 들어, 제1 플랫폼 서버(520)는 제1 플랫폼 서버(520)에 등록된 제1 사용자 ID를 타 플랫폼 연동 요청에 포함시켜, 연동 서버(530)로 전송할 수 있다.
단계(503)에서, 연동 서버(530)는 제1 사용자 ID를 등록할 수 있다. 예를 들어, 연동 서버(530)는 맵핑 테이블에 제1 플랫폼 서버(520)로부터 수신한 제1 사용자 ID가 등록되어 있는지 여부를 확인하고, 만약 등록되어 있지 않은 경우에는 제1 사용자 ID에 대응되는 통합 사용자 ID를 생성하고, 제1 사용자 ID를 통합 사용자 ID에 대응시켜서 맵핑 테이블에 등록할 수 있다. 여기서, 통합 사용자 ID는 서로 다른 플랫폼 서버를 연동시키기 위한 사용자 ID로서, 각 플랫폼 서버에 등록된 사용자 ID와 맵핑되어 관리될 수 있다. 만약 맵핑 테이블에 이미 제1 사용자 ID가 등록되어 있는 경우, 단계(503)는 생략될 수 있다.
단계(504)에서, 연동 서버(530)는 통합 사용자 ID에 대응하는 트랜잭션 ID를 생성할 수 있다. 트랜잭션 ID는 서로 다른 플랫폼 서버에 등록된 사용자 ID가 동일한 사용자에 대응된다는 것을 확인하기 위한 정보로서, 관련 없는 사용자 ID가 서로 맵핑되는 것을 방지하기 위해 비교적 짧은 유효시간을 가질 수 있다.
단계(505)에서, 연동 서버(530)는 제1 플랫폼 서버(520)에 연동될 수 있는 플랫폼 리스트 및 트랜잭션 ID를 제1 플랫폼 서버(520)로 전송할 수 있다. 그리고, 제1 플랫폼 서버(520)는 플랫폼 리스트 및 트랜잭션 ID를 제1 디바이스(510)로 전달할 수 있다. 여기서, 플랫폼 리스트는 제1 플랫폼 서버(520)에 연동될 수 있는 플랫폼의 Federation URL을 포함할 수 있다. 나아가, 플랫폼 리스트는 플랫폼 명칭 등 해당 플랫폼에 대한 설명이 더 포함될 수도 있다.
단계(506)에서, 제1 디바이스(510)는 플랫폼 리스트를 사용자로 제공하고, 사용자로부터 플랫폼 리스트에 포함된 플랫폼들 중에서 연동하고자 하는 플랫폼에 대한 선택을 입력 받을 수 있다.
단계(507)에서, 제1 디바이스(510)는 사용자가 선택한 플랫폼을 제공하는 제2 플랫폼 서버(540)로 Federation URL 호출을 전송할 수 있다. 제2 플랫폼 서버(540)로 Federation URL이 호출되면, 제1 디바이스(510)에는 제2 플랫폼 서버(540)에 대한 로그인 화면을 디스플레이하며, 사용자는 해당 화면을 통해 제2 플랫폼 서버(540)에 등록된 로그인 정보(예컨대, 제2 사용자 ID, 패스워드 등)를 입력할 수 있다.
단계(508)에서, 제1 디바이스(510)는 제2 플랫폼 서버(540)의 로그인 정보 및 트랜잭션 ID를 제2 플랫폼 서버(540)로 전송할 수 있다.
단계(509)에서, 제2 플랫폼 서버(540)는 제1 디바이스(510)로부터 수신한 로그인 정보를 확인할 수 있다. 제2 플랫폼 서버(540)는 로그인 정보를 확인함으로써, 연동을 요청한 사용자가 제2 플랫폼 서버(540)에 등록된 정당 사용자인지 여부를 판단할 수 있다. 제1 디바이스(510)로부터 수신한 로그인 정보를 통해 성공적으로 로그인한 경우, 제2 플랫폼 서버(540)는 해당 로그인 정보를 정당한 것으로 확인할 수 있다.
제2 플랫폼 서버(540)에 성공적으로 로그인된 경우, 단계(511)에서, 제2 플랫폼 서버(540)는 로그인 정보에 포함된 제2 사용자 ID와 트랜잭션 ID를 연동 서버(530)로 전송할 수 있다.
단계(512)에서, 연동 서버(530)는 트랜잭션 ID에 기초하여 제2 사용자 ID를 맵핑 테이블에 등록할 수 있다. 연동 서버(530)는 제2 플랫폼 서버(540)로부터 수신한 트랜잭션 ID를 검증할 수 있다. 예를 들어, 연동 서버(530)는 제2 플랫폼 서버(540)로부터 수신한 트랜잭션 ID가 유효한지 여부를 판단하고, 만약 해당 트랜잭션 ID가 유효한 경우, 제2 사용자 ID를 통합 사용자 ID에 대응시켜 맵핑 테이블에 등록할 수 있다. 만약, 미리 결정된 유효시간이 경과되어 트랜잭션 ID가 유효하지 않거나, 통신 도중 트랜잭션 ID가 변형되는 등의 사유로 트랜잭션 ID가 유효하지 않는 경우에는, 연동 서버(530)는 제2 사용자 ID를 맵핑 테이블에 등록하지 않는다.
단계(513)에서, 연동 서버(530)는 단계(512)의 처리 결과를 제2 플랫폼 서버(540)로 통지할 수 있다. 또한, 실시예에 따라서 연동 서버(530)는 타 플랫폼 연동을 요청한 제1 디바이스(510)로 처리 결과를 통지할 수도 있다.
도 6은 일실시예에 따라 타 플랫폼 서버에 등록된 디바이스 리스트를 요청하는 과정을 설명하기 위한 도면이다.
도 6을 참조하면, 제1 디바이스(610)에서 제2 플랫폼 서버(670)에 등록된 제2 디바이스 리스트를 요청하는 과정을 설명하기 위한 흐름도가 도시된다.
일실시예에 따른 제1 디바이스(610)는 제2 디바이스(680)를 제어하기에 앞서 제2 플랫폼 서버(670)에 등록된 제2 디바이스 리스트를 먼저 요청할 수 있다.
단계(601)에서, 제1 디바이스(610)는 제2 디바이스 리스트에 대한 요청을 제1 플랫폼 서버(620)로 전달할 수 있다. 그리고, 제1 플랫폼 서버(620)는 제1 어댑터(630)로 제2 디바이스 리스트에 대한 요청을 전달할 수 있다.
단계(602)에서, 제1 어댑터(630)는 제2 디바이스 리스트 요청을 위한 토큰(예컨대, 액세스 토큰(Access Token))을 인증 서버(640)로 요청할 수 있다. 제1 어댑터(630)는 제2 디바이스 리스트를 요청한 제1 플랫폼 서버(620)의 식별정보, 제2 디바이스(680)가 등록된 제2 플랫폼 서버(670)의 식별정보 및 제2 디바이스 리스트를 요청한 사용자를 나타내는 제1 사용자 ID를 토큰 요청과 함께 인증 서버(640)로 전달할 수 있다.
단계(603)에서, 인증 서버(640)는 제1 어댑터(730)의 토큰 요청에 기초하여 토큰을 생성할 수 있다. 예를 들어, 인증 서버(640)는 제1 사용자 ID에 대응하는 통합 사용자 ID를 암호화함으로써, 토큰을 생성할 수 있다. 이 때, 통합 사용자 ID는 시간에 따라 변경될 수 있다. 따라서, 토큰이 생성되는 시점에 따라 통합 사용자 ID가 다르게 결정되고, 예를 들어, 통합 사용자 ID는 주기적으로 변경될 수 있다.
통합 사용자 ID가 시간에 따라 변경됨으로써, 통합 사용자 ID가 암호화되어 생성되는 토큰도 마찬가지로 시간에 따라 변경될 수 있다. 예를 들어, 제1 시점에 생성된 토큰과 제2 시점에 생성된 토큰은 서로 다른 통합 사용자 ID에 기초하여 생성되고, 제1 시점에 생성된 토큰과 제2 시점에 생성된 토큰은 서로 다를 수 있다. 여기서, 제1 시점과 제2 시점은 미리 결정된 시간적 간격이 있는 시점을 나타낸다. 따라서, 설사 이전에 생성했던 토큰이 유출되더라도 일정한 시간이 경과한 후에는 새로운 토큰이 이용되므로, 서로 다른 플랫폼을 연동시키는 데에 높은 보안성을 유지할 수 있다.
단계(604)에서, 인증 서버(640)는 생성된 토큰을 제1 어댑터(630)로 전송할 수 있다.
단계(605)에서, 제1 어댑터(630)는 라우팅 서버(650)로 제2 디바이스 리스트 요청과 함께 토큰을 전송할 수 있다. 일실시예에 따른 제1 어댑터(630)는 제2 플랫폼 서버(670)만이 해독할 수 있는 키를 이용하여 제2 디바이스 리스트 요청을 암호화하여 전송할 수 있다. 예를 들어, 제1 어댑터(630)는 제2 플랫폼 서버(670)의 공개키로 제2 디바이스 리스트 요청을 암호화함으로써, 제2 플랫폼 서버(670) 이외의 장치(예컨대, 라우팅 서버(650) 등)가 제2 디바이스 리스트 요청을 확인할 수 없도록 할 수 있다. 그리고, 라우팅 서버(650)는 제2 디바이스 리스트 요청과 토큰을 제2 어댑터(660)로 전달할 수 있다.
단계(606)에서, 제2 어댑터(660)는 수신한 토큰이 유효한지 여부에 대한 확인을 인증 서버(640)로 요청할 수 있다. 이 때, 제2 어댑터(660)는 수신한 토큰을 인증 서버(640)로 전송할 수 있다.
단계(607)에서, 인증 서버(640)는 제2 어댑터(660)로부터 수신한 토큰이 유효한지 여부를 확인할 수 있다. 예를 들어, 해당 토큰이 단계(603)에서 생성한 토큰에 해당하는 경우, 인증 서버(640)는 해당 토큰이 유효한 것으로 판단할 수 있다. 해당 토큰이 유효한 경우, 인증 서버(640)는 단계(603)에서 토큰을 생성할 때 이용했던 암호화키에 기초하여 토큰으로부터 통합 사용자 ID를 추출할 수 있다.
단계(608)에서, 인증 서버(640)는 확인 결과를 제2 어댑터(660)에 통보할 수 있다. 만약 해당 토큰이 유효한 경우, 인증 서버(640)는 해당 토큰이 유효하다는 메시지와 통합 사용자 ID에 대응하는 제2 사용자 ID를 제2 어댑터(660)로 전송할 수 있다. 만약 해당 토큰이 유효하지 않는 경우, 인증 서버(640)는 해당 토큰이 유효하지 않다는 메시지만을 제2 어댑터(660)로 전송할 수 있다.
단계(609)에서, 해당 토큰이 유효하다는 메시지를 수신한 제2 어댑터(660)는 제2 디바이스 리스트를 제2 플랫폼 서버(670)로 요청할 수 있다. 이 때, 제2 어댑터(660)는 인증 서버(640)로부터 수신한 제2 사용자 ID와 함께 전송할 수 있다.
단계(611)에서, 제2 플랫폼 서버(670)는 제2 디바이스(680)가 포함된 제2 디바이스 리스트를 제2 어댑터(660)로 전송할 수 있다. 이 때, 제2 디바이스(680)는 제2 플랫폼 서버(670)에서 제2 사용자 ID에 대응되어 등록된 디바이스를 나타낼 수 있다. 예를 들어, 제2 디바이스 리스트에는 "DeviceID" 형식의 제2 디바이스 ID가 포함될 수 있다.
그리고, 제2 어댑터(660)는 제2 디바이스 리스트를 라우팅 서버(650)로 전달할 수 있다. 이 때, 제2 어댑터(660)는 제2 디바이스 리스트에 포함된 제2 디바이스 ID를 제2 플랫폼 서버(670)의 ID와 병합시킬 수 있다. 그래서, 제2 디바이스 리스트에는 "PlatformID@DeviceID" 형식의 제2 디바이스 ID가 포함될 수 있다.
그리고, 라우팅 서버(650)는 제2 디바이스 리스트를 제1 어댑터(630)로 전달하고, 제1 어댑터(630)는 제2 디바이스 리스트를 제1 플랫폼 서버(620)로 전달하며, 제1 플랫폼 서버(620)는 제2 디바이스 리스트를 제1 디바이스(610)로 전달할 수 있다. 제1 디바이스(610)는 제2 디바이스 리스트를 사용자로 제공할 수 있다. 이 때, 제1 플랫폼 서버(620)는 제2 어댑터(670)에서 결정된 "PlatformID@DeviceID" 형식의 제2 디바이스 ID를 그대로 활용할 수도 있고, 또는 제1 플랫폼 서버(620)만의 ID로 변경하여 활용할 수도 있다.
도 7은 일실시예에 따라 타 플랫폼 서버에 등록된 디바이스에 대한 제어를 요청하는 과정을 설명하기 위한 도면이다.
도 7을 참조하면, 제1 디바이스(710)에서 제2 디바이스(780)에 대한 제어를 요청하는 과정을 설명하기 위한 흐름도가 도시된다.
일실시예에 따른 사용자는 제1 디바이스(710)를 통해 제2 디바이스(780)의 동작을 제어할 수 있다. 이 때, 제2 디바이스(780)는 도 6에서 설명한 방법으로 획득한 제2 디바이스 리스트에 포함된 장치일 수 있다. 예를 들어, 사용자는 제1 디바이스(710)를 통해 제2 디바이스(780)에 해당되는 스마트 에어컨을 온(On)시키거나, 제2 디바이스(780)에 해당되는 스마트 조명을 오프(Off)시킬 수 있다.
단계(701)에서, 제1 디바이스(710)는 제2 디바이스(780) 제어에 대한 요청을 제1 플랫폼 서버(720)로 전송할 수 있다. 이 때, 제1 디바이스(710)는 제어의 대상이 되는 제2 디바이스(780)를 나타내는 정보인 제2 디바이스 ID를 제어 요청과 함께 제1 플랫폼 서버(720)로 전송할 수 있고, 이 때, 제2 디바이스 ID에는 제2 디바이스(780) 자체에 대한 ID뿐만 아니라 제2 플랫폼 서버(770)의 ID도 포함될 수 있다(예컨대, "PlatformID@DeviceID" 형식의 제2 디바이스 ID).
그리고 제1 플랫폼 서버(720)는 제2 디바이스 제어 요청을 제1 어댑터(730)로 전달할 수 있다.
단계(702)에서, 제1 어댑터(730)는 제2 디바이스 제어 요청을 위한 토큰을 인증 서버(740)로 요청할 수 있다. 제1 어댑터(730)는 제2 디바이스 제어를 요청하는 제1 플랫폼 서버(710)의 식별정보, 제2 디바이스(780)가 등록된 제2 플랫폼 서버(770)의 식별정보, 제2 디바이스 리스트를 요청한 사용자를 나타내는 제1 사용자 ID를 토큰 요청과 함께 인증 서버(740)로 전달할 수 있다.
단계(703)에서, 인증 서버(740)는 제1 어댑터(730)의 토큰 요청에 기초하여 토큰을 생성할 수 있다. 인증 서버(740)는 제1 사용자 ID에 대응하는 통합 사용자 ID를 암호화함으로써, 토큰을 생성할 수 있다. 이 때, 통합 사용자 ID는 시간에 따라 다르게 결정될 수 있고 그래서 토큰이 생성되는 시점에 따라 통합 사용자 ID도 다르게 결정될 수 있다. 나아가, 통합 사용자 ID가 시간에 따라 다르게 결정됨으로써, 토큰도 마찬가지로 시간에 따라 다르게 결정될 수 있다.
단계(704)에서, 인증 서버(740)는 생성된 토큰을 제1 어댑터(730)로 전송할 수 있다.
단계(705)에서, 제1 어댑터(730)는 라우팅 서버(750)로 제2 디바이스 제어 요청과 함께 토큰을 전송할 수 있다. 그리고, 라우팅 서버(750)는 제2 디바이스 제어 요청과 토큰을 제2 어댑터(760)로 전달할 수 있다.
단계(706)에서, 제2 어댑터(760)는 수신한 토큰이 유효한지 여부에 대한 확인을 인증 서버(740)로 요청할 수 있다. 이 때, 제2 어댑터(760)는 수신한 토큰을 인증 서버(740)로 전송할 수 있다.
단계(707)에서, 인증 서버(740)는 제2 어댑터(760)로부터 수신한 토큰이 유효한지 여부를 확인할 수 있다. 해당 토큰이 유효한 경우, 인증 서버(740)는 단계(703)에서 토큰을 생성할 때 이용했던 암호화키에 기초하여 토큰으로부터 통합 사용자 ID를 추출할 수 있다.
단계(708)에서, 인증 서버(740)는 확인 결과를 제2 어댑터(760)에 통보할 수 있다. 만약 해당 토큰이 유효한 경우, 인증 서버(740)는 해당 토큰이 유효하다는 메시지와 통합 사용자 ID에 대응하는 제2 사용자 ID를 제2 어댑터(760)로 전송할 수 있다.
단계(709)에서, 해당 토큰이 유효하다는 메시지를 수신한 제2 어댑터(760)는 제2 디바이스 제어 요청을 제2 플랫폼 서버(770)로 전송할 수 있다. 이 때, 제2 어댑터(760)는 인증 서버(740)로부터 수신한 제2 사용자 ID와 함께 전송할 수 있다. 제2 어댑터(760)는 제어의 대상이 되는 제2 디바이스(780)를 나타내는 제2 디바이스(780)의 ID에서 제2 플랫폼 서버(770)의 ID를 제거한 나머지(예컨대, "DeviceID" 형식의 제2 디바이스 ID)를 제2 플랫폼 서버(770)로 전달할 수 있다.
그리고, 제2 플랫폼 서버(770)는 제2 사용자 ID에 등록되고 제2 디바이스 ID에 대응되는 제2 디바이스(780)를 식별하고, 식별된 제2 디바이스(780)로 제어를 요청할 수 있다.
제2 디바이스(780)가 제어 요청에 따라 일정한 동작을 수행한 경우, 단계(711)에서, 제2 디바이스(780)는 제어 요청에 따른 처리 결과를 제2 플랫폼 서버(770)로 전송할 수 있다. 이 때, 처리 결과에는 제2 디바이스(780)를 나타내는 제2 디바이스 ID가 "DeviceID" 형식으로 포함될 수 있다.
그리고, 제2 플랫폼 서버(770)는 처리 결과를 제2 어댑터(760)로 전달할 수 있다. 그리고, 제2 어댑터(760)는 처리 결과를 라우팅 서버(750)로 전달할 수 있다. 이 때, 제2 어댑터(760)는 처리 결과에 포함된 제2 디바이스 ID에 제2 플랫폼 서버(770)의 ID를 병합시켜, "PlatformID@DeviceID" 형식의 제2 디바이스 ID를 전달할 수 있다.
그리고, 라우팅 서버(750)는 처리 결과를 제1 어댑터(730)로 전달하고, 제1 어댑터(730)는 처리결과를 제1 플랫폼 서버(720)로 전달하며, 제1 플랫폼 서버(720)는 처리 결과를 제1 디바이스(710)로 전달할 수 있다. 그래서, 제1 디바이스(710)는 제2 디바이스(780)에 대한 처리 결과를 사용자로 제공할 수 있다.
도 7에 도시된 각 단계들에는 도 1 내지 도 6을 통하여 전술한 사항들이 그대로 적용되므로, 보다 상세한 설명은 생략한다.
도 8은 일실시예에 따라 타 플랫폼 서버에 등록된 디바이스에 대한 이벤트 구동을 요청하는 과정을 설명하기 위한 도면이다.
도 8을 참조하면, 제2 디바이스(880)에서 발생한 이벤트에 대한 구독을 요청하는 과정을 설명하기 위한 흐름도가 도시된다.
일실시예에 따른 사용자는 제1 디바이스(810)를 통해 제2 디바이스(880)에서 발생한 이벤트를 통지 받을 수 있다. 이 때, 제2 디바이스(880)는 도 6에서 설명한 방법으로 획득한 제2 디바이스 리스트에 포함된 장치일 수 있다. 예를 들어, 제2 디바이스(880)에 해당하는 스마트 세탁기에서 세탁 작업이 완료되는 이벤트가 발생한 경우, 사용자는 제1 디바이스(810)를 통해 제2 디바이스(880)의 이벤트 발생 사실을 통지 받을 수 있다.
단계(801)에서, 제1 디바이스(810)는 제2 디바이스 이벤트 구독에 대한 요청을 제1 플랫폼 서버(820)로 전송할 수 있다. 이 때, 제1 디바이스(810)는 구독의 대상이 되는 제2 디바이스(880)를 나타내는 정보인 제2 디바이스 ID를 이벤트 구독 요청과 함께 제1 플랫폼 서버(820)로 전송할 수 있고, 이 때, 제2 디바이스 ID에는 제2 디바이스(880) 자체에 대한 ID뿐만 아니라 제2 플랫폼 서버(870)의 ID도 포함될 수 있다(예컨대, "PlatformID@DeviceID" 형식의 제2 디바이스 ID).
그리고 제1 플랫폼 서버(820)는 이벤트 구독 요청을 제1 어댑터(830)로 전달할 수 있다.
단계(802)에서, 제1 어댑터(830)는 이벤트 구독 요청을 위한 토큰을 인증 서버(840)로 요청할 수 있다. 제1 어댑터(830)는 이벤트 구독을 요청하는 제1 플랫폼 서버(820)의 식별정보, 제2 디바이스(880)가 등록된 제2 플랫폼 서버(870)의 식별정보, 제2 디바이스 리스트를 요청한 사용자를 나타내는 제1 사용자 ID를 토큰 요청과 함께 인증 서버(840)로 전달할 수 있다.
단계(803)에서, 인증 서버(840)는 토큰 요청에 기초하여 토큰을 생성할 수 있다. 인증 서버(840)는 제1 사용자 ID에 대응하는 통합 사용자 ID를 암호화함으로써, 토큰을 생성할 수 있다. 이 때, 통합 사용자 ID는 시간에 따라 다르게 결정될 수 있고, 그래서 생성되는 시점에 따라 통합 사용자 ID는 다르게 결정될 수 있다. 통합 사용자 ID가 시간에 따라 다르게 결정됨으로써, 통합 사용자 ID가 암호화되어 생성되는 토큰도 마찬가지로 시간에 따라 다르게 결정될 수 있다.
단계(804)에서, 인증 서버(840)는 생성된 토큰을 제1 어댑터(830)로 전송할 수 있다.
단계(805)에서, 제1 어댑터(830)는 라우팅 서버(850)로 이벤트 구독 요청과 함께 토큰을 전송할 수 있다. 그리고, 라우팅 서버(850)는 이벤트 구독 요청과 토큰을 제2 어댑터(860)로 전달할 수 있다.
단계(806)에서, 제2 어댑터(860)는 수신한 토큰이 유효한지 여부에 대한 확인을 인증 서버(840)로 요청할 수 있다. 이 때, 제2 어댑터(860)는 수신한 토큰을 인증 서버(840)로 전송할 수 있다.
단계(807)에서, 인증 서버(840)는 제2 어댑터(860)로부터 수신한 토큰이 유효한지 여부를 확인할 수 있다. 해당 토큰이 유효한 경우, 인증 서버(840)는 단계(803)에서 토큰을 생성할 때 이용했던 암호화키에 기초하여 토큰으로부터 통합 사용자 ID를 추출할 수 있다.
단계(808)에서, 인증 서버(840)는 확인 결과를 제2 어댑터(860)에 통보할 수 있다. 만약 해당 토큰이 유효한 경우, 인증 서버(840)는 해당 토큰이 유효하다는 메시지와 통합 사용자 ID에 대응하는 제2 사용자 ID를 제2 어댑터(860)로 전송할 수 있다.
단계(809)에서, 해당 토큰이 유효하다는 메시지를 수신한 제2 어댑터(860)는 이벤트 구독 요청을 제2 플랫폼 서버(870)로 전송할 수 있다. 이 때, 제2 어댑터(860)는 인증 서버(840)로부터 수신한 제2 사용자 ID와 함께 전송할 수 있다. 제2 어댑터(860)는 구독의 대상이 되는 제2 디바이스(880)를 나타내는 제2 디바이스 ID에서 제2 플랫폼 서버(870)의 ID를 제거한 나머지(예컨대, "DeviceID" 형식의 제2 디바이스 ID)를 제2 플랫폼 서버(870)로 전달할 수 있다.
그리고, 제2 플랫폼 서버(870)는 제2 사용자 ID에 등록되고 제2 디바이스 ID에 대응되는 제2 디바이스(880)를 식별하고, 식별된 제2 디바이스(880)에서 발생한 이벤트를 감지할 수 있다.
제2 디바이스(880)에서 이벤트가 발생된 경우, 단계(811)에서, 제2 디바이스(880)는 발생한 이벤트를 제2 플랫폼 서버(870)로 통지할 수 있다. 이 때, 이벤트 통지에는 제2 디바이스(880)를 나타내는 제2 디바이스 ID가 "DeviceID" 형식으로 포함될 수 있다.
그리고, 제2 플랫폼 서버(870)는 이벤트를 제2 어댑터(860)로 통지할 수 있다. 그리고, 제2 어댑터(860)는 이벤트를 라우팅 서버(850)로 통지할 수 있다. 이 때, 제2 어댑터(860)는 이벤트 통지에 포함된 제2 디바이스(880)의 ID에 제2 플랫폼 서버(870)의 ID를 병합시켜, "PlatformID@DeviceID" 형식으로 제2 디바이스(880)의 ID를 전달할 수 있다.
그리고, 라우팅 서버(850)는 이벤트를 제1 어댑터(830)로 통지하고, 제1 어댑터(830)는 이벤트를 제1 플랫폼 서버(820)로 통지하며, 제1 플랫폼 서버(820)는 이벤트를 제1 디바이스(810)로 통지할 수 있다. 그래서, 제1 디바이스(810)는 제2 디바이스(880)에서 발생한 이벤트에 대한 정보를 사용자로 제공할 수 있다.
도 8에 도시된 각 단계들에는 도 1 내지 도 6을 통하여 전술한 사항들이 그대로 적용되므로, 보다 상세한 설명은 생략한다.
도 9는 일실시예에 따라 연동 서버의 통신 방법을 나타낸 도면이다.
도 9를 참조하면, 연동 서버에 구비된 프로세서에 의해 수행되는 연동 서버의 통신 방법이 도시된다.
단계(910)에서, 연동 서버는 제1 플랫폼 서버로부터 제1 플랫폼 서버에 등록된 제1 사용자 식별정보를 포함하는 토큰 요청을 수신한다.
단계(920)에서, 연동 서버는 제1 사용자 식별정보에 대응하는 통합 사용자 식별정보로부터 생성된 토큰을 제1 플랫폼 서버로 전송한다. 연동 서버는 시간에 따라 변경되는 통합 사용자 식별정보를 암호화함으로써, 토큰을 생성할 수 있다.
단계(930)에서, 연동 서버는 제1 플랫폼 서버로부터 제2 플랫폼 서버로 전달된 토큰이 유효한지 여부에 대한 확인 요청을 제2 플랫폼 서버로부터 수신한다.
토큰이 유효한 경우, 단계(940)에서 연동 서버는 통합 사용자 식별정보에 대응하고 제2 플랫폼 서버에 등록된 제2 사용자 식별정보를 제2 플랫폼 서버로 전달한다.
여기서, 제1 사용자 식별정보 및 제2 사용자 식별정보 각각은 제1 플랫폼 서버 및 제2 플랫폼 서버에 가입한 동일한 사용자를 식별하는 정보일 수 있다. 또한, 통합 사용자 식별정보는 제1 사용자 식별정보 및 제2 사용자 식별정보에 맵핑될 수 있다.
일실시예에 따른 연동 서버는 단계(910)를 수행하기에 앞서 하기의 동작들을 수행할 수 있다. 연동 서버는 제1 플랫폼 서버로부터 제1 사용자 식별정보를 포함하는 타 플랫폼 연동 요청을 수신할 수 있다. 그리고, 연동 서버는 제1 플랫폼 서버에 연동될 수 있는 플랫폼 리스트 및 통합 사용자 식별정보에 기초하여 생성된 트랜잭션 식별정보를 제1 플랫폼 서버로 전송할 수 있다. 그리고, 연동 서버는 플랫폼 리스트를 통해 제2 플랫폼 서버에 성공적으로 로그인한 경우, 제2 플랫폼 서버로부터 제2 사용자 식별정보 및 트랜잭션 식별정보를 수신할 수 있다. 그리고, 연동 서버는 트랜잭션 식별정보가 유효한 경우, 제2 사용자 식별정보를 통합 사용자 식별정보 및 제1 사용자 식별정보에 맵핑할 수 있다.
이 때, 연동 서버는 트랜잭션 식별정보에 대한 유효시간이 만료되기 전에 제2 플랫폼 서버로부터 트랜잭션 식별정보를 수신하여 트랜잭션 식별정보가 유효한 것으로 판단된 경우, 제2 사용자 식별정보를 통합 사용자 식별정보 및 제2 사용자 식별정보에 맵핑할 수 있다.
또한, 플랫폼 리스트는 제1 플랫폼 서버에 연동되는 플랫폼에 로그인할 수 있는 인터페이스를 제공하는 Federation URL을 포함할 수 있다.
도 9에 도시된 각 단계들에는 도 1 내지 도 8을 통하여 전술한 사항들이 그대로 적용되므로, 보다 상세한 설명은 생략한다.
도 10은 일실시예에 따라 제1 플랫폼 서버의 통신 방법을 나타낸 도면이다.
도 10을 참조하면, 제1 플랫폼 서버에 구비된 프로세서에 의해 수행되는 제1 플랫폼 서버의 통신 방법이 도시된다.
단계(1010)에서, 제1 플랫폼 서버는 연동 서버로 제1 플랫폼 서버에 등록된 제1 사용자 식별정보를 포함하는 토큰 요청을 전송한다.
단계(1020)에서, 제1 플랫폼 서버는 제1 사용자 식별정보에 대응하는 통합 사용자 식별정보로부터 생성된 토큰을 연동 서버로부터 수신한다.
단계(1030)에서, 제1 플랫폼 서버는 제2 플랫폼 서버로 토큰 및 제2 플랫폼 서버에 등록된 디바이스에 대한 요청을 전송한다. 여기서, 디바이스에 대한 요청은 제2 플랫폼 서버에 등록된 디바이스 리스트, 디바이스에 대한 제어, 디바이스에 대한 이벤트 구독 중 적어도 하나에 대한 요청을 포함할 수 있다.
단계(1040)에서, 제1 플랫폼 서버는 제2 플랫폼 서버로부터 디바이스에 대한 요청의 처리 결과를 수신한다.
이 때, 제2 플랫폼 서버는 제1 플랫폼 서버로부터 제2 플랫폼 서버로 전달된 토큰을 유효한 것으로 판단한 연동 서버로부터 통합 사용자 식별정보에 대응하고 제2 플랫폼 서버에 등록된 제2 사용자 식별정보를 수신한 경우, 디바이스에 대한 요청에 따른 처리 결과를 제1 플랫폼 서버로 전송한다.
일실시예에 따른 제1 플랫폼 서버는 단계(1010)를 수행하기에 앞서 아래의 동작들을 먼저 수행할 수 있다. 제1 플랫폼 서버는 연동 서버로 제1 사용자 식별정보를 포함하는 타 플랫폼 연동 요청을 전송할 수 있다. 그리고, 제1 플랫폼 서버는 연동 서버로부터 제1 플랫폼 서버와 연동될 수 있는 플랫폼 리스트 및 제1 사용자 식별정보에 대응하는 트랜잭션 식별정보를 수신할 수 있다. 그리고, 제1 플랫폼 서버는 플랫폼 리스트를 통해 제2 플랫폼 서버에 대한 로그인 정보 및 트랜잭션 식별정보를 전송할 수 있다.
여기서, 로그인 정보에 포함된 제2 사용자 식별정보는 제2 플랫폼 서버에 성공적으로 로그인한 경우에 제2 플랫폼 서버로부터 연동 서버로 전송되어 통합 사용자 식별정보 및 제1 플랫폼 사용자 식별정보에 맵핑될 수 있다.
도 10에 도시된 각 단계들에는 도 1 내지 도 8을 통하여 전술한 사항들이 그대로 적용되므로, 보다 상세한 설명은 생략한다.
도 11은 일실시예에 따라 제2 플랫폼 서버의 통신 방법을 나타낸 도면이다.
도 11을 참조하면, 제2 플랫폼 서버에 구비된 프로세서에 의해 수행되는 제2 플랫폼 서버의 통신 방법이 도시된다.
단계(1110)에서, 제2 플랫폼 서버는 제1 플랫폼 서버로부터 토큰 및 2 플랫폼 서버에 등록된 디바이스에 대한 요청을 수신한다. 이 때, 토큰은 제1 플랫폼 서버의 요청에 응답하여 제1 플랫폼 서버에 등록된 제1 사용자 식별정보에 대응하는 통합 사용자 식별정보로부터 생성될 수 있다.
단계(1120)에서, 제2 플랫폼 서버는 연동 서버로 토큰이 유효한지 여부에 대한 확인 요청을 전송할 수 있다.
단계(1130)에서, 제2 플랫폼 서버는 토큰을 유효한 것으로 판단한 연동 서버로부터 통합 사용자 식별정보에 대응하고 제2 플랫폼 서버에 등록된 제2 사용자 식별정보를 수신할 수 있다.
일실시예에 따른 제2 플랫폼 서버는 단계(1110)를 수행하기에 앞서 아래의 동작들을 먼저 수행할 수 있다. 제2 플랫폼 서버는 타 플랫폼 연동을 요청한 제1 플랫폼 서버로부터 제2 플랫폼 서버에 대한 로그인 정보 및 통합 사용자 식별정보에 대응하는 트랜잭션 식별정보를 수신할 수 있다. 그리고, 제2 플랫폼 서버는 로그인 정보에 기초한 제2 플랫폼 서버에 성공적으로 로그인한 경우에 트랜잭션 식별정보 및 제2 사용자 식별정보를 연동 서버로 전송할 수 있다.
여기서, 제2 사용자 식별정보는 제2 플랫폼 서버로부터 수신된 트랜잭션 식별정보가 유효한 것으로 판단한 연동 서버에 의해 통합 사용자 식별정보 및 제1 플랫폼 사용자 식별정보에 맵핑될 수 있다.
도 11에 도시된 각 단계들에는 도 1 내지 도 8을 통하여 전술한 사항들이 그대로 적용되므로, 보다 상세한 설명은 생략한다.
도 12는 일실시예에 따른 연동 서버를 나타낸 도면이다.
도 12을 참조하면, 연동 서버(1200)는 메모리(1210), 프로세서(1220)를 포함한다. 연동 서버(1200)는 홈 네트워크 시스템에 포함된 다른 장치와 통신을 수행하는 통신부(1230)를 더 포함할 수 있다.
메모리(1210)는 프로세서(1220)에 의해 수행될 수 있는 통신 방법을 저장할 수 있다.
프로세서(1220)는 제1 플랫폼 서버로부터 제1 플랫폼 서버에 등록된 제1 사용자 식별정보를 포함하는 토큰 요청을 수신한다. 그리고, 프로세서(1220)는 제1 사용자 식별정보에 대응하는 통합 사용자 식별정보로부터 생성된 토큰을 제1 플랫폼 서버로 전송한다. 그리고, 프로세서(1220)는 제1 플랫폼 서버로부터 제2 플랫폼 서버로 전달된 토큰이 유효한지 여부에 대한 확인 요청을 제2 플랫폼 서버로부터 수신한다. 그리고, 프로세서(1220)는 토큰이 유효한 경우에 통합 사용자 식별정보에 대응하고 제2 플랫폼 서버에 등록된 제2 사용자 식별정보를 제2 플랫폼 서버로 전달한다.
도 12에 도시된 각 구성요소들에는 도 1 내지 도 9를 통하여 전술한 사항들이 그대로 적용되므로, 보다 상세한 설명은 생략한다.
이상에서 설명된 실시예들은 하드웨어 구성요소, 소프트웨어 구성요소, 및/또는 하드웨어 구성요소 및 소프트웨어 구성요소의 조합으로 구현될 수 있다. 예를 들어, 실시예들에서 설명된 장치, 방법 및 구성요소는, 예를 들어, 프로세서, 콘트롤러, ALU(arithmetic logic unit), 디지털 신호 프로세서(digital signal processor), 마이크로컴퓨터, FPGA(field programmable gate array), PLU(programmable logic unit), 마이크로프로세서, 또는 명령(instruction)을 실행하고 응답할 수 있는 다른 어떠한 장치와 같이, 하나 이상의 범용 컴퓨터 또는 특수 목적 컴퓨터를 이용하여 구현될 수 있다. 처리 장치는 운영 체제(OS) 및 상기 운영 체제 상에서 수행되는 하나 이상의 소프트웨어 애플리케이션을 수행할 수 있다. 또한, 처리 장치는 소프트웨어의 실행에 응답하여, 데이터를 접근, 저장, 조작, 처리 및 생성할 수도 있다. 이해의 편의를 위하여, 처리 장치는 하나가 사용되는 것으로 설명된 경우도 있지만, 해당 기술분야에서 통상의 지식을 가진 자는, 처리 장치가 복수 개의 처리 요소(processing element) 및/또는 복수 유형의 처리 요소를 포함할 수 있음을 알 수 있다. 예를 들어, 처리 장치는 복수 개의 프로세서 또는 하나의 프로세서 및 하나의 콘트롤러를 포함할 수 있다. 또한, 병렬 프로세서(parallel processor)와 같은, 다른 처리 구성(processing configuration)도 가능하다.
소프트웨어는 컴퓨터 프로그램(computer program), 코드(code), 명령(instruction), 또는 이들 중 하나 이상의 조합을 포함할 수 있으며, 원하는 대로 동작하도록 처리 장치를 구성하거나 독립적으로 또는 결합적으로(collectively) 처리 장치를 명령할 수 있다. 소프트웨어 및/또는 데이터는, 처리 장치에 의하여 해석되거나 처리 장치에 명령 또는 데이터를 제공하기 위하여, 어떤 유형의 기계, 구성요소(component), 물리적 장치, 가상 장치(virtual equipment), 컴퓨터 저장 매체 또는 장치, 또는 전송되는 신호 파(signal wave)에 영구적으로, 또는 일시적으로 구체화(embody)될 수 있다. 소프트웨어는 네트워크로 연결된 컴퓨터 시스템 상에 분산되어서, 분산된 방법으로 저장되거나 실행될 수도 있다. 소프트웨어 및 데이터는 하나 이상의 컴퓨터 판독 가능 기록 매체에 저장될 수 있다.
실시예에 따른 방법은 다양한 컴퓨터 수단을 통하여 수행될 수 있는 프로그램 명령 형태로 구현되어 컴퓨터 판독 가능 매체에 기록될 수 있다. 상기 컴퓨터 판독 가능 매체는 프로그램 명령, 데이터 파일, 데이터 구조 등을 단독으로 또는 조합하여 포함할 수 있다. 상기 매체에 기록되는 프로그램 명령은 실시예를 위하여 특별히 설계되고 구성된 것들이거나 컴퓨터 소프트웨어 당업자에게 공지되어 사용 가능한 것일 수도 있다. 컴퓨터 판독 가능 기록 매체의 예에는 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체(magnetic media), CD-ROM, DVD와 같은 광기록 매체(optical media), 플롭티컬 디스크(floptical disk)와 같은 자기-광 매체(magneto-optical media), 및 롬(ROM), 램(RAM), 플래시 메모리 등과 같은 프로그램 명령을 저장하고 수행하도록 특별히 구성된 하드웨어 장치가 포함된다. 프로그램 명령의 예에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함한다. 상기된 하드웨어 장치는 실시예의 동작을 수행하기 위해 하나 이상의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지이다.
실시예들에서 설명된 구성요소들은 하나 이상의 DSP (Digital Signal Processor), 프로세서 (Processor), 컨트롤러 (Controller), ASIC (Application Specific Integrated Circuit), FPGA (Field Programmable Gate Array)와 같은 프로그래머블 논리 소자 (Programmable Logic Element), 다른 전자 기기들 및 이것들의 조합 중 하나 이상을 포함하는 하드웨어 구성 요소들(hardware componests)에 의해 구현될 수 있다. 실시예들에서 설명된 기능들(functions) 또는 프로세스들(processes) 중 적어도 일부는 소프트웨어(software)에 의해 구현될 수 있고, 해당 소프트웨어는 기록 매체(recording medium)에 기록될 수 있다. 실시예들에서 설명된 구성요소들, 기능들 및 프로세스들은 하드웨어와 소프트웨어의 조합에 의해 구현될 수 있다.
이상과 같이 실시예들이 비록 한정된 도면에 의해 설명되었으나, 해당 기술분야에서 통상의 지식을 가진 자라면 상기를 기초로 다양한 기술적 수정 및 변형을 적용할 수 있다. 예를 들어, 설명된 기술들이 설명된 방법과 다른 순서로 수행되거나, 및/또는 설명된 시스템, 구조, 장치, 회로 등의 구성요소들이 설명된 방법과 다른 형태로 결합 또는 조합되거나, 다른 구성요소 또는 균등물에 의하여 대치되거나 치환되더라도 적절한 결과가 달성될 수 있다.
100: 홈 네트워크 시스템
110: 제1 플랫폼 서버
111: 제1 디바이스
120: 제2 플랫폼 서버
121: 제2 디바이스

Claims (18)

  1. 서로 다른 플랫폼을 제공하는 제1 플랫폼 서버 및 제2 플랫폼 서버를 연동시키는 연동 서버의 통신 방법에 있어서,
    상기 제1 플랫폼 서버로부터 상기 제1 플랫폼 서버에 등록된 제1 사용자 식별정보를 포함하는 토큰 요청을 수신하는 단계;
    상기 제1 사용자 식별정보에 대응하는 통합 사용자 식별정보로부터 생성된 토큰을 상기 제1 플랫폼 서버로 전송하는 단계;
    상기 제1 플랫폼 서버로부터 상기 제2 플랫폼 서버로 전달된 토큰이 유효한지 여부에 대한 확인 요청을 상기 제2 플랫폼 서버로부터 수신하는 단계; 및
    상기 토큰이 유효한 경우, 상기 통합 사용자 식별정보에 대응하고 상기 제2 플랫폼 서버에 등록된 제2 사용자 식별정보를 상기 제2 플랫폼 서버로 전달하는 단계
    를 포함하는 통신 방법.
  2. 제1항에 있어서,
    상기 통합 사용자 식별정보로부터 생성된 토큰은,
    시간에 따라 변경되는 통합 사용자 식별정보가 암호화됨으로써 생성되는, 통신 방법.
  3. 제1항에 있어서,
    상기 제1 사용자 식별정보 및 상기 제2 사용자 식별정보 각각은,
    상기 제1 플랫폼 서버 및 상기 제2 플랫폼 서버에 가입한 동일한 사용자를 식별하는 정보이고,
    상기 통합 사용자 식별정보는,
    상기 제1 사용자 식별정보 및 상기 제2 사용자 식별정보에 맵핑되는, 통신 방법.
  4. 제1항에 있어서,
    상기 제1 플랫폼 서버로부터 상기 제1 사용자 식별정보를 포함하는 타 플랫폼 연동 요청을 수신하는 단계;
    상기 제1 플랫폼 서버에 연동될 수 있는 플랫폼 리스트 및 상기 통합 사용자 식별정보에 기초하여 생성된 트랜잭션 식별정보를 상기 제1 플랫폼 서버로 전송하는 단계;
    상기 플랫폼 리스트를 통해 상기 제2 플랫폼 서버에 성공적으로 로그인한 경우, 상기 제2 플랫폼 서버로부터 상기 제2 사용자 식별정보 및 상기 트랜잭션 식별정보를 수신하는 단계; 및
    상기 트랜잭션 식별정보가 유효한 경우, 상기 제2 사용자 식별정보를 상기 통합 사용자 식별정보 및 상기 제1 사용자 식별정보에 맵핑하는 단계
    를 더 포함하는, 통신 방법.
  5. 제4항에 있어서,
    상기 제2 사용자 식별정보를 상기 통합 사용자 식별정보 및 상기 제2 사용자 식별정보에 맵핑하는 단계는,
    상기 트랜잭션 식별정보에 대한 유효시간이 만료되기 전에 상기 제2 플랫폼 서버로부터 상기 트랜잭션 식별정보를 수신하여 상기 트랜잭션 식별정보가 유효한 것으로 판단된 경우, 상기 제2 사용자 식별정보를 상기 통합 사용자 식별정보 및 상기 제2 사용자 식별정보에 맵핑하는, 통신 방법.
  6. 제4항에 있어서,
    상기 플랫폼 리스트는,
    상기 제1 플랫폼 서버에 연동되는 플랫폼에 로그인할 수 있는 인터페이스를 제공하는 Federation URL을 포함하는, 통신 방법.
  7. 연동 서버를 통해 서로 다른 플랫폼을 제공하는 제2 플랫폼 서버에 연동되는 제1 플랫폼 서버의 통신 방법에 있어서,
    상기 연동 서버로 상기 제1 플랫폼 서버에 등록된 제1 사용자 식별정보를 포함하는 토큰 요청을 전송하는 단계;
    상기 제1 사용자 식별정보에 대응하는 통합 사용자 식별정보로부터 생성된 토큰을 상기 연동 서버로부터 수신하는 단계;
    상기 제2 플랫폼 서버로 상기 토큰 및 상기 제2 플랫폼 서버에 등록된 디바이스에 대한 요청을 전송하는 단계; 및
    상기 제2 플랫폼 서버로부터 상기 디바이스에 대한 요청의 처리 결과를 수신하는 단계
    를 포함하고,
    상기 제2 플랫폼 서버는,
    상기 제1 플랫폼 서버로부터 상기 제2 플랫폼 서버로 전달된 토큰을 유효한 것으로 판단한 상기 연동 서버로부터 상기 통합 사용자 식별정보에 대응하고 상기 제2 플랫폼 서버에 등록된 제2 사용자 식별정보를 수신한 경우, 상기 디바이스에 대한 요청에 따른 처리 결과를 상기 제1 플랫폼 서버로 전송하는 통신 방법.
  8. 제7항에 있어서,
    상기 디바이스에 대한 요청은,
    상기 제2 플랫폼 서버에 등록된 디바이스 리스트, 상기 디바이스에 대한 제어, 상기 디바이스에 대한 이벤트 구독 중 적어도 하나에 대한 요청을 포함하는, 통신 방법.
  9. 제7항에 있어서,
    상기 연동 서버로 상기 제1 사용자 식별정보를 포함하는 타 플랫폼 연동 요청을 전송하는 단계;
    상기 연동 서버로부터 상기 제1 플랫폼 서버와 연동될 수 있는 플랫폼 리스트 및 상기 통합 사용자 식별정보에 기초하여 생성된 트랜잭션 식별정보를 수신하는 단계; 및
    상기 플랫폼 리스트를 통해 상기 제2 플랫폼 서버에 대한 로그인 정보 및 상기 트랜잭션 식별정보를 전송하는 단계
    를 더 포함하고,
    상기 로그인 정보에 포함된 제2 사용자 식별정보는,
    상기 제2 플랫폼 서버에 성공적으로 로그인한 경우, 상기 제2 플랫폼 서버로부터 상기 연동 서버로 전송되어 상기 통합 사용자 식별정보 및 상기 제1 플랫폼 사용자 식별정보에 맵핑되는, 통신 방법.
  10. 제7항에 있어서,
    상기 통합 사용자 식별정보로부터 생성된 토큰은,
    시간에 따라 변경되는 상기 통합 사용자 식별정보를 암호화함으로써 생성되는, 통신 방법.
  11. 제7항에 있어서,
    상기 제1 사용자 식별정보 및 상기 제2 사용자 식별정보 각각은,
    상기 제1 플랫폼 서버 및 상기 제2 플랫폼 서버에 가입한 동일한 사용자를 식별하는 정보이고,
    상기 통합 사용자 식별정보는,
    상기 제1 사용자 식별정보 및 상기 제2 사용자 식별정보에 맵핑되는, 통신 방법.
  12. 연동 서버를 통해 서로 다른 플랫폼을 제공하는 제1 플랫폼 서버에 연동되는 제2 플랫폼 서버의 통신 방법에 있어서,
    상기 제1 플랫폼 서버로부터 토큰 및 상기 제2 플랫폼 서버에 등록된 디바이스에 대한 요청을 수신하는 단계 -토큰은, 상기 제1 플랫폼 서버의 요청에 응답하여 상기 제1 플랫폼 서버에 등록된 제1 사용자 식별정보에 대응하는 통합 사용자 식별정보로부터 생성됨 -;
    상기 연동 서버로 상기 토큰이 유효한지 여부에 대한 확인 요청을 전송하는 단계;
    상기 토큰을 유효한 것으로 판단한 상기 연동 서버로부터 상기 통합 사용자 식별정보에 대응하고 제2 플랫폼 서버에 등록된 제2 사용자 식별정보를 수신하는 단계
    를 포함하는 통신 방법.
  13. 제12항에 있어서,
    상기 통합 사용자 식별정보로부터 생성된 토큰은,
    시간에 따라 변경되는 통합 사용자 식별정보가 암호화됨으로써 생성되는, 통신 방법.
  14. 제12항에 있어서,
    상기 디바이스에 대한 요청은,
    상기 제2 플랫폼 서버에 등록된 디바이스 리스트, 상기 디바이스에 대한 제어, 상기 디바이스에 대한 이벤트 구독 중 적어도 하나에 대한 요청을 포함하는, 통신 방법.
  15. 제12항에 있어서,
    상기 디바이스에 대한 요청의 처리 결과를 상기 디바이스 식별정보 및 상기 제2 플랫폼 서버 식별정보와 함께 상기 제1 플랫폼 서버로 전송하는 단계
    를 더 포함하는, 통신 방법.
  16. 제12항에 있어서,
    타 플랫폼 연동을 요청한 상기 제1 플랫폼 서버로부터 상기 제2 플랫폼 서버에 대한 로그인 정보 및 상기 통합 사용자 식별정보에 대응하는 트랜잭션 식별정보를 수신하는 단계; 및
    상기 로그인 정보에 기초한 제2 플랫폼 서버에 성공적으로 로그인한 경우, 상기 트랜잭션 식별정보 및 상기 제2 사용자 식별정보를 상기 연동 서버로 전송하는 단계
    를 더 포함하고,
    상기 제2 사용자 식별정보는,
    상기 제2 플랫폼 서버로부터 수신된 상기 트랜잭션 식별정보가 유효한 것으로 판단한 상기 연동 서버에 의해 상기 통합 사용자 식별정보 및 상기 제1 플랫폼 사용자 식별정보에 맵핑되는, 통신 방법.
  17. 제12항에 있어서,
    상기 제1 사용자 식별정보 및 상기 제2 사용자 식별정보 각각은,
    상기 제1 플랫폼 서버 및 상기 제2 플랫폼 서버에 가입한 동일한 사용자를 식별하는 정보이고,
    상기 통합 사용자 식별정보는,
    상기 제1 사용자 식별정보 및 상기 제2 사용자 식별정보에 맵핑되는, 통신 방법.
  18. 서로 다른 플랫폼을 제공하는 제1 플랫폼 서버 및 제2 플랫폼 서버 간의 연동을 위한 연동 서버에 있어서,
    통신 방법이 저장된 메모리; 및
    상기 통신 방법을 수행하는 프로세서
    를 포함하고,
    상기 프로세서는,
    상기 제1 플랫폼 서버로부터 상기 제1 플랫폼 서버에 등록된 제1 사용자 식별정보를 포함하는 토큰 요청을 수신하고,
    상기 제1 사용자 식별정보에 대응하는 통합 사용자 식별정보로부터 생성된 토큰을 상기 제1 플랫폼 서버로 전송하고,
    상기 제1 플랫폼 서버로부터 상기 제2 플랫폼 서버로 전달된 토큰이 유효한지 여부에 대한 확인 요청을 상기 제2 플랫폼 서버로부터 수신하며,
    상기 토큰이 유효한 경우, 상기 통합 사용자 식별정보에 대응하고 상기 제2 플랫폼 서버에 등록된 제2 사용자 식별정보를 상기 제2 플랫폼 서버로 전달하는 연동 서버.
KR1020160131915A 2015-11-19 2016-10-12 이종 플랫폼 간 통신 방법 및 장치 KR101952925B1 (ko)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US15/353,953 US10476857B2 (en) 2015-11-19 2016-11-17 Method and apparatus for communication between heterogeneous platforms

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
KR1020150162859 2015-11-19
KR20150162859 2015-11-19

Publications (2)

Publication Number Publication Date
KR20170058847A true KR20170058847A (ko) 2017-05-29
KR101952925B1 KR101952925B1 (ko) 2019-02-28

Family

ID=59053668

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020160131915A KR101952925B1 (ko) 2015-11-19 2016-10-12 이종 플랫폼 간 통신 방법 및 장치

Country Status (1)

Country Link
KR (1) KR101952925B1 (ko)

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110321176A1 (en) * 2010-06-28 2011-12-29 Canon Kabushiki Kaisha Authority transfer system, authority transfer method, information processing apparatus, and recording medium
US20140122198A1 (en) * 2012-10-29 2014-05-01 Trialpay, Inc. Affiliate network tracking for online-to-offline transactions

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110321176A1 (en) * 2010-06-28 2011-12-29 Canon Kabushiki Kaisha Authority transfer system, authority transfer method, information processing apparatus, and recording medium
US20140122198A1 (en) * 2012-10-29 2014-05-01 Trialpay, Inc. Affiliate network tracking for online-to-offline transactions

Also Published As

Publication number Publication date
KR101952925B1 (ko) 2019-02-28

Similar Documents

Publication Publication Date Title
US11777926B2 (en) Internet of things (IoT) device management
EP3672148B1 (en) Home appliance, network connection system for home appliance and network connection method of home appliance
US10826704B2 (en) Blockchain key storage on SIM devices
US8588990B2 (en) Communicating through a server between appliances and applications
WO2018161807A1 (zh) 用户身份校验方法及装置
US9043600B2 (en) Security model for industrial devices
US9548975B2 (en) Authentication method, authentication system, and service delivery server
WO2019153701A1 (zh) 一种获得设备标识的方法及装置
EP1855440B1 (en) Personal domain controller
CN110235424A (zh) 用于在通信***中提供和管理安全信息的设备和方法
US10419900B2 (en) Method and apparatus for managing application terminal remotely in wireless communication system
US10476857B2 (en) Method and apparatus for communication between heterogeneous platforms
US20190020469A1 (en) Method for the authentication of a first electronic entity by a second electronic entity, and electronic entity implementing such a method
CN105099985A (zh) 多应用程序登录实现方法和装置
WO2018196686A1 (zh) 一种服务响应方法及其中间件
JP2014534515A (ja) ユーザーのアクセス許可の方法、システム、クライアントおよびサーバ
US9549366B2 (en) Method and apparatus for providing network access to a connecting apparatus
JP5727661B2 (ja) 認証方法、認証システム、サービス提供サーバ、および認証サーバ
CN111567076B (zh) 用户终端设备、电子设备、包括它们的***及控制方法
JP2005322033A (ja) 情報配信システム、情報配信サーバ、端末機器、情報配信方法、情報受信方法、情報処理プログラム、及び記憶媒体
CN112333214B (zh) 一种用于物联网设备管理的安全用户认证方法及***
McPherson et al. Using smartphones to enable low-cost secure consumer IoT devices
KR20160149926A (ko) 토큰 서버 인증을 이용한 홈네트워크 기기의 원격 제어 시스템 및 방법
KR101952925B1 (ko) 이종 플랫폼 간 통신 방법 및 장치
EP3534629B1 (en) Dynamic data package access for mobile device

Legal Events

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