KR20180089682A - Electronic apparatus and method for verifing data integrity based on a blockchain - Google Patents

Electronic apparatus and method for verifing data integrity based on a blockchain Download PDF

Info

Publication number
KR20180089682A
KR20180089682A KR1020170014325A KR20170014325A KR20180089682A KR 20180089682 A KR20180089682 A KR 20180089682A KR 1020170014325 A KR1020170014325 A KR 1020170014325A KR 20170014325 A KR20170014325 A KR 20170014325A KR 20180089682 A KR20180089682 A KR 20180089682A
Authority
KR
South Korea
Prior art keywords
data
stored
integrity
server
block chain
Prior art date
Application number
KR1020170014325A
Other languages
Korean (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 KR1020170014325A priority Critical patent/KR20180089682A/en
Priority to PCT/KR2018/001388 priority patent/WO2018143694A1/en
Publication of KR20180089682A publication Critical patent/KR20180089682A/en

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/32Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
    • H04L9/3263Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials involving certificates, e.g. public key certificate [PKC] or attribute certificate [AC]; Public key infrastructure [PKI] arrangements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/06Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/06Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
    • H04L9/0618Block ciphers, i.e. encrypting groups of characters of a plain text message using fixed encryption transformation
    • H04L9/0637Modes of operation, e.g. cipher block chaining [CBC], electronic codebook [ECB] or Galois/counter mode [GCM]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/06Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
    • H04L9/0643Hash functions, e.g. MD5, SHA, HMAC or f9 MAC
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/32Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Power Engineering (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)

Abstract

The present invention is to verify the integrity of data. The present invention relates to an electronic apparatus and method for verifying the integrity of data stored in a server using a block chain. To this end, the present invention relates to a server for verifying the integrity of data. The server comprises a memory for storing at least one piece of data; and a processor for grouping the stored data, chaining the elements of the grouped data, and storing the chained data in a block chain. It is possible to improve the reliability of data stored in the server.

Description

블록체인 기반의 데이터의 무결성을 검증하는 전자 장치 및 방법{ELECTRONIC APPARATUS AND METHOD FOR VERIFING DATA INTEGRITY BASED ON A BLOCKCHAIN}BACKGROUND OF THE INVENTION 1. Field of the Invention [0001] The present invention relates to an electronic device and a method for verifying the integrity of data based on a block chain,

본 발명은 데이터의 무결성을 검증하는 것으로서, 서버에 저장된 데이터의 무결성을 블록체인을 이용하여 검증하는 전자 장치 및 방법에 관한 것이다.The present invention relates to an electronic device and method for verifying the integrity of data, which verifies the integrity of data stored in a server using a block chain.

일반적으로 블록 체인(blockchain)은 P2P(peer-to-peer) 네트워크에 의해 생성되고 관리되는 위변조 불가능한 분산 저장소이다. 블록 체인은 트랜잭션(쌍방간의 쪼갤 수 없는 단위 작업)으로 생성된 데이터 블록들을 체인(chain) 형태로 잇따라 연결한 모음을 의미한다. 이전 블록에 다름 블록을 연이어 암호화하고 과반수가 넘는 사용자가 동의한 데이터를 실제 데이터로 인정하기 때문에, 한번 기록된 데이터는 위조 또는 변조가 불가능하다. 블록 체인의 대표적인 응용사례는 암호화폐의 거래 과정을 기록하는 분산화된 전자 화폐인 비트코인(bitcoin)이 있다. 블록 체인에는 일정 시간 동안 사용자들 간에 발생되는 확정된 거래 내역이 저장될 수 있다. 그리고, 많은 사용자들은 블록 체인 사본을 각자 갖고 있으며, 거래 내역은 모두에게 공개될 수 있다. 이와 같이, 과반수가 넘는 사용자가 동의한 거래 내역만 실제 데이터로 인정되고, 영구적으로 보관할 블록으로 묶여 저장될 수 있다. In general, a blockchain is a non-forgivable distributed storage that is created and managed by a peer-to-peer (P2P) network. A block chain is a collection of data blocks created in a transaction (a non-breakable unit operation between the two parties) connected in a chain. Once recorded, the data can not be falsified or altered because the difference blocks in the previous block are consecutively encrypted and more than half of the user's agreed data is recognized as actual data. A typical example of a block chain is a bitcoin, which is a decentralized electronic money that records the transaction process of cryptography. In the block chain, a definite transaction history generated between users for a predetermined time can be stored. And many users have copies of the block chain, and transactions can be made public. In this way, only the transaction details agreed to by more than a half of the users are recognized as actual data, and can be stored in a block to be permanently stored.

종래에는 서버(예: 데이터 베이스)에 저장된 데이터의 무결성을 향상시키기 위해 블록 체인을 활용하지 않았으며, 블록 체인을 이용하여 서버에 저장된 중요한 데이터가 위조 되었는지 또는 변조되었는지를 검출하지 않았을 뿐만 아니라, 데이터의 무결성 역시 보장받지도 못하였다.Conventionally, a block chain is not utilized to improve the integrity of data stored in a server (e.g., a database). In addition to not detecting whether important data stored in a server has been falsified or altered using a block chain, The integrity of the system was not guaranteed.

따라서, 서버에 저장된 데이터의 안정성이 요구됨에 따라, 서버에 저장된 데이터의 신뢰성을 향상시키는 필요성이 제기된다.Therefore, as the stability of the data stored in the server is required, there is a need to improve the reliability of the data stored in the server.

본 발명의 다양한 실시 예는 블록 체인에 기반하여 서버에 저장된 데이터의 신뢰성을 향상시키는 데이터의 무결성을 검증하는 전자 장치 및 방법을 제공할 수 있다. 또한, 상기 서버에 연결된 전자 장치에서 데이터의 무결성을 검증할 수 있다.Various embodiments of the present invention may provide an electronic device and method for verifying the integrity of data that improves the reliability of data stored in a server based on a block chain. In addition, the integrity of the data may be verified in an electronic device connected to the server.

이를 위해, 본 발명의 다양한 실시 예는 데이터의 무결성을 검증하는 서버에 있어서, 적어도 하나의 데이터를 저장하는 메모리; 및 상기 저장된 데이터를 그룹화하고, 상기 그룹화된 데이터의 요소들을 체인화하고, 상기 체인화된 데이터를 블록체인(blockchain)에 저장하는 프로세서를 포함할 수 있다.To this end, various embodiments of the present invention provide a server for verifying the integrity of data, comprising: a memory for storing at least one data; And a processor for grouping the stored data, chaining elements of the grouped data, and storing the chained data in a block chain.

또한, 본 발명의 다양한 실시 예는 서버에서 데이터의 무결성을 검증하는 방법에 있어서, 메모리에 저장된 적어도 하나의 데이터를 그룹화하는 동작; 상기 그룹화된 데이터를 체인화하는 동작; 및 상기 체인화된 데이터를 블록체인에 저장하는 동작을 포함할 수 있다.Also, various embodiments of the present invention provide a method of verifying the integrity of data in a server, comprising: grouping at least one data stored in a memory; Chaining the grouped data; And storing the chained data in a block chain.

또한, 본 발명의 다양한 실시 예는 데이터의 무결성을 검증하는 전자 장치에 있어서, 서버로부터 수신되는 증명서를 저장하는 메모리; 및 상기 저장된 증명서에 기반하여 블록체인에 저장된 데이터의 요소들을 블록체인 네트워크에 요청하여 획득하고, 상기 획득된 요소들과 그룹화된 데이터를 비교하여 무결성을 검증하는 적어도 하나의 프로세서를 포함할 수 있다.Also, various embodiments of the present invention provide an electronic device for verifying the integrity of data, comprising: a memory for storing a certificate received from a server; And at least one processor for requesting and obtaining elements of data stored in the block chain based on the stored certificate in a block-chain network, and verifying integrity by comparing the grouped data with the obtained elements.

본 발명의 다양한 실시 예에 따르면, 서버에 저장된 데이터의 무결성을 검증하는 전자 장치 및 방법을 제공함으로써 데이터의 안정성을 향상시킬 수 있다.According to various embodiments of the present invention, the stability of data can be improved by providing an electronic device and method for verifying the integrity of data stored in a server.

또한, 본 발명은 서버에 저장된 데이터의 위조 또는 변조를 방지함으로써, 데이터의 신뢰성을 향상시킬 수 있다.Further, the present invention can prevent the data stored in the server from being falsified or altered, thereby improving the reliability of the data.

또한, 본 발명은 사용자 자신이 직접 자신의 데이터의 무결성 여부를 판단할 수 있다.In addition, the present invention can directly determine whether the user himself / herself is data integrity.

도 1은 다양한 실시 예에 따른 데이터의 무결성을 검증하는 네트워크 구성도이다.
도 2는 다양한 실시 예에 따른 데이터의 무결성을 검증하는 서버와 전자 장치의 블럭도이다.
도 3은 본 발명의 다양한 실시 예에 따른 서버에서 데이터를 그룹화하여 블록체인에 저장하는 과정을 나타낸 순서도이다.
도 4a는 본 발명의 일 실시 예에 따른 서버가 데이터의 무결성을 검증하는 과정을 나타낸 순서도이다.
도 4b는 본 발명의 일 실시 예에 따른 전자 장치가 데이터의 무결성을 검증하는 과정을 나타낸 순서도이다.
도 5는 본 발명의 일 실시 예에 따른 데이터를 그룹화하고, 상기 그룹화된 데이터의 요소들을 체인화하여 블록 체인에 저장하는 예시도이다.
1 is a network configuration diagram for verifying the integrity of data according to various embodiments.
2 is a block diagram of a server and an electronic device for verifying the integrity of data according to various embodiments.
FIG. 3 is a flowchart illustrating a process of grouping data in a server according to various embodiments of the present invention and storing the data in a block chain.
4A is a flowchart illustrating a process of verifying integrity of data by a server according to an exemplary embodiment of the present invention.
4B is a flowchart illustrating a process of verifying integrity of data by an electronic device according to an exemplary embodiment of the present invention.
FIG. 5 illustrates an example of grouping data according to an embodiment of the present invention, and chaining elements of the grouped data and storing them in a block chain.

이하, 본 문서의 다양한 실시예가 첨부된 도면을 참조하여 기재된다. 그러나, 이는 본 문서에 기재된 기술을 특정한 실시 형태에 대해 한정하려는 것이 아니며, 본 문서의 실시예의 다양한 변경(modifications), 균등물(equivalents), 및/또는 대체물(alternatives)을 포함하는 것으로 이해되어야 한다. 도면의 설명과 관련하여, 유사한 구성요소에 대해서는 유사한 참조 부호가 사용될 수 있다.Hereinafter, various embodiments of the present document will be described with reference to the accompanying drawings. It should be understood, however, that this invention is not intended to be limited to the particular embodiments described herein but includes various modifications, equivalents, and / or alternatives of the embodiments of this document . In connection with the description of the drawings, like reference numerals may be used for similar components.

본 문서에서, "가진다," "가질 수 있다," "포함한다," 또는 "포함할 수 있다" 등의 표현은 해당 특징(예: 수치, 기능, 동작, 또는 부품 등의 구성요소)의 존재를 가리키며, 추가적인 특징의 존재를 배제하지 않는다.In this document, the expressions "having," " having, "" comprising," or &Quot;, and does not exclude the presence of additional features.

본 문서에서, "A 또는 B," "A 또는/및 B 중 적어도 하나," 또는 "A 또는/및 B 중 하나 또는 그 이상"등의 표현은 함께 나열된 항목들의 모든 가능한 조합을 포함할 수 있다. 예를 들면, "A 또는 B," "A 및 B 중 적어도 하나," 또는 "A 또는 B 중 적어도 하나"는, (1) 적어도 하나의 A를 포함, (2) 적어도 하나의 B를 포함, 또는 (3) 적어도 하나의 A 및 적어도 하나의 B 모두를 포함하는 경우를 모두 지칭할 수 있다.In this document, the expressions "A or B," "at least one of A or / and B," or "one or more of A and / or B," etc. may include all possible combinations of the listed items . For example, "A or B," "at least one of A and B," or "at least one of A or B" includes (1) at least one A, (2) Or (3) at least one A and at least one B all together.

본 문서에서 사용된 "제 1," "제 2," "첫째," 또는 "둘째,"등의 표현들은 다양한 구성요소들을, 순서 및/또는 중요도에 상관없이 수식할 수 있고, 한 구성요소를 다른 구성요소와 구분하기 위해 사용될 뿐 해당 구성요소들을 한정하지 않는다. 예를 들면, 제 1 사용자 기기와 제 2 사용자 기기는, 순서 또는 중요도와 무관하게, 서로 다른 사용자 기기를 나타낼 수 있다. 예를 들면, 본 문서에 기재된 권리 범위를 벗어나지 않으면서 제 1 구성요소는 제 2 구성요소로 명명될 수 있고, 유사하게 제 2 구성요소도 제 1 구성요소로 바꾸어 명명될 수 있다.As used herein, the terms "first," "second," "first," or "second," and the like may denote various components, regardless of their order and / or importance, But is used to distinguish it from other components and does not limit the components. For example, the first user equipment and the second user equipment may represent different user equipment, regardless of order or importance. For example, without departing from the scope of the rights described in this document, the first component can be named as the second component, and similarly the second component can also be named as the first component.

어떤 구성요소(예: 제 1 구성요소)가 다른 구성요소(예: 제 2 구성요소)에 "(기능적으로 또는 통신적으로) 연결되어((operatively or communicatively) coupled with/to)" 있다거나 "접속되어(connected to)" 있다고 언급된 때에는, 상기 어떤 구성요소가 상기 다른 구성요소에 직접적으로 연결되거나, 다른 구성요소(예: 제 3 구성요소)를 통하여 연결될 수 있다고 이해되어야 할 것이다. 반면에, 어떤 구성요소(예: 제 1 구성요소)가 다른 구성요소(예: 제 2 구성요소)에 "직접 연결되어" 있다거나 "직접 접속되어" 있다고 언급된 때에는, 상기 어떤 구성요소와 상기 다른 구성요소 사이에 다른 구성요소(예: 제 3 구성요소)가 존재하지 않는 것으로 이해될 수 있다.(Or functionally or communicatively) coupled with / to "another component (eg, a second component), or a component (eg, a second component) Quot; connected to ", it is to be understood that any such element may be directly connected to the other element or may be connected through another element (e.g., a third element). On the other hand, when it is mentioned that a component (e.g., a first component) is "directly connected" or "directly connected" to another component (e.g., a second component) It can be understood that there is no other component (e.g., a third component) between other components.

본 문서에서 사용된 표현 "~하도록 구성된(또는 설정된)(configured to)"은 상황에 따라, 예를 들면, "~에 적합한(suitable for)," "~하는 능력을 가지는(having the capacity to)," "~하도록 설계된(designed to)," "~하도록 변경된(adapted to)," "~하도록 만들어진(made to)," 또는 "~를 할 수 있는(capable of)"과 바꾸어 사용될 수 있다. 용어 "~하도록 구성된(또는 설정된)"은 하드웨어적으로 "특별히 설계된(specifically designed to)" 것만을 반드시 의미하지 않을 수 있다. 대신, 어떤 상황에서는, "~하도록 구성된 장치"라는 표현은, 그 장치가 다른 장치 또는 부품들과 함께 "~할 수 있는" 것을 의미할 수 있다. 예를 들면, 문구 "A, B, 및 C를 수행하도록 구성된(또는 설정된) 프로세서"는 해당 동작을 수행하기 위한 전용 프로세서(예: 임베디드 프로세서), 또는 메모리 장치에 저장된 하나 이상의 소프트웨어 프로그램들을 실행함으로써, 해당 동작들을 수행할 수 있는 범용 프로세서(generic-purpose processor)(예: CPU 또는 application processor)를 의미할 수 있다. As used herein, the phrase " configured to " (or set) to be "configured according to circumstances may include, for example, having the capacity to, To be designed to, "" adapted to, "" made to, "or" capable of ". The term " configured to (or set up) "may not necessarily mean" specifically designed to "in hardware. Instead, in some situations, the expression "configured to" may mean that the device can "do " with other devices or components. For example, a processor configured (or configured) to perform the phrases "A, B, and C" may be implemented by executing one or more software programs stored in a memory device or a dedicated processor (e.g., an embedded processor) , And a generic-purpose processor (e.g., a CPU or an application processor) capable of performing the corresponding operations.

본 문서에서 사용된 용어들은 단지 특정한 실시예를 설명하기 위해 사용된 것으로, 다른 실시 예의 범위를 한정하려는 의도가 아닐 수 있다. 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함할 수 있다. 기술적이거나 과학적인 용어를 포함해서 여기서 사용되는 용어들은 본 문서에 기재된 기술 분야에서 통상의 지식을 가진 자에 의해 일반적으로 이해되는 것과 동일한 의미를 가질 수 있다. 본 문서에 사용된 용어들 중 일반적인 사전에 정의된 용어들은, 관련 기술의 문맥상 가지는 의미와 동일 또는 유사한 의미로 해석될 수 있으며, 본 문서에서 명백하게 정의되지 않는 한, 이상적이거나 과도하게 형식적인 의미로 해석되지 않는다. 경우에 따라서, 본 문서에서 정의된 용어일지라도 본 문서의 실시예들을 배제하도록 해석될 수 없다.The terminology used herein is for the purpose of describing particular embodiments only and is not intended to limit the scope of the other embodiments. The singular expressions may include plural expressions unless the context clearly dictates otherwise. Terms used herein, including technical or scientific terms, may have the same meaning as commonly understood by one of ordinary skill in the art. The general predefined terms used in this document may be interpreted in the same or similar sense as the contextual meanings of the related art and, unless expressly defined in this document, include ideally or excessively formal meanings . In some cases, even the terms defined in this document can not be construed as excluding the embodiments of this document.

본 문서의 다양한 실시예들에 따른 전자 장치는, 예를 들면, 스마트폰(smartphone), 태블릿 PC(tablet personal computer), 이동 전화기(mobile phone), 영상 전화기, 전자책 리더기(e-book reader), 데스크탑 PC(desktop personal computer), 랩탑 PC(laptop personal computer), 넷북 컴퓨터(netbook computer), 워크스테이션(workstation), 서버, PDA(personal digital assistant), PMP(portable multimedia player), MP3 플레이어, 모바일 의료기기, 카메라(camera), 또는 웨어러블 장치(wearable device) 중 적어도 하나를 포함할 수 있다. 다양한 실시예에 따르면, 웨어러블 장치는 액세서리형(예: 시계, 반지, 팔찌, 발찌, 목걸이, 안경, 콘택트 렌즈, 또는 머리 착용형 장치(head-mounted-device(HMD)), 직물 또는 의류 일체형(예: 전자 의복), 신체 부착형(예: 스킨 패드(skin pad) 또는 문신), 또는 생체 이식형(예: implantable circuit) 중 적어도 하나를 포함할 수 있다. An electronic device according to various embodiments of the present document may be, for example, a smartphone, a tablet personal computer, a mobile phone, a video phone, an e-book reader, A desktop personal computer, a laptop personal computer, a netbook computer, a workstation, a server, a personal digital assistant (PDA), a portable multimedia player (PMP) A medical device, a camera, or a wearable device. According to various embodiments, the wearable device may be of the accessory type (e.g., a watch, a ring, a bracelet, a bracelet, a necklace, a pair of glasses, a contact lens or a head-mounted-device (HMD) (E. G., Electronic apparel), a body attachment type (e. G., A skin pad or tattoo), or a bioimplantable type (e.g., implantable circuit).

어떤 실시예들에서, 전자 장치는 가전 제품(home appliance)일 수 있다. 가전 제품은, 예를 들면, 텔레비전, DVD(digital video disk) 플레이어, 오디오, 냉장고, 에어컨, 청소기, 오븐, 전자레인지, 세탁기, 공기 청정기, 셋톱 박스(set-top box), 홈 오토매이션 컨트롤 패널(home automation control panel), 보안 컨트롤 패널(security control panel), TV 박스(예: 삼성 HomeSyncTM, 애플TVTM, 또는 구글 TVTM), 게임 콘솔(예: XboxTM, PlayStationTM), 전자 사전, 전자 키, 캠코더(camcorder), 충전 장치 또는 전자 액자 중 적어도 하나를 포함할 수 있다.In some embodiments, the electronic device may be a home appliance. Home appliances include, for example, televisions, digital video disc (DVD) players, audio, refrigerators, air conditioners, vacuum cleaners, ovens, microwaves, washing machines, air cleaners, set- Such as a home automation control panel, a security control panel, a TV box such as Samsung HomeSync TM , Apple TV TM or Google TV TM , a game console such as Xbox TM and PlayStation TM , , An electronic key, a camcorder, a charging device, or an electronic photo frame.

다른 실시예에서, 전자 장치는, 각종 의료기기(예: 각종 휴대용 의료측정기기(혈당 측정기, 심박 측정기, 혈압 측정기, 또는 체온 측정기 등), MRA(magnetic resonance angiography), MRI(magnetic resonance imaging), CT(computed tomography), 촬영기, 또는 초음파기 등), 네비게이션(navigation) 장치, 위성 항법 시스템(GNSS(global navigation satellite system)), EDR(event data recorder), FDR(flight data recorder), 자동차 인포테인먼트(infotainment) 장치, 선박용 전자 장비(예: 선박용 항법 장치, 자이로 콤파스 등), 항공 전자기기(avionics), 보안 기기, 차량용 헤드 유닛(head unit), 산업용 또는 가정용 로봇, 금융 기관의 ATM(automatic teller's machine), 상점의 POS(point of sales), 또는 사물 인터넷 장치(internet of things)(예: 전구, 각종 센서, 전기 또는 가스 미터기, 스프링클러 장치, 화재경보기, 온도조절기(thermostat), 가로등, 토스터(toaster), 운동기구, 온수탱크, 히터, 보일러 등) 중 적어도 하나를 포함할 수 있다.In an alternative embodiment, the electronic device may be any of a variety of medical devices (e.g., various portable medical measurement devices such as a blood glucose meter, a heart rate meter, a blood pressure meter, or a body temperature meter), magnetic resonance angiography (MRA) Navigation systems, global navigation satellite systems (GNSS), event data recorders (EDRs), flight data recorders (FDRs), infotainment (infotainment) systems, ) Automotive electronic equipment (eg marine navigation systems, gyro compass, etc.), avionics, security devices, head units for vehicles, industrial or home robots, automatic teller's machines (ATMs) Point of sale, or internet of things (eg, light bulbs, various sensors, electrical or gas meters, sprinkler devices, fire alarms, thermostats, street lights, Of the emitter (toaster), exercise equipment, hot water tank, a heater, boiler, etc.) may include at least one.

어떤 실시예에 따르면, 전자 장치는 가구(furniture) 또는 건물/구조물의 일부, 전자 보드(electronic board), 전자 사인 수신 장치(electronic signature receiving device), 프로젝터(projector), 또는 각종 계측 기기(예: 수도, 전기, 가스, 또는 전파 계측 기기 등) 중 적어도 하나를 포함할 수 있다. 다양한 실시예에서, 전자 장치는 전술한 다양한 장치들 중 하나 또는 그 이상의 조합일 수 있다. 어떤 실시예에 따른 전자 장치는 플렉서블 전자 장치일 수 있다. 또한, 본 문서의 실시예에 따른 전자 장치는 전술한 기기들에 한정되지 않으며, 기술 발전에 따른 새로운 전자 장치를 포함할 수 있다.According to some embodiments, the electronic device is a piece of furniture or a part of a building / structure, an electronic board, an electronic signature receiving device, a projector, Water, electricity, gas, or radio wave measuring instruments, etc.). In various embodiments, the electronic device may be a combination of one or more of the various devices described above. An electronic device according to some embodiments may be a flexible electronic device. Further, the electronic device according to the embodiment of the present document is not limited to the above-described devices, and may include a new electronic device according to technological advancement.

이하, 첨부 도면을 참조하여, 다양한 실시예에 따른 전자 장치가 설명된다. 본 문서에서, 사용자라는 용어는 전자 장치를 사용하는 사람 또는 전자 장치를 사용하는 장치(예: 인공지능 전자 장치)를 지칭할 수 있다.DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS An electronic apparatus according to various embodiments will now be described with reference to the accompanying drawings. In this document, the term user may refer to a person using an electronic device or a device using an electronic device (e.g., an artificial intelligence electronic device).

도 1은 본 발명의 다양한 실시 예에 따른 데이터의 무결성을 검증하는 네트워크 구성도이다.1 is a network configuration diagram for verifying the integrity of data according to various embodiments of the present invention.

도 1을 참조하면, 본 발명의 다양한 실시 예에 따른 데이터의 무결성을 검증하는 네트워크(100)는 서버(101)와 적어도 하나의 전자 장치(102-1~102-5)를 포함할 수 있다. 본 발명은 서버에 저장된 중요한 데이터를 그룹화하여 블록 체인에 저장한 후, 데이터의 위조 또는 변조를 검증할 수 있다.Referring to FIG. 1, a network 100 for verifying the integrity of data according to various embodiments of the present invention may include a server 101 and at least one electronic device 102-1 through 102-5. The present invention can group important data stored in a server and store them in a block chain, and then verify falsification or tampering of the data.

다양한 실시 예에 따른 서버(101)는 적어도 하나의 전자 장치(102-1~102-5)와 유무선을 통해 연결될 수 있다. 상기 서버(101)는, 메모리(240)에 저장된 데이터를 그룹화하고, 상기 그룹화된 데이터의 요소들을 체인화하고, 상기 체인화된 데이터를 상기 메모리(240)의 블록체인(block chain)에 저장할 수 있다. 상기 서버(101)는 메모리(240)의 데이터 저장 영역(241)에 저장된 적어도 하나의 데이터를 체인 스케일러(chain scaler)를 이용하여 그룹화할 수 있다. 상기 서버(101)는 체인 스케일러를 이용해 그룹화된 데이터를 사슬 형태로 메모리(240)에 저장할 수 있다. 상기 서버(101)는 상기 그룹화된 데이터에 포함된 적어도 하나의 요소들을 블록체인(242)에 저장할 수 있다. 상기 서버(101)는 메모리(240)의 데이터 저장 영역(241)에 저장된 복수의 데이터들을 미리 결정된 개수 단위로 그룹화할 수 있다. 상기 서버(101)는 미리 결정된 시간, 미리 결정된 데이터 개수 및 데이터의 중요도 중 적어도 하나에 기반하여 상기 메모리(240)에 저장된 복수의 데이터를 그룹화할 수 있다. 상기 서버(101)는 상기 메모리(240)에 저장된 적어도 하나의 데이터에 기반하여 머클 해쉬(merkle hash)를 생성하고, 상기 생성된 머클 해쉬가 포함되도록 복수의 데이터를 그룹화할 수 있다. The server 101 according to various embodiments may be connected to at least one electronic device 102-1 through 102-5 via wired or wireless. The server 101 may group the data stored in the memory 240, chain the elements of the grouped data, and store the chained data in a block chain of the memory 240. The server 101 may group at least one data stored in the data storage area 241 of the memory 240 using a chain scaler. The server 101 may store the grouped data in the memory 240 in a chain form using a chain scaler. The server 101 may store in the block chain 242 at least one element included in the grouped data. The server 101 may group a plurality of data stored in the data storage area 241 of the memory 240 into a predetermined number of units. The server 101 may group a plurality of data stored in the memory 240 based on at least one of a predetermined time, a predetermined number of data, and an importance of data. The server 101 may generate a merkle hash based on at least one piece of data stored in the memory 240 and group the plurality of pieces of data so that the generated hasle hash is included.

다양한 실시 예에 따르면, 상기 서버(101)는, 상기 저장할 내용을 블록체인 트랜잭션으로 만들어 블록체인 네트워크에 참여한 적어도 하나의 전자 장치(102)로 전송할 수 있다. 상기 블록체인 트랜잭션에 저장할 데이터는 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함할 수 있다. 상기 서버(101)는 미리 결정된 시간 및 상기 저장된 데이터의 개수 중 적어도 하나에 기반하여 상기 저장된 블록체인에 저장된 적어도 하나의 요소와 상기 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교하여 상기 저장된 데이터의 무결성을 검증할 수 있다. 상기 서버(101)는 상기 저장된 데이터가 무결성하지 않는 경우, 입출력 인터페이스(230)를 통해 상기 무결성 여부를 출력할 수 있다. 상기 서버(101)는 상기 저장된 데이터가 위조 또는 변조되거나 손상된 경우, 상기 서버(101)를 관리하는 관리자가 이러한 사항을 알 수 있도록 입출력 인터페이스(230)를 통해 상기 무결성 여부를 출력할 수 있다. 상기 프로세서(210)는 상기 저장된 블록체인의 무결성 여부를 판단하기 위한 증명서(certificate)를 생성하여 적어도 하나의 전자 장치로 전송할 수 있다. 상기 증명서는, 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 저장된 블록체인의 정보를 포함할 수 있다. 상기 증명서는 전자 장치(102)가 데이터의 무결성 여부를 판단하는데 이용될 수 있다. 상기 프로세서(210)는 상기 저장된 블록체인에 대한 적어도 하나의 요소의 요청이 상기 적어도 하나의 전자 장치로부터 수신되면, 상기 요청된 적어도 하나의 요소를 상기 전자 장치로 전송할 수 있다.According to various embodiments, the server 101 may make the stored content into a block-chained transaction and send it to at least one electronic device 102 participating in a block-chain network. The data to be stored in the block-chain transaction may include a merge hash identifier, a group identifier, and an identifier of the previous group. The server 101 compares at least one element included in the grouped data with at least one element stored in the stored block chain based on at least one of a predetermined time and the number of stored data, Integrity can be verified. If the stored data is not integrity, the server 101 may output the integrity status through the input / output interface 230. The server 101 may output the integrity information through the input / output interface 230 so that the administrator managing the server 101 can recognize such information if the stored data is falsified, altered, or damaged. The processor 210 may generate a certificate for determining integrity of the stored block chain and transmit the certificate to at least one electronic device. The certificate may include information of the stored at least one piece of data, information of the grouped data, and information of the stored block chain. The certificate may be used by the electronic device 102 to determine whether the data is integrity. The processor 210 may send the requested at least one element to the electronic device if a request for at least one element for the stored block chain is received from the at least one electronic device.

다양한 실시 예에 따른 전자 장치(102)는, 서버(101)로부터 수신되어 메모리(280)에 저장된 증명서에 기반하여 블록체인(281)에 저장된 요소들을 상기 서버(101)로 요청할 수 있다. 상기 전자 장치(102)는 메모리(280)에 저장된 증명서를 이용하여 상기 메모리(280)에 저장된 블록체인(281)에 저장된 요소들에 대응하는 그룹화된 데이터를 상기 서버(101)로 요청할 수 있다. 상기 메모리(280)는 서버(101)에서 그룹화된 각각의 데이터에 대한 적어도 하나의 블록체인을 저장할 수 있다. 상기 전자 장치(102)는 상기 획득된 요소들과 상기 그룹화된 데이터를 비교하여 데이터의 무결성을 검증할 수 있다. 상기 전자 장치(102)는 미리 결정된 시간 및 저장된 데이터의 개수 중 적어도 하나에 기반하여 블록체인에 저장된 적어도 하나의 요소와 상기 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교하여 상기 데이터의 무결성을 검증할 수 있다. 예를 들면, 상기 전자 장치(102)는 상기 데이터가 무결성하지 않는 경우, 상기 입출력인터페이스(270) 및 상기 디스플레이(290) 중 적어도 하나를 통해 무결성 여부를 출력할 수 있다.The electronic device 102 according to various embodiments may request the server 101 to store elements stored in the block chain 281 based on a certificate received from the server 101 and stored in the memory 280. [ The electronic device 102 may request the server 101 to use the grouped data corresponding to the elements stored in the block chain 281 stored in the memory 280 using the certificate stored in the memory 280. [ The memory 280 may store at least one block chain for each data grouped in the server 101. The electronic device 102 may verify the integrity of the data by comparing the obtained elements with the grouped data. The electronic device 102 compares at least one element contained in the grouped data with at least one element stored in a block chain based on at least one of a predetermined time and a number of stored data to verify the integrity of the data can do. For example, the electronic device 102 may output integrity through at least one of the input / output interface 270 and the display 290 if the data is not integrity.

도 2는 다양한 실시 예에 따른 데이터의 무결성을 검증하는 서버와 전자 장치의 블럭도이다.2 is a block diagram of a server and an electronic device for verifying the integrity of data according to various embodiments.

도 2를 참조하면, 서버(101)는 프로세서(210), 통신인터페이스(220), 입출력인터페이스(230) 및 메모리(240)를 포함할 수 있다. 전자 장치(102)는 프로세서(250), 통신인터페이스(260), 입출력인터페이스(270), 메모리(280) 및 디스플레이(290)를 포함할 수 있다. 본 발명은 서버에 저장된 중요한 데이터를 그룹화하여 블록 체인에 저장한 후, 데이터의 위조 또는 변조를 검증할 수 있다. 본 발명은 서버가 데이터를 그룹화하여 블록 체인에 저장한 후, 데이터의 위조 또는 변조를 검증할 수 있다. 또는, 본 발명은 전자 장치가 서버에 저장된 데이터의 위조 또는 변조를 검증할 수 있다.Referring to FIG. 2, the server 101 may include a processor 210, a communication interface 220, an input / output interface 230, and a memory 240. The electronic device 102 may include a processor 250, a communication interface 260, an input / output interface 270, a memory 280 and a display 290. The present invention can group important data stored in a server and store them in a block chain, and then verify falsification or tampering of the data. The present invention allows a server to group data and store it in a block chain, and then verify falsification or tampering of the data. Alternatively, the present invention can verify the forgery or tampering of data stored in the server by the electronic device.

다양한 실시 예에 따르면, 상기 서버(101)의 통신인터페이스(220) 또는 상기 전자 장치(102)의 통신인터페이스(260)는 적어도 하나의 전자 장치(102) 또는 서버(101)간의 통신을 설정할 수 있다. 예를 들면, 통신 인터페이스(220, 260)는 무선 통신 또는 유선 통신을 통해서 네트워크에 연결되어 적어도 하나의 전자 장치(102) 또는 서버(101)와 통신할 수 있다. 무선 통신은, 예를 들면, 셀룰러 통신 프로토콜로서, 예를 들면, LTE(long-term evolution), 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) 등 중 적어도 하나를 사용할 수 있다. 또한, 무선 통신은, 예를 들면, 근거리 통신(164)을 포함할 수 있다. 근거리 통신은, 예를 들면, WiFi(wireless fidelity), 블루투스(Bluetooth) 또는 NFC(near field communication) 등 중 적어도 하나를 포함할 수 있다. 유선 통신은, 예를 들면, USB(universal serial bus), HDMI(high definition multimedia interface), RS-232(recommended standard232), 또는 POTS(plain old telephone service) 등 중 적어도 하나를 포함할 수 있다. 네트워크는 통신 네트워크(telecommunications network), 예를 들면, 컴퓨터 네트워크(computer network)(예: LAN 또는 WAN), 인터넷, 또는 전화 망(telephone network) 중 적어도 하나를 포함할 수 있다.According to various embodiments, the communication interface 220 of the server 101 or the communication interface 260 of the electronic device 102 may establish communication between the at least one electronic device 102 or the server 101 . For example, the communication interfaces 220, 260 may be connected to the network via wireless communication or wired communication to communicate with the at least one electronic device 102 or the server 101. Wireless communications may include, for example, cellular communication protocols such as long-term evolution (LTE), LTE Advance (LTE), code division multiple access (CDMA), wideband CDMA (WCDMA) mobile telecommunications system, WiBro (Wireless Broadband), or Global System for Mobile Communications (GSM). The wireless communication may also include, for example, local communication 164. The local area communication may include at least one of, for example, wireless fidelity (WiFi), Bluetooth, or near field communication (NFC). The wired communication may include at least one of, for example, a universal serial bus (USB), a high definition multimedia interface (HDMI), a recommended standard 232 (RS-232), or plain old telephone service (POTS). The network may include at least one of a telecommunications network, e.g., a computer network (e.g., a LAN or WAN), the Internet, or a telephone network.

다양한 실시 예에 따르면, 서버(101)에서 실행되는 동작들의 전부 또는 일부는 다른 하나 또는 복수의 전자 장치(102)에서 실행될 수 있다. 또는, 전자 장치(102)에서 실행되는 동작들의 전부 또는 일부는 서버(101)에서 실행될 수 있다. 본 명세서에서 사용되는 전자 장치의 용어는 서버를 포함할 수 있다. 한 실시예에 따르면, 전자 장치(102)는 기능 또는 추가 기능을 서버(101)로 요청할 수 있다. 서버(101))는 전자 장치(102)로부터 요청된 기능 또는 추가 기능을 실행하고, 그 결과를 전자 장치(102)로 전달할 수 있다. 서버(101)는 실행된 결과를 그대로 또는 추가적으로 처리하여 요청된 기능이나 서비스를 제공할 수 있다. 전자 장치(102)는 데이터의 무결성 여부를 판단하기 위한 적어도 하나의 요청 또는 기능을 서버(101)로 요청할 수 있다. 이를 위하여, 예를 들면, 클라우드 컴퓨팅, 분산 컴퓨팅, 또는 클라이언트-서버 컴퓨팅 기술이 이용될 수 있다.According to various embodiments, all or a portion of the operations performed on the server 101 may be performed on the other electronic device 102 or on the plurality of electronic devices 102. [ Alternatively, all or a portion of the operations performed on the electronic device 102 may be executed on the server 101. [ The term electronic device as used herein may include a server. According to one embodiment, the electronic device 102 may request functionality or additional functionality from the server 101. Server 101) may execute the requested function or additional function from electronic device 102 and forward the result to electronic device 102. [ The server 101 can directly or additionally process the executed result to provide the requested function or service. The electronic device 102 may request the server 101 for at least one request or function for determining whether the data is integrity. For this purpose, for example, cloud computing, distributed computing, or client-server computing technology may be used.

다양한 실시 예에 따르면, 상기 서버(101)의 입출력인터페이스(230) 또는 상기 전자 장치(102)의 입출력인터페이스(270)는 전자 장치(102), 서버(101) 또는 다른 외부 기기(미도시)로부터 입력된 명령 또는 데이터를 다른 구성요소(들)에 전달할 수 있는 인터페이스의 역할을 할 수 있다. 또한, 입출력 인터페이스(230, 270)는 다른 구성요소(들)로부터 수신된 명령 또는 데이터를 전자 장치(102), 서버(101) 또는 다른 외부 기기(미도시)로 출력할 수 있다.According to various embodiments, the input / output interface 230 of the server 101 or the input / output interface 270 of the electronic device 102 may be connected to the electronic device 102, server 101 or other external device (not shown) And may serve as an interface through which an input command or data can be communicated to another component (s). The input / output interfaces 230 and 270 may also output commands or data received from the other component (s) to the electronic device 102, the server 101, or other external devices (not shown).

다양한 실시 예에 따르면, 상기 서버(101)의 메모리(240)는 또는 상기 전자 장치(102)의 메모리(280)는 휘발성 및/또는 비휘발성 메모리를 포함할 수 있다. 메모리(240, 280)는, 예를 들면, 적어도 하나의 다른 구성요소에 관계된 명령 또는 데이터를 저장할 수 있다. 한 실시 예에 따르면, 메모리(240, 280)는 소프트웨어 및/또는 프로그램을 저장할 수 있다. 한 실시 예에 따르면, 서버(101)의 메모리(240)는 적어도 하나의 데이터를 저장하는 데이터 저장 영역(241) 및 블록체인을 저장하는 블록체인(242)을 포함할 수 있다. 서버(101)의 메모리(280)는 개인 정보, 헬스 정보 및 공증 데이터 중 적어도 하나를 저장할 수 있다. 한 실시 예에 따르면, 전자 장치(102)의 메모리(280)는 블록체인을 저장하는 블록체인(281)을 포함할 수 있다. 전자 장치(102)의 메모리(280)는 서버(101)로부터 수신된 증명서를 저장할 수 있다. 또는 전자 장치(102)의 메모리(280)는 개인 정보, 헬스 정보 및 공증 데이터 중 적어도 하나를 저장할 수 있다. 상기 적어도 하나의 데이터는 개인 정보, 헬스 정보 및 공증 데이터 중 적어도 하나를 포함할 수 있다. 상기 프로세서(210)는 메모리(240)의 데이터 저장 영역(241)에 저장된 적어도 하나의 데이터를 그룹화하고, 상기 그룹화된 데이터의 요소들을 체인화하고, 상기 체인화된 데이터를 블록체인(242)에 저장할 수 있다.According to various embodiments, the memory 240 of the server 101 or the memory 280 of the electronic device 102 may include volatile and / or non-volatile memory. Memory 240,280 may store, for example, instructions or data related to at least one other component. According to one embodiment, the memories 240 and 280 may store software and / or programs. According to one embodiment, the memory 240 of the server 101 may include a data storage area 241 for storing at least one data and a block chain 242 for storing a block chain. The memory 280 of the server 101 may store at least one of personal information, health information, and notarized data. According to one embodiment, the memory 280 of the electronic device 102 may include a block chain 281 for storing block chains. The memory 280 of the electronic device 102 may store the certificate received from the server 101. [ Or the memory 280 of the electronic device 102 may store at least one of personal information, health information, and notarized data. The at least one data may include at least one of personal information, health information, and notarized data. The processor 210 may group at least one data stored in the data storage area 241 of the memory 240, chain the elements of the grouped data, and store the chained data in the block chain 242 have.

다양한 실시 예에 따르면, 상기 서버(101)의 프로세서(210) 또는 상기 전자 장치(102)의 프로세서(210)는 중앙처리장치(central processing unit(CPU)), 어플리케이션 프로세서(application processor(AP)), 또는 커뮤니케이션 프로세서(communication processor(CP)) 중 하나 또는 그 이상을 포함할 수 있다. 프로세서(210)는, 예를 들면, 서버(101)의 적어도 하나의 다른 구성요소들의 제어 및/또는 통신에 관한 연산이나 데이터 처리를 실행할 수 있다.According to various embodiments, the processor 210 of the server 101 or the processor 210 of the electronic device 102 includes a central processing unit (CPU), an application processor (AP) , Or a communication processor (CP). The processor 210 may perform, for example, operations or data processing relating to the control and / or communication of at least one other component of the server 101. For example,

다양한 실시 예에 따르면, 상기 서버(101)의 프로세서(210)는 메모리(240)에 저장된 데이터를 그룹화하고, 상기 그룹화된 데이터의 요소들을 체인화하고, 상기 체인화된 데이터를 블록체인(block chain)에 저장할 수 있다. 상기 프로세서(210)는 메모리(240)의 데이터 저장 영역(241)에 저장된 적어도 하나의 데이터를 체인 스케일러(chain scaler)를 이용하여 그룹화할 수 있다. 상기 프로세서(210)는 체인 스케일러를 이용해 그룹화된 데이터를 사슬 형태로 메모리(240)에 저장할 수 있다. 상기 프로세서(210)는 상기 그룹화된 데이터에 포함된 적어도 하나의 요소들을 블록체인(242)에 저장할 수 있다. 상기 프로세서(210)는 상기 그룹화된 데이터에 포함된 적어도 하나의 요소들을 체인 볼트(chain valut)를 이용하여 블록체인(242)에 저장할 수 있다. 상기 프로세서(210)는 상기 그룹화된 데이터 중에서 제1 데이터의 제1 요소를 제2 데이터에 포함하고, 상기 제2 데이터의 제2 요소를 제3 데이터에 포함하도록 체인화할 수 있다. 상기 프로세서(210)는 메모리(240)의 데이터 저장 영역(241)에 저장된 복수의 데이터들을 미리 결정된 개수 단위로 그룹화할 수 있다. 상기 프로세서(210)는 미리 결정된 시간, 미리 결정된 데이터 개수 및 데이터의 중요도 중 적어도 하나에 기반하여 상기 메모리(240)에 저장된 복수의 데이터를 그룹화할 수 있다. 상기 프로세서(210)는 상기 메모리(240)에 저장된 적어도 하나의 데이터에 기반하여 머클 해쉬(merkle hash)를 생성하고, 상기 생성된 머클 해쉬가 포함되도록 복수의 데이터를 그룹화할 수 있다. 상기 그룹화된 각각의 데이터는, 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함할 수 있다. 예를 들면, 상기 프로세서(210)는 제1 그룹화된 데이터를 생성하고, 상기 생성된 그룹화된 데이터의 식별자를 포함하여 제2 그룹화된 데이터를 생성할 수 있다. 이러한 상기 적어도 하나의 데이터는, 개인 정보, 헬스 정보 및 공증 데이터 중 적어도 하나를 포함할 수 있다.According to various embodiments, the processor 210 of the server 101 groups data stored in the memory 240, chains the elements of the grouped data, and stores the chained data in a block chain Can be stored. The processor 210 may group at least one data stored in the data storage area 241 of the memory 240 using a chain scaler. The processor 210 may store the grouped data in the memory 240 in a chain form using the chain scaler. The processor 210 may store in the block chain 242 at least one element included in the grouped data. The processor 210 may store at least one element included in the grouped data in a block chain 242 using a chain valut. The processor 210 may include a first element of the first data in the second data and a second element of the second data in the third data among the grouped data. The processor 210 may group a plurality of data stored in the data storage area 241 of the memory 240 into a predetermined number of units. The processor 210 may group the plurality of data stored in the memory 240 based on at least one of a predetermined time, a predetermined number of data, and an importance of the data. The processor 210 may generate a merkle hash based on the at least one data stored in the memory 240 and may group the plurality of data to include the generated hash hash. Each of the grouped data may include a merge hash identifier, a group identifier, and an identifier of a previous group. For example, the processor 210 may generate the first grouped data and the second grouped data including the identifier of the generated grouped data. The at least one data may include at least one of personal information, health information, and notarized data.

다양한 실시 예에 따르면, 상기 서버(101)의 프로세서(210)는 미리 결정된 시간 및 저장된 데이터의 개수 중 적어도 하나에 기반하여 블록 체인에 저장된 데이터의 적어도 하나의 요소와 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교하여 상기 저장된 데이터의 무결성을 검증할 수 있다. 상기 서버(101)의 프로세서(210)는 그룹화된 데이터의 체인화가 깨져 있는지도 검증할 수 있다.According to various embodiments, the processor 210 of the server 101 may include at least one element of data stored in the block chain based on at least one of a predetermined time and the number of stored data, and at least one The integrity of the stored data can be verified. The processor 210 of the server 101 may verify whether the chaining of the grouped data is broken.

다양한 실시 예에 따르면, 상기 서버(101)의 프로세서(210)는, 상기 저장된 블록체인의 사본을 적어도 하나의 전자 장치(102)로 전송할 수 있다. 상기 블록체인의 사본은, 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함할 수 있다. 상기 적어도 하나의 전자 장치(102)는 예를 들면, 스마트폰(smartphone), 태블릿 PC(tablet personal computer), 이동 전화기(mobile phone), 영상 전화기, 전자책 리더기(e-book reader), 데스크탑 PC(desktop personal computer), 랩탑 PC(laptop personal computer), 넷북 컴퓨터(netbook computer), 워크스테이션(workstation), 서버, PDA(personal digital assistant), PMP(portable multimedia player), MP3 플레이어, 모바일 의료기기, 카메라(camera), 또는 웨어러블 장치(wearable device) 중 적어도 하나를 포함할 수 있다. 다양한 실시 예에 따르면, 웨어러블 장치는 액세서리형(예: 시계, 반지, 팔찌, 발찌, 목걸이, 안경, 콘택트 렌즈, 또는 머리 착용형 장치(head-mounted-device(HMD)), 직물 또는 의류 일체형(예: 전자 의복), 신체 부착형(예: 스킨 패드(skin pad) 또는 문신), 또는 생체 이식형(예: implantable circuit) 중 적어도 하나를 포함할 수 있다. 상기 프로세서(210)는 미리 결정된 시간 및 상기 저장된 데이터의 개수 중 적어도 하나에 기반하여 상기 저장된 블록체인에 저장된 적어도 하나의 요소와 상기 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교하여 상기 저장된 데이터의 무결성을 검증할 수 있다. 상기 요소는 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자 중 적어도 하나를 포함할 수 있다. According to various embodiments, the processor 210 of the server 101 may send a copy of the stored block chain to the at least one electronic device 102. The copy of the block chain may include a merge hash identifier, a group identifier, and an identifier of the previous group. The at least one electronic device 102 may be, for example, a smartphone, a tablet personal computer, a mobile phone, a video phone, an e-book reader, a desktop PC such as a desktop personal computer, a laptop personal computer, a netbook computer, a workstation, a server, a personal digital assistant (PDA), a portable multimedia player (PMP) A camera, a wearable device, or the like. According to various embodiments, the wearable device may be of the accessory type (e.g., a watch, a ring, a bracelet, a bracelet, a necklace, a pair of glasses, a contact lens or a head-mounted-device (HMD) (E.g., an electronic garment), a body attachment type (e.g., a skin pad or tattoo), or a bioimplantable (e.g., implantable circuit) And compare the at least one element stored in the stored block chain and at least one element included in the grouped data based on at least one of the number of stored data and the number of stored data to verify the integrity of the stored data. May include at least one of a muckle hash identifier, a group identifier, and an identifier of the previous group.

다양한 실시 예에 따르면, 상기 서버(101)의 프로세서(210)는 상기 저장된 데이터가 무결성하지 않는 경우, 입출력 인터페이스(230)를 통해 상기 무결성 여부를 출력할 수 있다. 상기 프로세서(210)는 상기 저장된 데이터가 위조 또는 변조되거나 손상된 경우, 상기 서버(101)를 관리하는 관리자가 이러한 사항을 알 수 있도록 입출력 인터페이스(230)를 통해 상기 무결성 여부를 출력할 수 있다. 상기 프로세서(210)는 상기 저장된 블록체인의 무결성 여부를 판단하기 위한 증명서(certificate)를 생성하여 적어도 하나의 전자 장치로 전송할 수 있다. 상기 증명서는, 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 저장된 블록체인의 정보를 포함할 수 있다. 상기 증명서는 전자 장치(102)가 데이터의 무결성 여부를 판단하는데 이용될 수 있다. 상기 프로세서(210)는 상기 저장된 블록체인에 대한 적어도 하나의 요소의 요청이 상기 적어도 하나의 전자 장치로부터 수신되면, 상기 요청된 적어도 하나의 요소를 상기 전자 장치로 전송할 수 있다.According to various embodiments, the processor 210 of the server 101 may output the integrity information through the input / output interface 230 when the stored data is not integrity-related. The processor 210 may output the integrity information through the input / output interface 230 so that the administrator managing the server 101 can recognize such information if the stored data is falsified, altered, or damaged. The processor 210 may generate a certificate for determining integrity of the stored block chain and transmit the certificate to at least one electronic device. The certificate may include information of the stored at least one piece of data, information of the grouped data, and information of the stored block chain. The certificate may be used by the electronic device 102 to determine whether the data is integrity. The processor 210 may send the requested at least one element to the electronic device if a request for at least one element for the stored block chain is received from the at least one electronic device.

다양한 실시 예에 따르면, 상기 전자 장치(102)의 프로세서(250)는 서버(101)로부터 수신되어 메모리(280)에 저장된 증명서에 기반하여 블록체인(281)에 저장된 요소들을 상기 서버(101)로 요청할 수 있다. 상기 프로세서(250)는 데이터의 무결성에 대한 사용자의 요청을 디스플레이(290)를 통해 수신할 수 있다. 상기 디스플레이(290)는 터치 스크린을 포함할 수 있다. 상기 프로세서(250)는 상기 메모리(280)에 저장된 증명서를 이용하여 상기 메모리(280)에 저장된 블록체인(281)에 저장된 요소들에 대응하는 그룹화된 데이터를 상기 서버(101)로 요청할 수 있다. 상기 메모리(280)는 서버(101)에서 그룹화된 각각의 데이터에 대한 적어도 하나의 블록체인을 저장할 수 있다. 상기 프로세서(250)는 상기 획득된 요소들과 상기 그룹화된 데이터를 비교하여 데이터의 무결성을 검증할 수 있다. 상기 프로세서(250)는 미리 결정된 시간 및 저장된 데이터의 개수 중 적어도 하나에 기반하여 블록체인에 저장된 적어도 하나의 요소와 상기 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교하여 상기 데이터의 무결성을 검증할 수 있다. 예를 들면, 상기 프로세서(250)는 상기 데이터가 무결성하지 않는 경우, 상기 입출력인터페이스(270) 및 상기 디스플레이(290) 중 적어도 하나를 통해 무결성 여부를 출력할 수 있다.According to various embodiments, the processor 250 of the electronic device 102 may send the elements stored in the block chain 281 to the server 101 based on a certificate received from the server 101 and stored in the memory 280 Can be requested. The processor 250 may receive a user ' s request for data integrity via display 290. [ The display 290 may include a touch screen. The processor 250 may request the server 101 to use the grouped data corresponding to the elements stored in the block chain 281 stored in the memory 280 using the certificate stored in the memory 280. [ The memory 280 may store at least one block chain for each data grouped in the server 101. The processor 250 may compare the obtained elements with the grouped data to verify the integrity of the data. The processor 250 compares at least one element contained in the grouped data with at least one element stored in the block chain based on at least one of a predetermined time and the number of stored data to verify the integrity of the data . For example, the processor 250 may output integrity through at least one of the input / output interface 270 and the display 290 if the data is not integrity-protected.

다양한 실시 예에 따르면, 상기 전자 장치(102)의 디스플레이(290)는, 예를 들면, 액정 디스플레이(liquid crystal display(LCD)), 발광 다이오드(light-emitting diode(LED)) 디스플레이, 유기 발광 다이오드(organic light-emitting diode(OLED)) 디스플레이, 또는 마이크로 전자기계 시스템(microelectromechanical systems(MEMS)) 디스플레이, 또는 전자종이(electronic paper) 디스플레이를 포함할 수 있다. 디스플레이(290)는, 예를 들면, 사용자에게 각종 콘텐츠(예: 텍스트, 이미지, 비디오, 아이콘, 또는 심볼 등)을 표시할 수 있다. 디스플레이(290)는, 터치 스크린을 포함할 수 있으며, 예를 들면, 전자 펜 또는 사용자의 신체의 일부를 이용한 터치, 제스쳐, 근접, 또는 호버링 입력을 수신할 수 있다. According to various embodiments, the display 290 of the electronic device 102 may include, for example, a liquid crystal display (LCD), a light-emitting diode (LED) an organic light-emitting diode (OLED) display, or a microelectromechanical systems (MEMS) display, or an electronic paper display. Display 290 may display various content (e.g., text, image, video, icon, or symbol, etc.) to a user, for example. Display 290 may include a touch screen and may receive a touch, gesture, proximity, or hovering input using, for example, an electronic pen or a portion of the user's body.

다양한 실시 예에 따르면, 본 발명은 데이터의 무결성을 검증하는 서버에 있어서, 적어도 하나의 데이터를 저장하는 메모리; 및 상기 저장된 데이터를 그룹화하고, 상기 그룹화된 데이터의 요소들을 체인화하고, 상기 체인화된 데이터를 블록체인(blockchain)에 저장하는 프로세서를 포함할 수 있다.According to various embodiments, the present invention provides a server for verifying the integrity of data, comprising: a memory for storing at least one data; And a processor for grouping the stored data, chaining elements of the grouped data, and storing the chained data in a block chain.

일 실시 예에 따르면, 상기 프로세서는, 상기 그룹화된 데이터 중에서 제1 데이터의 제1 요소를 제2 데이터에 포함하고, 상기 제2 데이터의 제2 요소를 제3 데이터에 포함하도록 체인화할 수 있다.According to one embodiment, the processor may include a first element of the first data in the second data and a second element of the second data in the third data among the grouped data.

일 실시 예에 따르면, 상기 프로세서는, 미리 결정된 시간, 미리 결정된 데이터 개수, 데이터 종류 및 데이터의 중요도 중 적어도 하나에 기반하여 상기 저장된 데이터를 그룹화할 수 있다.According to one embodiment, the processor may group the stored data based on at least one of a predetermined time, a predetermined number of data, a data type, and an importance of data.

일 실시 예에 따르면, 상기 프로세서는, 상기 저장된 데이터에 기반하여 머클 해쉬(merkle hash)를 생성하고, 상기 생성된 머클 해쉬가 포함되도록 상기 저장된 데이터를 그룹화할 수 있다.According to one embodiment, the processor may generate a merkle hash based on the stored data and group the stored data to include the generated hash hash.

일 실시 예에 따르면, 상기 프로세서는, 상기 그룹화된 데이터는, 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함할 수 있다.According to one embodiment, the processor may include the grouped data include a merge hash identifier, a group identifier, and an identifier of the previous group.

일 실시 예에 따르면, 상기 프로세서는, 상기 적어도 하나의 데이터는, 개인 정보, 헬스 정보 및 공증 데이터 중 적어도 하나를 포함할 수 있다.According to one embodiment, the processor may include at least one of the personal information, health information, and notarized data.

일 실시 예에 따르면, 본 발명의 서버는 통신 인터페이스를 더 포함하며, 상기 프로세서는, 상기 블록체인에 저장된 데이터의 사본을 적어도 하나의 전자 장치로 전송하며, 상기 사본은, 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함할 수 있다.According to one embodiment, the server of the present invention further comprises a communication interface, wherein the processor transmits a copy of the data stored in the block chain to at least one electronic device, the copy comprising a merge hash identifier, And an identifier of the previous group.

일 실시 예에 따르면, 상기 프로세서는, 미리 결정된 시간 및 상기 저장된 데이터의 개수 중 적어도 하나에 기반하여 상기 블록체인에 저장된 데이터의 적어도 하나의 요소와 상기 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교하여 상기 저장된 데이터의 무결성을 검증할 수 있다.According to one embodiment, the processor compares at least one element of data stored in the block chain with at least one element contained in the grouped data based on at least one of a predetermined time and the number of stored data Thereby verifying the integrity of the stored data.

일 실시 예에 따르면, 본 발명의 서버는 입출력 인터페이스를 더 포함하며, 상기 프로세서는, 상기 저장된 데이터가 무결성하지 않는 경우, 상기 입출력 인터페이스를 통해 상기 무결성 여부를 출력할 수 있다.According to one embodiment, the server of the present invention further includes an input / output interface, and the processor may output the integrity through the input / output interface when the stored data is not integrity.

일 실시 예에 따르면, 상기 프로세서는, 상기 블록체인에 저장된 데이터의 무결성 여부를 판단하기 위한 증명서를 생성하여 적어도 하나의 전자 장치로 전송하며, 상기 증명서는, 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 블록체인의 정보를 포함할 수 있다.According to one embodiment, the processor generates a certificate for determining whether integrity of data stored in the block chain is integrity, and transmits the certificate to at least one electronic device, and the certificate includes information of the stored at least one data, Information of grouped data, and information of the block chain.

일 실시 예에 따르면, 상기 프로세서는, 상기 블록체인에 저장된 데이터에 대한 적어도 하나의 요소에 대한 요청이 상기 적어도 하나의 전자 장치로부터 수신되면, 상기 요청에 해당되는 요소의 종류에 따라 데이터의 포맷을 변환하여 상기 요청된 적어도 하나의 요소를 상기 전자 장치로 전송할 수 있다.According to one embodiment, when a request for at least one element of data stored in the block chain is received from the at least one electronic device, the processor may determine a format of the data according to the type of the element corresponding to the request And transmit the requested at least one element to the electronic device.

다양한 실시 예에 따르면, 본 발명은 데이터의 무결성을 검증하는 전자 장치에 있어서, 서버로부터 수신되는 증명서를 저장하는 메모리; 및 상기 저장된 증명서에 기반하여 블록체인에 저장된 데이터의 요소들을 상기 서버로 요청하여 획득하고, 상기 획득된 요소들과 그룹화된 데이터를 비교하여 무결성을 검증할 수 있다.According to various embodiments, the present invention provides an electronic device for verifying the integrity of data, comprising: a memory for storing a certificate received from a server; And requesting, by the server, the elements of the data stored in the block chain based on the stored certificate, and comparing the obtained elements with the grouped data to verify the integrity.

일 실시 예에 따르면, 상기 프로세서는, 상기 블록체인에 저장된 데이터의 무결성 여부를 판단하기 위한 증명서를 상기 서버로부터 수신하며, 상기 증명서는, 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 블록체인의 정보를 포함할 수 있다.According to one embodiment, the processor receives from the server a certificate for determining whether the data stored in the block chain is integrity, and the certificate includes information of the stored at least one piece of data, information of the grouped data And information of the block chain.

일 실시 예에 따르면, 상기 프로세서는, 상기 저장된 데이터가 무결성하지 않는 경우, 상기 무결성 여부를 출력할 수 있다.According to one embodiment, the processor may output the integrity if the stored data is not integrity.

도 3은 본 발명의 다양한 실시 예에 따른 서버에서 데이터를 그룹화하여 블록체인에 저장하는 과정을 나타낸 순서도이다.FIG. 3 is a flowchart illustrating a process of grouping data in a server according to various embodiments of the present invention and storing the data in a block chain.

이하, 도 3을 참조하여, 본 발명의 다양한 실시 예에 따른 서버에서 데이터를 그룹화하여 블록체인에 저장하는 과정을 상세히 설명하면 다음과 같다.Hereinafter, a process of grouping data in a server according to various embodiments of the present invention and storing the data in a block chain will be described in detail with reference to FIG.

다양한 실시 예에 따르면, 동작 310에서, 서버(101)(예: 프로세서(120))는 데이터를 그룹화할 수 있다. 서버(101)는 메모리(240)에 저장된 데이터를 그룹화할 수 있다. 서버(101)는 미리 결정된 시간, 미리 결정된 데이터 개수, 데이터 중요도 및 데이터의 중요도 중 적어도 하나에 기반하여 메모리(241)의 데이터 저장 영역(241)에 저장된 데이터를 그룹화할 수 있다. 서버(101)는 메모리(240)에 저장된 데이터에 기반하여 머클 해쉬(merkle hash)를 생성하고, 상기 생성된 머클 해쉬가 포함되도록 데이터를 그룹화할 수 있다. 서버(101)는 메모리(241)의 데이터 저장 영역(241)에 저장된 데이터를 체인 스케일러(chain scaler)를 이용하여 그룹화할 수 있다. 상기 적어도 하나의 데이터는 개인 정보, 헬스 정보 및 공증 데이터 중 적어도 하나를 포함하는 미리 결정된 데이터일 수 있다. 상기 그룹화된 데이터는 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함할 수 있다. 그룹화된 각각의 데이터(또는 각 데이터에 포함된 요소들)는 무결성 검증을 위해 블록 체인에 저장된 값과 비교될 수 있다.According to various embodiments, at operation 310, server 101 (e.g., processor 120) may group data. The server 101 can group the data stored in the memory 240. The server 101 may group the data stored in the data storage area 241 of the memory 241 based on at least one of the predetermined time, the predetermined number of data, the data importance, and the importance of the data. The server 101 may generate a merge hash based on the data stored in the memory 240 and group the data so that the generated merge hash is included. The server 101 may group data stored in the data storage area 241 of the memory 241 using a chain scaler. The at least one data may be predetermined data comprising at least one of personal information, health information, and notarized data. The grouped data may include a merge hash identifier, a group identifier, and an identifier of the previous group. Each grouped data (or elements contained in each data) can be compared with the values stored in the block chain for integrity verification.

다양한 실시 예에 따르면, 동작 312에서, 서버(101)(예: 프로세서(120))는 각 그룹화된 데이터의 요소들을 체인화하여 블록체인에 저장할 수 있다. 서버(101)는 메모리(240)의 데이터 저장 영역(241)에 저장된 데이터를 그룹화하여 블록체인(242)에 저장할 수 있다. 서버(101)는 그룹화된 데이터 중에서 제1 데이터의 제1 요소를 제2 데이터에 포함하고, 제2 데이터의 제2 요소를 제3 데이터에 포함하도록 체인화할 수 있다. 서버(101)는 메모리(240)의 데이터 저장 영역(241)에 데이터가 저장된 미리 결정된 시간, 상기 저장된 데이터의 개수, 상기 저장된 데이터의 종류 및 상기 데이터의 중요도 중 적어도 하나에 기반하여 그룹화하여 복수의 그룹화된 데이터를 생성할 수 있다. 서버(101)는 생성된 복수의 그룹화된 데이터 중에서 제1 데이터의 제1 요소를 제2 데이터에 포함되도록 각 그룹화된 데이터의 요소들을 체인화할 수 있다. 서버(101)는 생성된 복수의 그룹화된 데이터 중에서 제2 데이터의 제2 요소를 제3 데이터에 포함되도록 각 그룹화된 데이터의 요소들을 체인화할 수 있다. 상기 각각의 데이터는 데이터 식별자 및 데이터 정보를 포함할 수 있다. 상기 그룹화된 데이터는 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함할 수 있다. 상기 머클 해쉬 식별자는 해쉬 방식을 이용하여 머클 해쉬를 만드는 방식을 나타내며, 상기 그룹 식별자는 그룹화된 데이터의 식별자를 나타내며, 상기 이전 그룹의 식별자는 이전에 그룹화된 데이터의 식별자를 나타낸다. 서버(101)는 각 그룹화된 데이터의 요소들을 체인화하여 블록체인에 저장할 수 있다. 서버(101)는 미리 결정된 시간 및 상기 저장된 데이터의 개수 중 적어도 하나에 기반하여 상기 블록 체인에 저장된 데이터와 상기 그룹화된 데이터를 비교할 수 있다. 서버(101)는 미리 결정된 시간 및 상기 저장된 데이터의 개수 중 적어도 하나에 기반하여 상기 블록 체인에 저장된 데이터의 적어도 하나의 요소와 상기 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교할 수 있다. 서버(101)는 상기 비교에 기반하여 저장된 데이터의 무결성을 검증할 수 있다. 서버(101)는 전자 장치(102)에 저장된 블록 체인과 비교하여 무결성 검증을 판단하기 위해, 각 그룹화된 데이터의 요소들을 체인화하여 블록체인에 저장할 수 있다. 서버(101)는 상기 저장된 데이터가 무결성하지 않는 경우, 서버(101)의 입출력 인터페이스(230)를 통해 출력할 수 있다. 서버(101)는 상기 저장된 데이터가 무결성하지 않는 경우, 상기 서버(101)를 관리하는 관리자가 인지할 수 있도록 서버(101)의 입출력 인터페이스(230)를 통해 무결성 여부를 출력할 수 있다.According to various embodiments, at operation 312, the server 101 (e.g., processor 120) may chain the elements of each grouped data and store them in a block chain. The server 101 may group the data stored in the data storage area 241 of the memory 240 and store the data in the block chain 242. The server 101 may chose to include the first element of the first data in the second data and the second element of the second data in the third data among the grouped data. The server 101 groups the data in the data storage area 241 of the memory 240 based on at least one of a predetermined time at which data is stored, a number of the stored data, a type of the stored data, Grouped data can be generated. The server 101 may chain the elements of each grouped data so that the first element of the first data is included in the second data among the plurality of generated grouped data. The server 101 may chain the elements of each grouped data so that the second element of the second data is included in the third data among the plurality of generated grouped data. Each of the data may include a data identifier and data information. The grouped data may include a merge hash identifier, a group identifier, and an identifier of the previous group. The hash identifier represents a method of creating a hash hash using a hash scheme, the group identifier represents an identifier of grouped data, and the identifier of the previous group represents an identifier of previously grouped data. The server 101 may chain the elements of each grouped data and store them in a block chain. The server 101 may compare the grouped data with the data stored in the block chain based on at least one of the predetermined time and the number of stored data. The server 101 may compare at least one element of the data stored in the block chain and at least one element included in the grouped data based on at least one of the predetermined time and the number of stored data. The server 101 can verify the integrity of the stored data based on the comparison. The server 101 may chain and store the elements of each grouped data in a block chain to determine integrity verification as compared to the block chain stored in the electronic device 102. [ The server 101 may output the stored data through the input / output interface 230 of the server 101 when the stored data is not integrity-related. The server 101 may output integrity information through the input / output interface 230 of the server 101 so that the administrator managing the server 101 can recognize the stored data if the stored data is not integrity-protected.

다양한 실시 예에 따르면, 서버(101)는 블록 체인에 데이터를 저장하기 위해서 블록체인 네트워크에 참여하고 있는 적어도 하나의 전자 장치(102)로 블록체인 트랜잭션을 전송할 수 있다. 상기 블록체인 트랜잭션에는 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자 등의 요소를 포함할 수 있다. 서버(101)는 블록 체인에 저장된 데이터의 사본을 서버(101)와 연결된 적어도 하나의 전자 장치(102)로 전송할 수 있다. 서버(101)는 블록 체인에 저장된 데이터의 무결성 여부를 판단하기 위한 증명서를 생성하여 적어도 하나의 전자 장치(102)를 전송할 수 있다. 상기 증명서는 전자 장치(102)가 데이터가 위조 되었는지 또는 변조 되었는지를 판단하기 위해 이용될 수 있다. 상기 증명서는 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 블록체인의 정보를 포함할 수 있다. 서버(101)는 블록 체인에 저장된 데이터의 적어도 하나의 요소에 대한 요청이 전자 장치(102)로부터 수신되면, 서버(101)는 상기 요청된 적어도 하나의 요소를 상기 요청을 전송한 전자 장치(102)로 전송할 수 있다.According to various embodiments, the server 101 may send a blockchain transaction to at least one electronic device 102 participating in a block-chain network to store data in a block chain. The block-chain transaction may include elements such as a merge hash identifier, a group identifier, and an identifier of a previous group. The server 101 may send a copy of the data stored in the block chain to at least one electronic device 102 connected to the server 101. The server 101 may generate a certificate for determining whether the data stored in the block chain is integrity or not and transmit the at least one electronic device 102. [ The certificate may be used by electronic device 102 to determine if data has been tampered with or tampered with. The certificate may include information of the stored at least one piece of data, information of the grouped data, and information of the block chain. When a request for at least one element of data stored in the block chain is received from the electronic device 102, the server 101 sends the requested at least one element to the electronic device 102 ).

도 4a는 본 발명의 일 실시 예에 따른 서버가 데이터의 무결성을 검증하는 과정을 나타낸 순서도이다.4A is a flowchart illustrating a process of verifying integrity of data by a server according to an exemplary embodiment of the present invention.

이하, 도 4a를 참조하여, 본 발명의 일 실시 예에 따른 서버가 데이터의 무결성을 검증하는 과정을 상세히 설명하면 다음과 같다. Hereinafter, a process of verifying the integrity of data according to an embodiment of the present invention will be described in detail with reference to FIG. 4A.

본 발명의 서버(101)는 메모리(240)에 저장된 데이터의 무결성 여부를 판단할 수 있다.The server 101 of the present invention can determine whether the data stored in the memory 240 is integrity.

다양한 실시 예에 따르면, 동작 410에서, 서버(101)(예: 프로세서(210))는 블록 체인에 저장된 요소들과 그룹화된 데이터의 요소들을 비교할 수 있다. 서버(101)는 메모리(240)에 저장된 데이터가 위조 되었는지 또는 변조되었는지를 판단하기 위해, 블록 체인에 저장된 요소들과 그룹화된 데이터의 요소들을 비교할 수 있다. 서버(101)는 메모리(240)의 데이터 저장 영역(241)에 저장된 데이터와 블록 체인(242)에 저장된 데이터를 비교할 수 있다. 상기 서버(101)는 메모리(240)에 저장된 데이터가 위조 되었는지 또는 변조되었는지를 미리 결정된 시간 단위로 비교할 수 있다. 서버(101)는 메모리(240)에 저장된 데이터의 개수가 미리 결정된 개수를 초과하는 경우, 상기 저장된 데이터가 위조 되었는지 또는 변조되었는지를 비교할 수 있다. According to various embodiments, at operation 410, the server 101 (e.g., processor 210) may compare the elements of the grouped data with the elements stored in the block chain. The server 101 may compare the elements of the grouped data with the elements stored in the block chain to determine whether the data stored in the memory 240 has been falsified or tampered with. The server 101 may compare the data stored in the data storage area 241 of the memory 240 with the data stored in the block chain 242. [ The server 101 may compare whether the data stored in the memory 240 is falsified or modulated by a predetermined time unit. The server 101 may compare whether the stored data is forged or tampered when the number of data stored in the memory 240 exceeds a predetermined number.

다양한 실시 예에 따르면, 동작 412에서, 서버(101)는 블록 체인에 저장된 요소들과 그룹화된 데이터를 비교하여 메모리(240)에 저장된 데이터가 무결성한지를 판단할 수 있다. 서버(101)(예: 프로세서(210))는 블록 체인에 저장된 요소들과 그룹화된 데이터의 구성 요소들을 비교하여 메모리(240)에 저장된 데이터의 무결성을 판단할 수 있다. 서버(101)는 블록 체인에 저장된 요소들과 그룹화된 데이터의 구성 요소들을 비교하여 메모리(240)에 저장된 데이터가 위조 되었는지 또는 변조되었는지를 판단할 수 있다. 서버(101)는 메모리(240)의 데이터 저장 영역(241)에 저장된 데이터와 블록 체인(242)에 저장된 데이터를 비교하여 상기 데이터 저장 영역(241)에 저장된 데이터가 무결성한지를 판단할 수 있다. 서버(101)는 메모리(240)에 저장된 데이터의 무결성 여부를 미리 결정된 시간 단위로 판단할 수 있다. 서버(101)는 메모리(240)에 저장된 데이터의 개수가 미리 결정된 개수를 초과하는 경우, 상기 저장된 데이터가 위조 되었는지 또는 변조되었는지를 판단할 수 있다.According to various embodiments, at operation 412, the server 101 may compare the grouped data with the elements stored in the block chain to determine whether the data stored in the memory 240 is integrity. The server 101 (e.g., the processor 210) may compare the elements of the grouped data with the elements stored in the block chain to determine the integrity of the data stored in the memory 240. [ The server 101 may compare the elements of the grouped data with the elements stored in the block chain to determine whether the data stored in the memory 240 has been forged or tampered with. The server 101 may compare the data stored in the data storage area 241 of the memory 240 with the data stored in the block chain 242 to determine whether the data stored in the data storage area 241 is integrity. The server 101 can determine whether the data stored in the memory 240 is integrity based on a predetermined time unit. When the number of data stored in the memory 240 exceeds a predetermined number, the server 101 may determine whether the stored data has been falsified or altered.

다양한 실시 예에 따르면, 동작 414에서, 서버(101)는 무결성 여부를 관리자에게 통지할 수 있다. 예를 들면, 메모리(240)에 저장된 데이터가 위조 되었거나 또는 변조되는 경우, 상기 데이터가 무결성하지 않음을 상기 서버(101)의 관리자에게 통지할 수 있다. 서버(101)는 상기 저장된 데이터가 무결성하지 않는 경우, 상기 서버(101)를 관리하는 관리자가 인지할 수 있도록 서버(101)의 입출력 인터페이스(230)를 통해 무결성 여부를 출력할 수 있다.According to various embodiments, at operation 414, the server 101 may notify the administrator of integrity. For example, if the data stored in the memory 240 is falsified or tampered, it may notify the manager of the server 101 that the data is not integrity. The server 101 may output integrity information through the input / output interface 230 of the server 101 so that the administrator managing the server 101 can recognize the stored data if the stored data is not integrity-protected.

도 4b는 본 발명의 일 실시 예에 따른 전자 장치가 데이터의 무결성을 검증하는 과정을 나타낸 순서도이다.4B is a flowchart illustrating a process of verifying integrity of data by an electronic device according to an exemplary embodiment of the present invention.

이하, 도 4b를 참조하여 본 발명의 일 실시 예에 따른 전자 장치가 데이터의 무결성을 검증하는 과정을 상세히 설명하면 다음과 같다.Hereinafter, a process of verifying the integrity of data of an electronic device according to an embodiment of the present invention will be described in detail with reference to FIG. 4B.

본 발명의 전자 장치(102)는 메모리(280)의 블록 체인(281)에 저장된 데이터의 무결성을 검증할 수 있다.The electronic device 102 of the present invention can verify the integrity of the data stored in the block chain 281 of the memory 280. [

다양한 실시 예에 따르면, 동작 420에서, 전자 장치(102)(예: 프로세서(250)는 서버로부터 증명서를 수신하여 저장할 수 있다. 서버(101)는 전자 장치(102)가 데이터의 무결성 여부를 직접 체크할 수 있도록 증명서를 적어도 하나의 전자 장치(102)로 전송할 수 있다. 서버(101)는 블록 체인(242)에 데이터를 저장하기 위해 하나의 전자 장치(102)로 블록체인 트랜잭션을 전송할 수 있다. 서버(101)에 연결된 각각의 전자 장치(102)는 상기 서버(101)로부터 수신된 증명서를 수신하여 메모리(280)에 저장할 수 있다. 서버(101)에 연결된 각각의 전자 장치(102)는 상기 서버(101)로부터 수신된 블록 체인 트랜잭션을 처리하여 메모리(280)의 블록체인(281)에 저장할 수 있다. 상기 증명서는 서버(101)에 저장된 데이터의 정보, 그룹화된 데이터의 정보 및 블록 체인의 정보를 포함할 수 있다. 상기 블록체인에 저장된 요소는, 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함할 수 있다. 상기 서버(101)에 저장된 데이터의 정보는 데이터 식별자 및 데이터의 내용에 관한 정보를 포함할 수 있다. 상기 그룹화된 데이터의 정보는 그룹화된 데이터의 식별자 및 머클 해쉬 식별자를 포함할 수 있다. 상기 블록 체인의 정보는 블록 체인의 식별자 및 타임 스탬프를 포함할 수 있다. 상기 증명서는 전자 장치(102)가 데이터의 무결성 여부를 판단하는데 이용될 수 있다.According to various embodiments, at operation 420, electronic device 102 (e.g., processor 250 may receive and store a certificate from a server). Server 101 may determine whether electronic device 102 The server 101 may send a certificate to the at least one electronic device 102 for checking. The server 101 may send a blockchain transaction to one electronic device 102 to store data in the block chain 242 Each electronic device 102 connected to the server 101 may receive the certificate received from the server 101 and store it in the memory 280. Each electronic device 102 connected to the server 101 The block chain transaction received from the server 101 may be processed and stored in the block chain 281 of the memory 280. The certificate may include information of data stored in the server 101, May contain information The element stored in the block chain may include a header hash identifier, a group identifier, and an identifier of a previous group. The information of the data stored in the server 101 includes a data identifier and information on the content of the data The information of the grouped data may include an identifier of the grouped data and a merge hash identifier. The information of the block chain may include an identifier and a time stamp of the block chain. 102 may be used to determine whether the data is integrity.

다양한 실시 예에 따르면, 동작 422에서, 전자 장치(102)(예: 프로세서(250)는 무결성 체크 요청이 입력되는지 판단할 수 있다. 전자 장치(101)는 무결성 체크를 요청하는 입력을 사용자로부터 입력받을 수 있다. 전자 장치(101)는 디스플레이(290)(예: 터치 스크린)를 통해 무결성 체크를 요청하는 입력을 사용자로부터 수신할 수 있다. 사용자는 상기 증명서에 기반하여 자신의 중요 데이터가 위조 되었는지 또는 변조 되었는지를 블록 체인에 저장된 데이터를 기반으로 검증할 수 있다. According to various embodiments, at operation 422, the electronic device 102 (e.g., the processor 250 may determine whether an integrity check request is entered.) The electronic device 101 may provide an input requesting an integrity check from a user Electronic device 101 may receive an input from a user requesting an integrity check via display 290 (e.g., a touch screen). The user may determine whether his / her critical data has been falsified Or modulated based on the data stored in the block chain.

다양한 실시 예에 따르면, 동작 424에서, 전자 장치(102)(예: 프로세서(250)는 메모리(280)에 저장된 증명서에 기반하여 블록 체인에 저장된 요소들을 획득할 수 있다. 상기 전자 장치(102)는 상기 메모리(280)에 저장된 증명서를 이용하여 상기 메모리(280)에 저장된 블록체인(281)에 저장된 요소들에 대응하는 그룹화된 데이터를 요청할 수 있다. 전자 장치(102)는 무결성 체크 요청이 입력되면, 상기 메모리(280)에 저장된 증명서를 이용하여 상기 메모리(280)에 저장된 블록체인(281)에 저장된 요소들에 대응하는 그룹화된 데이터를 블록체인 네트워크에 요청하고 수신할 수 있다. 전자 장치(102)는 상기 메모리(280)에 저장된 증명서를 이용하여 상기 메모리(280)에 저장된 블록체인(281)에 저장된 요소들을 블록체인 네트워크에 요청하고, 블록체인 네트워크로부터 상기 요청에 대응한 요소들을 획득할 수 있다. 예를 들면, 전자장치가 블록체인을 가지고 있지 않다면, 특정 서버(예: 블록체인에 참여하고 있거나 또는 자신의 요청을 대신 수행할 수 있는 특정 서버)에게 요청할 수 있겠지만, 전자장치가 블록체인을 가지고 있는 경우(예: 전자장치가 블록체인 네트워크에 참여하고 있는 경우)에는 직접 블록체인 네트워크에 요청할 수 있다.According to various embodiments, at operation 424, electronic device 102 (e.g., processor 250 may obtain elements stored in a block chain based on a certificate stored in memory 280) The electronic device 102 may request the grouped data corresponding to the elements stored in the block chain 281 stored in the memory 280 using the certificate stored in the memory 280. The electronic device 102 may send an integrity check request It is possible to request and receive the grouped data corresponding to the elements stored in the block chain 281 stored in the memory 280 with the certificate stored in the memory 280 to the block chain network. 102 requests the block chain network elements stored in the block chain 281 stored in the memory 280 using a certificate stored in the memory 280 and transmits the request to the block chain network For example, if an electronic device does not have a block chain, it may be able to acquire elements corresponding to a particular server (eg, a particular server participating in a block chain or performing its own requests instead). As you may ask, you can ask the block-chained network directly if the electronic device has a block chain (for example, if the electronic device is participating in a block-chained network).

다양한 실시 예에 따르면, 동작 426에서, 전자 장치(102)(예: 프로세서(250)는 획득된 요소들과 그룹화된 데이터의 요소들을 비교할 수 있다. 전자 장치(102)는 메모리(260)에 저장된 데이터가 위조 되었는지 또는 변조되었는지를 판단하기 위해, 블록 체인에 저장된 요소들을 블록체인 네트워크로부터 획득하고, 상기 획득된 요소들과 상기 증명서에 저장된 그룹화된 데이터의 요소들을 비교할 수 있다. 전자 장치(102)는 메모리(280)에 저장된 데이터의 요소들과 상기 블록체인 네트워크로부터 획득된 요소들을 비교할 수 있다. 상기 전자 장치(102)는 메모리(280)에 저장된 데이터가 위조 되었는지 또는 변조되었는지를 미리 결정된 시간 단위로 비교할 수 있다. 상기 전자 장치(102)는 메모리(280)에 저장된 데이터의 개수가 미리 결정된 개수를 초과하는 경우, 상기 저장된 데이터가 위조 되었는지 또는 변조되었는지를 비교할 수 있다.According to various embodiments, at operation 426, the electronic device 102 (e.g., the processor 250 may compare the elements of the grouped data with the acquired elements). The electronic device 102 may obtain the elements stored in the block chain from the block-chain network and compare the elements of the grouped data stored in the certificate with the obtained elements to determine whether the data has been forged or tampered. The electronic device 102 may compare the elements of the data stored in the memory 280 with the elements obtained from the block chain network. The electronic device 102 may determine whether the data stored in the memory 280 has been forged or tampered with, When the number of data stored in the memory 280 exceeds a predetermined number, The stored data can be compared to that whether or modulation forged.

다양한 실시 예에 따르면, 동작 428에서, 전자 장치(102)(예: 프로세서(250)는 무결성 여부를 판단할 수 있다. 전자 장치(102)는 블록 체인에 저장된 요소들과 그룹화된 데이터의 요소들을 비교하여 메모리(280)에 저장된 데이터가 무결성한지를 판단할 수 있다. 전자 장치(102)는 블록 체인에 저장된 요소들과 그룹화된 데이터의 요소들을 비교하여 메모리(280)에 저장된 데이터의 무결성을 판단할 수 있다. 전자 장치(102)는 블록 체인에 저장된 요소들과 그룹화된 데이터의 요소들을 비교하여 메모리(280)에 저장된 데이터가 위조 되었는지 또는 변조되었는지를 판단할 수 있다. 전자 장치(102)는 메모리(280)에 저장된 데이터와 블록 체인(281)에 저장된 데이터를 비교하여 상기 메모리(280)에 저장된 데이터가 무결성한지를 판단할 수 있다. 전자 장치(102)는 메모리(280)에 저장된 데이터의 무결성 여부를 미리 결정된 시간 단위로 판단할 수 있다.According to various embodiments, at operation 428, electronic device 102 (e.g., processor 250 may determine integrity). Electronic device 102 may store elements stored in a block chain and elements of grouped data And compare the data stored in the memory 280 with the data stored in the memory 280. The electronic device 102 compares the elements of the grouped data with the elements stored in the block chain to determine the integrity of the data stored in the memory 280 The electronic device 102 may compare the elements of the grouped data with the elements stored in the block chain to determine whether the data stored in the memory 280 has been tampered with or tampered with. The data stored in the memory 280 may be compared with the data stored in the block chain 281 to determine whether the data stored in the memory 280 is integrity. May determine whether the integrity of the stored data in a predetermined time unit.

다양한 실시 예에 따르면, 동작 430에서, 전자 장치(102)(예: 프로세서(250)는 관리자에게 통지할 수 있다. 예를 들면, 전자 장치(102)는 메모리(240)에 저장된 데이터가 위조 되었거나 또는 변조되는 경우, 상기 데이터가 무결성하지 않음을 상기 서버(101)의 관리자에게 통지할 수 있다. 또는 전자 장치(102)는 메모리(240)에 저장된 데이터가 위조 되었거나 또는 변조되는 경우, 상기 데이터가 무결성하지 않음을 상기 전자 장치(102)의 사용자에게 통지할 수 있다. 전자 장치(102)는 상기 저장된 데이터가 무결성하지 않는 경우, 상기 서버(101)를 관리하는 관리자 또는 상기 전자 장치(102)의 사용자가 인지할 수 있도록 서버(101)로 무결성 여부를 전송하거나, 상기 전자 장치(102)의 입출력 인터페이스(270)를 통해 무결성 여부를 출력할 수 있다.According to various embodiments, at operation 430, the electronic device 102 (e.g., the processor 250 may notify the administrator). For example, the electronic device 102 may determine that the data stored in the memory 240 has been falsified The electronic device 102 may notify the manager of the server 101 that the data is not integrity if the data stored in the memory 240 is falsified or modulated, To the user of the electronic device 102. If the stored data is not integrity, the electronic device 102 may notify the administrator managing the server 101 or the user of the electronic device 102 It may transmit integrity to the server 101 so as to be recognized by the user or may output integrity through the input / output interface 270 of the electronic device 102.

다양한 실시 예에 따르면, 본 발명은 서버에서 데이터의 무결성을 검증하는 방법에 있어서, 메모리에 저장된 적어도 하나의 데이터를 그룹화하는 동작; 상기 그룹화된 데이터를 체인화하는 동작; 및 상기 체인화된 데이터를 블록체인에 저장하는 동작을 포함할 수 있다.According to various embodiments, the present invention provides a method of verifying the integrity of data in a server, the method comprising: grouping at least one data stored in a memory; Chaining the grouped data; And storing the chained data in a block chain.

일 실시 예에 따르면, 상기 그룹화된 데이터를 체인화하는 동작은, 상기 그룹화된 데이터 중에서 제1 데이터의 제1 요소를 제2 데이터에 포함하고, 상기 제2 데이터의 제2 요소를 제3 데이터에 포함하도록 체인화하는 동작을 포함할 수 있다.According to one embodiment, the act of chaining the grouped data may include, in the grouped data, including a first element of the first data in the second data and a second element of the second data in the third data To < / RTI >

일 실시 예에 따르면, 상기 적어도 하나의 데이터를 그룹화하는 동작은, 미리 결정된 시간, 미리 결정된 데이터 개수, 데이터 종류 및 데이터의 중요도 중 적어도 하나에 기반하여 그룹화하는 동작을 포함할 수 있다.According to one embodiment, the grouping of the at least one data may comprise grouping based on at least one of a predetermined time, a predetermined number of data, a data type and an importance of the data.

일 실시 예에 따르면, 상기 적어도 하나의 데이터를 그룹화하는 동작은, 상기 저장된 데이터에 기반하여 머클 해쉬(merkle hash)를 생성하는 동작; 및 상기 생성된 머클 해쉬가 포함되도록 상기 저장된 데이터를 그룹화하는 동작을 포함할 수 있다.According to one embodiment, the grouping of the at least one data comprises: generating a merkle hash based on the stored data; And grouping the stored data such that the generated hash hash is included.

일 실시 예에 따르면, 상기 그룹화된 데이터는, 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함할 수 있다.According to one embodiment, the grouped data may include a merge hash identifier, a group identifier, and an identifier of a previous group.

일 실시 예에 따르면, 본 발명은 상기 블록체인에 저장된 데이터의 사본을 적어도 하나의 전자 장치로 전송하는 동작을 더 포함하며, 상기 사본은, 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함할 수 있다.According to one embodiment, the invention further comprises transmitting a copy of the data stored in the block chain to at least one electronic device, the copy comprising a hash identifier, a group identifier and an identifier of the previous group .

일 실시 예에 따르면, 본 발명은 미리 결정된 시간 및 상기 저장된 데이터의 개수 중 적어도 하나에 기반하여 상기 블록체인에 저장된 데이터의 적어도 하나의 요소와 상기 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교하여 상기 저장된 데이터의 무결성을 검증하는 동작을 더 포함할 수 있다.According to one embodiment, the present invention compares at least one element of data stored in the block chain with at least one element contained in the grouped data based on at least one of a predetermined time and the number of stored data And verifying the integrity of the stored data.

일 실시 예에 따르면, 본 발명은 상기 저장된 데이터가 무결성하지 않는 경우, 상기 무결성 여부를 출력하는 동작을 더 포함할 수 있다.According to one embodiment, the present invention may further include outputting the integrity information if the stored data is not integrity.

일 실시 예에 따르면, 본 발명은 상기 블록체인에 저장된 데이터의 무결성 여부를 판단하기 위한 증명서를 생성하여 적어도 하나의 전자 장치로 전송하는 동작을 더 포함하며, 상기 증명서는, 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 블록체인의 정보를 포함할 수 있다.According to one embodiment, the present invention further comprises generating and transmitting a certificate for determining integrity of data stored in the block chain to at least one electronic device, wherein the certificate includes at least one of the stored at least one data Information of the grouped data, and information of the block chain.

도 5는 본 발명의 일 실시 예에 따른 데이터를 그룹화하고, 상기 그룹화된 데이터의 요소들을 체인화하여 블록 체인에 저장하는 예시도이다.FIG. 5 illustrates an example of grouping data according to an embodiment of the present invention, and chaining elements of the grouped data and storing them in a block chain.

도 5를 참조하면, 서버(101)의 메모리(240)는 적어도 하나의 데이터를 저장하는 데이터 저장 영역(241)과 상기 적어도 하나의 데이터가 그룹화되고, 상기 그룹화된 데이터의 요소들을 저장하는 블록 체인(242)을 포함할 수 있다. 상기 데이터 저장 영역(241)은 복수의 데이터(520)를 저장할 수 있다. 상기 블록 체인(242)은 체인화된 데이터를 저장할 수 있다. 상기 복수의 데이터(520)는 개인 정보, 헬스 정보 및 공증 데이터 중 적어도 하나를 포함할 수 있다. 상기 복수의 데이터(520) 중 각각의 데이터(521 내지 529)는 전자 장치(102)의 사용자 별로 개인 정보, 헬스 정보 및 공증 데이터를 포함할 수 있다. 상기 각각의 데이터(521 내지 529)는 데이터 식별자 및 데이터의 정보를 포함할 수 있다. 서버(101)는 미리 결정된 데이터의 개수 단위로 데이터를 그룹화하고, 그룹화된 데이터를 체인화하여 블록 체인(530)에 저장할 수 있다. 예를 들면, 서버(101)는 제1 데이터(521), 제2 데이터(522) 및 제3 데이터(523)를 그룹화하여 생성된 제1 그룹화된 데이터(531)를 블록 체인(530)에 저장할 수 있다. 상기 제1 그룹화된 데이터(531)는 마크 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함할 수 있다. 서버(101)는 제1 데이터(521), 제2 데이터(522) 및 제3 데이터(523)를 그룹화하고, 상기 그룹화된 데이터(531)의 요소들을 체인화하여 블록 체인(530)에 저장할 수 있다. 예를 들면, 서버(101)는 제4 데이터(524), 제5 데이터(525) 및 제6 데이터(526)를 그룹화하여 생성된 제2 그룹화된 데이터(532)를 블록 체인(530)에 저장할 수 있다. 상기 제2 그룹화된 데이터(532)는 마크 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자(예: 제1 그룹화된 식별자(531))를 포함할 수 있다. Referring to FIG. 5, the memory 240 of the server 101 includes a data storage area 241 for storing at least one data, and a block chain for storing the elements of the grouped data, Lt; RTI ID = 0.0 > 242 < / RTI > The data storage area 241 may store a plurality of data 520. The block chain 242 may store the chained data. The plurality of data 520 may include at least one of personal information, health information, and notarized data. The data 521 to 529 of the plurality of data 520 may include personal information, health information, and notarized data for each user of the electronic device 102. Each of the data 521 to 529 may include a data identifier and information of data. The server 101 may group the data in units of a predetermined number of data, and may chain the grouped data and store the grouped data in the block chain 530. For example, the server 101 stores the first grouped data 531 generated by grouping the first data 521, the second data 522, and the third data 523 in the block chain 530 . The first grouped data 531 may include a mark hash identifier, a group identifier, and an identifier of a previous group. The server 101 may group the first data 521, the second data 522 and the third data 523 and chain the elements of the grouped data 531 and store them in the block chain 530 . For example, the server 101 stores the second grouped data 532 generated by grouping the fourth data 524, the fifth data 525 and the sixth data 526 in the block chain 530 . The second grouped data 532 may include a mark hash identifier, a group identifier, and an identifier of a previous group (e.g., a first grouped identifier 531).

다양한 실시 예에 따르면, 서버(101)는 이전 그룹의 식별자가 포함되도록 그룹화된 데이터를 생성하여 블록 체인(530)에 저장할 수 있다. 서버(101)는 데이터 저장 영역(241)에 포함된 복수의 데이터(521 내지 529)를 미리 결정된 개수로 그룹화하고, 상기 그룹화된 데이터의 요소들을 체인화하고, 상기 체인화된 데이터를 블록 체인(530)에 저장할 수 있다. 서버(101)는 데이터 저장 영역(241)에 포함된 복수의 데이터(521 내지 529)가 저장된 시간에 기반하여 그룹화하고, 상기 그룹화된 데이터의 요소들을 체인화하고, 상기 체인화된 데이터를 블록 체인(530)에 저장할 수 있다. 서버(101)는 데이터 저장 영역(241)에 포함된 복수의 데이터(521 내지 529)의 중요도에 기반하여 그룹화하고, 상기 그룹화된 데이터의 요소들을 체인화하고, 상기 체인화된 데이터를 블록 체인(530)에 저장할 수 있다. 서버(101)의 블록 체인(530)은 복수의 그룹화된 데이터를 저장할 수 있다. 상기 서버(101)는 각각의 그룹화된 데이터의 요소를 체인화하여 블록 체인(530)에 저장할 수 있다. 서버(101)는 블록 체인(530)에 저장된 각각의 그룹화된 데이터를 블록체인 트랜잭션으로 만들어 적어도 하나의 전자 장치(102)로 전송할 수 있다. 상기 서버(101)에 연결된 전자 장치(102)는 서버(101)의 블록 체인(530)에 저장된 적어도 하나의 그룹화된 데이터의 요소들(541, 542, 543)을 저장할 수 있다. 상기 전자 장치(102)는 서버(101)의 블록 체인(530)에 저장된 적어도 하나의 그룹화된 데이터의 요소들(541, 542, 543)을 메모리(280)의 블록 체인(281)에 저장할 수 있다. 상기 그룹화된 데이터의 사본은 에비던스 해쉬(evidence hash)를 포함할 수 있으며, 상기 에비던스 해쉬는 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함할 수 있다.According to various embodiments, the server 101 may generate grouped data to include the identifier of the previous group and store the grouped data in the block chain 530. The server 101 groups a plurality of data 521 to 529 included in the data storage area 241 into a predetermined number of chunks, chaining elements of the grouped data, and transmits the chuned data to the block chain 530. [ Lt; / RTI > The server 101 groups the plurality of data 521 to 529 included in the data storage area 241 on the basis of the stored time, chokes the elements of the grouped data, and transmits the chained data to the block chain 530 ). ≪ / RTI > The server 101 groups the data based on the importance of the plurality of data 521 to 529 included in the data storage area 241 and chaining the elements of the grouped data and transmits the chained data to the block chain 530. [ Lt; / RTI > The block chain 530 of the server 101 may store a plurality of grouped data. The server 101 may chain each element of the grouped data and store the chained element in the block chain 530. The server 101 may make each of the grouped data stored in the block chain 530 into a block-chain transaction and transmit it to the at least one electronic device 102. [ The electronic device 102 connected to the server 101 may store at least one grouped data element 541, 542, 543 stored in the block chain 530 of the server 101. The electronic device 102 may store at least one grouped data element 541, 542, 543 stored in a block chain 530 of the server 101 in a block chain 281 of the memory 280 . The copy of the grouped data may include an evidence hash, which may include a hash identifier, a group identifier, and an identifier of the previous group.

다양한 실시 예에 따르면, 서버(101)는 블록 체인(530)에 저장된 그룹화된 데이터의 무결성 여부를 판단하는 증명서를 생성할 수 있다. 상기 서버(101)는 상기 저장된 블록체인의 무결성 여부를 판단하기 위한 증명서(certificate)를 생성하여 적어도 하나의 전자 장치(102)로 전송할 수 있다. 상기 증명서는 전자 장치(102)가 데이터가 위조 되었는지 또는 변조 되었는지를 판단하기 위해 이용될 수 있다. 상기 증명서는 데이터 저장 영역(241)에 저장된 데이터의 정보, 상기 데이터 저장 영역(241)에 저장된 데이터를 그룹화한 데이터 그룹 정보 및 상기 그룹화된 데이터가 저장된 블록 체인의 정보를 포함할 수 있다. 상기 서버(101)의 데이터 저장 영역(241)에 저장된 데이터의 정보는 데이터 식별자 및 데이터의 내용에 관한 정보를 포함할 수 있다. 상기 그룹화된 데이터의 그룹 정보는 그룹화된 데이터의 식별자 및 머클 해쉬 식별자를 포함할 수 있다. 상기 블록 체인의 정보는 블록 체인의 식별자 및 타임 스탬프를 포함할 수 있다. 상기 블록 체인의 정보는 전자 장치(102)에 저장된 데이터의 블록 체인에 대한 정보를 포함할 수 있다.According to various embodiments, the server 101 may generate a certificate that determines whether the grouped data stored in the block chain 530 is integrity. The server 101 may generate a certificate for determining integrity of the stored block chain and transmit the generated certificate to the at least one electronic device 102. The certificate may be used by electronic device 102 to determine if data has been tampered with or tampered with. The certificate may include information on data stored in the data storage area 241, data group information on which data stored in the data storage area 241 is grouped, and information on a block chain in which the grouped data is stored. The information of the data stored in the data storage area 241 of the server 101 may include a data identifier and information on the content of the data. The group information of the grouped data may include an identifier of the grouped data and a merge hash identifier. The information in the block chain may include an identifier of the block chain and a time stamp. The information in the block chain may include information about a block chain of data stored in the electronic device 102.

본 발명에 사용된 용어 "모듈"은, 예를 들어, 하드웨어, 소프트웨어 또는 펌웨어(firmware) 중 하나 또는 둘 이상의 조합을 포함하는 단위(unit)를 의미할 수 있다. "모듈"은 예를 들어, 유닛(unit), 로직(logic), 논리 블록(logical block), 부품(component) 또는 회로(circuit) 등의 용어와 바꾸어 사용(interchangeably use)될 수 있다. "모듈"은, 일체로 구성된 부품의 최소 단위 또는 그 일부가 될 수 있다. "모듈"은 하나 또는 그 이상의 기능을 수행하는 최소 단위 또는 그 일부가 될 수도 있다. "모듈"은 기계적으로 또는 전자적으로 구현될 수 있다. 예를 들면, 본 발명에 따른 "모듈"은, 알려졌거나 앞으로 개발될, 어떤 동작들을 수행하는 ASIC(application-specific integrated circuit) 칩, FPGAs(field-programmable gate arrays) 또는 프로그램 가능 논리 장치(programmable-logic device) 중 적어도 하나를 포함할 수 있다.The term "module" as used in the present invention may mean a unit including, for example, one or a combination of hardware, software, or firmware. A "module" may be interchangeably used with terms such as, for example, unit, logic, logical block, component or circuit. A "module" may be a minimum unit or a portion of an integrally constructed component. A "module" may be a minimum unit or a portion thereof that performs one or more functions. "Modules" may be implemented either mechanically or electronically. For example, a "module" in accordance with the present invention may be implemented as an application-specific integrated circuit (ASIC) chip, field-programmable gate arrays (FPGAs) or programmable logic arrays logic device).

다양한 실시 예에 따르면, 본 발명에 따른 장치(예: 모듈들 또는 그 기능들) 또는 방법(예: 동작들)의 적어도 일부는, 예컨대, 프로그래밍 모듈의 형태로 컴퓨터로 읽을 수 있는 저장매체(computer-readable storage media)에 저장된 명령어로 구현될 수 있다. 상기 명령어는, 제어 회로에 의해 실행될 경우, 상기 제어 회로가 상기 명령어에 해당하는 기능을 수행할 수 있다. 컴퓨터로 읽을 수 있는 저장매체는, 예를 들면, 상기 메모리(130)가 될 수 있다. 상기 프로그래밍 모듈의 적어도 일부는, 예를 들면, 제어 회로에 의해 구현(implement)(예: 실행)될 수 있다. 상기 프로그래밍 모듈의 적어도 일부는 하나 이상의 기능을 수행하기 위한, 예를 들면, 모듈, 프로그램, 루틴, 명령어 세트 (sets of instructions) 또는 프로세스 등을 포함할 수 있다.According to various embodiments, at least a portion of a device (e.g., modules or functions thereof) or a method (e.g., operations) according to the present invention may be stored in a computer readable storage medium -readable storage media). When executed by the control circuit, the control circuit may perform a function corresponding to the command. The computer readable storage medium may be, for example, the memory 130. [ At least some of the programming modules may be implemented (e.g., implemented) by, for example, control circuitry. At least some of the programming modules may include, for example, modules, programs, routines, sets of instructions or processes, etc. to perform one or more functions.

상기 컴퓨터로 판독 가능한 기록 매체에는 하드디스크, 플로피디스크 및 자기 테이프와 같은 마그네틱 매체(Magnetic Media)와, CD-ROM(Compact Disc Read Only Memory), DVD(Digital Versatile Disc)와 같은 광기록 매체(Optical Media)와, 플롭티컬 디스크(Floptical Disk)와 같은 자기-광 매체(Magneto-Optical Media)와, 그리고 ROM(Read Only Memory), RAM(Random Access Memory), 플래시 메모리 등과 같은 프로그램 명령(예: 프로그래밍 모듈)을 저장하고 수행하도록 특별히 구성된 하드웨어 장치가 포함될 수 있다. 또한, 프로그램 명령에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함할 수 있다. 상술한 하드웨어 장치는 본 발명의 동작을 수행하기 위해 하나 이상의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지다.The computer-readable recording medium includes a magnetic medium such as a hard disk, a floppy disk and a magnetic tape, an optical recording medium such as a CD-ROM (Compact Disc Read Only Memory), a DVD (Digital Versatile Disc) A magneto-optical medium such as a floppy disk, and a program command such as a read only memory (ROM), a random access memory (RAM), a flash memory, Module) that is configured to store and perform the functions described herein. The program instructions may also include machine language code such as those generated by a compiler, as well as high-level language code that may be executed by a computer using an interpreter or the like. The hardware devices described above may be configured to operate as one or more software modules to perform the operations of the present invention, and vice versa.

본 발명에 따른 모듈 또는 프로그래밍 모듈은 전술한 구성요소들 중 적어도 하나 이상을 포함하거나, 일부가 생략되거나, 또는 추가적인 다른 구성요소를 더 포함할 수 있다. 본 발명에 따른 모듈, 프로그래밍 모듈 또는 다른 구성요소에 의해 수행되는 동작들은 순차적, 병렬적, 반복적 또는 휴리스틱(heuristic)한 방법으로 실행될 수 있다. 또한, 일부 동작은 다른 순서로 실행되거나, 생략되거나, 또는 다른 동작이 추가될 수 있다. 다양한 실시 예에 따르면, 명령들을 저장하고 있는 저장 매체에 있어서, 상기 명령들은, 서버에서 데이터의 무결성을 검증하는 방법에 있어서, 메모리에 저장된 적어도 하나의 데이터를 그룹화하는 제1 명령 셋; 상기 그룹화된 데이터를 체인화하는 제2 명령 셋; 및 상기 체인화된 데이터를 블록체인에 저장하는 제3 명령 셋을 포함할 수 있다.A module or programming module according to the present invention may include at least one or more of the above-described components, some of which may be omitted, or may further include other additional components. Operations performed by modules, programming modules, or other components in accordance with the present invention may be performed in a sequential, parallel, iterative, or heuristic manner. Also, some operations may be performed in a different order, omitted, or other operations may be added. According to various embodiments, there is provided a storage medium storing instructions, the instructions comprising: a first instruction set for grouping at least one data stored in a memory; A second instruction set for chaining the grouped data; And a third instruction set for storing the chained data in a block chain.

그리고 본 명세서와 도면에 개시된 본 발명의 실시 예들은 본 발명의 기술 내용을 쉽게 설명하고 본 발명의 이해를 돕기 위해 특정 예를 제시한 것일 뿐이며, 본 발명의 범위를 한정하고자 하는 것은 아니다. 따라서 본 발명의 범위는 여기에 개시된 실시 예들 이외에도 본 발명의 기술적 사상을 바탕으로 도출되는 모든 변경 또는 변형된 형태가 본 발명의 범위에 포함되는 것으로 해석되어야 한다.It is to be understood that both the foregoing general description and the following detailed description of the present invention are exemplary and explanatory and are intended to provide further explanation of the invention as claimed. Accordingly, the scope of the present invention should be construed as being included in the scope of the present invention, all changes or modifications derived from the technical idea of the present invention.

101: 서버 102: 전자 장치
210: 프로세서 220: 통신 인터페이스
230: 입출력 인터페이스 240: 메모리
241: 데이터 저장 영역 242: 블록 체인
101: server 102: electronic device
210: processor 220: communication interface
230: input / output interface 240: memory
241: Data storage area 242: Block chain

Claims (20)

데이터의 무결성을 검증하는 서버에 있어서,
적어도 하나의 데이터를 저장하는 메모리; 및
상기 저장된 데이터를 그룹화하고, 상기 그룹화된 데이터의 요소들을 체인화하고, 상기 체인화된 데이터를 블록체인(blockchain)에 저장하는 프로세서를 포함하는 서버.
A server for verifying the integrity of data,
A memory for storing at least one data; And
A processor for grouping the stored data, chaining elements of the grouped data, and storing the chained data in a block chain.
제1 항에 있어서,
상기 프로세서는,
상기 그룹화된 데이터 중에서 제1 데이터의 제1 요소를 제2 데이터에 포함하고, 상기 제2 데이터의 제2 요소를 제3 데이터에 포함하도록 체인화하는 서버.
The method according to claim 1,
The processor comprising:
A first element of the first data is included in the second data among the grouped data, and a second element of the second data is included in the third data.
제1 항에 있어서,
상기 프로세서는,
미리 결정된 시간, 미리 결정된 데이터 개수, 데이터 종류 및 데이터의 중요도 중 적어도 하나에 기반하여 상기 저장된 데이터를 그룹화하는 서버.
The method according to claim 1,
The processor comprising:
Wherein the server groups the stored data based on at least one of a predetermined time, a predetermined number of data, a data type, and an importance of the data.
제1 항에 있어서,
상기 프로세서는,
상기 저장된 데이터에 기반하여 머클 해쉬(merkle hash)를 생성하고, 상기 생성된 머클 해쉬가 포함되도록 상기 저장된 데이터를 그룹화하며,
상기 그룹화된 데이터는, 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함하는 서버.
The method according to claim 1,
The processor comprising:
Generating a merge hash based on the stored data, grouping the stored data to include the generated merge hash,
Wherein the grouped data comprises a merge hash identifier, a group identifier, and an identifier of a previous group.
제1 항에 있어서,
상기 적어도 하나의 데이터는, 개인 정보, 헬스 정보 및 공증 데이터 중 적어도 하나를 포함하는 서버.
The method according to claim 1,
Wherein the at least one data comprises at least one of personal information, health information, and notarized data.
제1 항에 있어서,
상기 프로세서는,
미리 결정된 시간 및 상기 저장된 데이터의 개수 중 적어도 하나에 기반하여 상기 블록체인에 저장된 데이터의 적어도 하나의 요소와 상기 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교하여 상기 저장된 데이터의 무결성을 검증하는 서버.
The method according to claim 1,
The processor comprising:
A server for verifying the integrity of the stored data by comparing at least one element of data stored in the block chain with at least one element included in the grouped data based on at least one of a predetermined time and a number of the stored data, .
제6 항에 있어서,
입출력 인터페이스를 더 포함하며,
상기 프로세서는,
상기 저장된 데이터가 무결성하지 않는 경우, 상기 입출력 인터페이스를 통해 상기 무결성 여부를 출력하는 서버.
The method according to claim 6,
Further comprising an input / output interface,
The processor comprising:
And outputting the integrity information through the input / output interface when the stored data is not integrity.
제1 항에 있어서,
상기 프로세서는,
상기 블록체인에 저장된 데이터의 무결성 여부를 판단하기 위한 증명서를 생성하여 적어도 하나의 전자 장치로 전송하며,
상기 증명서는, 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 블록체인의 정보를 포함하는 서버.
The method according to claim 1,
The processor comprising:
Generating a certificate for determining whether the data stored in the block chain is integrity, and transmitting the certificate to at least one electronic device,
Wherein the certificate includes information of the stored at least one piece of data, information of the grouped data, and information of the block chain.
제8 항에 있어서,
상기 프로세서는,
상기 블록체인에 저장된 데이터에 대한 적어도 하나의 요소에 대한 요청이 상기 적어도 하나의 전자 장치로부터 수신되면, 상기 요청에 해당되는 요소의 종류에 따라 데이터의 포맷을 변환하여 상기 요청된 적어도 하나의 요소를 상기 전자 장치로 전송하는 서버.
9. The method of claim 8,
The processor comprising:
If a request for at least one element of data stored in the block chain is received from the at least one electronic device, converting the format of the data according to the type of element corresponding to the request, To the electronic device.
서버에서 데이터의 무결성을 검증하는 방법에 있어서,
메모리에 저장된 적어도 하나의 데이터를 그룹화하는 동작;
상기 그룹화된 데이터를 체인화하는 동작; 및
상기 체인화된 데이터를 블록체인에 저장하는 동작을 포함하는 방법.
A method for verifying the integrity of data at a server,
Grouping at least one data stored in the memory;
Chaining the grouped data; And
And storing the chained data in a block chain.
제10 항에 있어서,
상기 그룹화된 데이터를 체인화하는 동작은,
상기 그룹화된 데이터 중에서 제1 데이터의 제1 요소를 제2 데이터에 포함하고, 상기 제2 데이터의 제2 요소를 제3 데이터에 포함하도록 체인화하는 동작을 포함하는 방법.
11. The method of claim 10,
Wherein the act of chaining the grouped data comprises:
And including the first element of the first data in the second data and the second element of the second data in the third data from among the grouped data.
제10 항에 있어서,
상기 적어도 하나의 데이터를 그룹화하는 동작은,
미리 결정된 시간, 미리 결정된 데이터 개수, 데이터 종류 및 데이터의 중요도 중 적어도 하나에 기반하여 그룹화하는 것을 특징으로 하는 방법.
11. The method of claim 10,
Wherein the grouping of the at least one data comprises:
Wherein the grouping is based on at least one of a predetermined time, a predetermined number of data, a data type, and an importance of data.
제10 항에 있어서,
상기 적어도 하나의 데이터를 그룹화하는 동작은,
상기 저장된 데이터에 기반하여 머클 해쉬(merkle hash)를 생성하는 동작; 및
상기 생성된 머클 해쉬가 포함되도록 상기 저장된 데이터를 그룹화하는 동작을 포함하는 방법.
11. The method of claim 10,
Wherein the grouping of the at least one data comprises:
Generating a merge hash based on the stored data; And
And grouping the stored data such that the generated hash hash is included.
제10 항에 있어서,
상기 그룹화된 데이터는, 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함하는 방법.
11. The method of claim 10,
Wherein the grouped data comprises a merge hash identifier, a group identifier, and an identifier of a previous group.
제10 항에 있어서,
미리 결정된 시간 및 상기 저장된 데이터의 개수 중 적어도 하나에 기반하여 상기 블록체인에 저장된 데이터의 적어도 하나의 요소와 상기 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교하여 상기 저장된 데이터의 무결성을 검증하는 동작을 더 포함하는 방법.
11. The method of claim 10,
Comparing at least one element of data stored in the block chain with at least one element included in the grouped data based on at least one of a predetermined time and the number of stored data to verify the integrity of the stored data ≪ / RTI >
제15 항에 있어서,
상기 저장된 데이터가 무결성하지 않는 경우, 상기 무결성 여부를 출력하는 동작을 더 포함하는 방법.
16. The method of claim 15,
And outputting the integrity if the stored data is not integrity.
제10 항에 있어서,
상기 블록체인에 저장된 데이터의 무결성 여부를 판단하기 위한 증명서를 생성하여 적어도 하나의 전자 장치로 전송하는 동작을 더 포함하며,
상기 증명서는, 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 블록체인의 정보를 포함하는 방법.
11. The method of claim 10,
Further comprising: generating a certificate for determining whether the data stored in the block chain is integrity, and transmitting the certificate to at least one electronic device,
Wherein the certificate includes information of the stored at least one piece of data, information of the grouped data, and information of the block chain.
데이터의 무결성을 검증하는 전자 장치에 있어서,
서버로부터 수신되는 증명서를 저장하는 메모리; 및
상기 저장된 증명서에 기반하여 블록체인에 저장된 데이터의 요소들을 블록체인 네트워크에 요청하여 획득하고, 상기 획득된 요소들과 그룹화된 데이터를 비교하여 무결성을 검증하는 적어도 하나의 프로세서를 포함하는 전자 장치.
An electronic device for verifying the integrity of data,
A memory for storing a certificate received from a server; And
At least one processor for requesting and obtaining elements of data stored in a block chain based on the stored certificate in a block-chain network, and verifying integrity by comparing grouped data with the obtained elements.
제18 항에 있어서,
상기 프로세서는,
상기 블록체인에 저장된 데이터의 무결성 여부를 판단하기 위한 증명서를 상기 서버로부터 수신하며,
상기 증명서는, 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 블록체인의 정보를 포함하는 전자 장치.
19. The method of claim 18,
The processor comprising:
From the server, a certificate for judging whether or not the data stored in the block chain is integrity,
Wherein the certificate includes information of the stored at least one piece of data, information of the grouped data, and information of the block chain.
제18 항에 있어서,
상기 프로세서는,
상기 저장된 데이터가 무결성하지 않는 경우, 상기 무결성 여부를 출력하는 전자 장치.
19. The method of claim 18,
The processor comprising:
And if the stored data is not integrity, outputs the integrity.
KR1020170014325A 2017-02-01 2017-02-01 Electronic apparatus and method for verifing data integrity based on a blockchain KR20180089682A (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
KR1020170014325A KR20180089682A (en) 2017-02-01 2017-02-01 Electronic apparatus and method for verifing data integrity based on a blockchain
PCT/KR2018/001388 WO2018143694A1 (en) 2017-02-01 2018-02-01 Electronic device and method for verifying integrity of data on basis of blockchain

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020170014325A KR20180089682A (en) 2017-02-01 2017-02-01 Electronic apparatus and method for verifing data integrity based on a blockchain

Publications (1)

Publication Number Publication Date
KR20180089682A true KR20180089682A (en) 2018-08-09

Family

ID=63040000

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020170014325A KR20180089682A (en) 2017-02-01 2017-02-01 Electronic apparatus and method for verifing data integrity based on a blockchain

Country Status (2)

Country Link
KR (1) KR20180089682A (en)
WO (1) WO2018143694A1 (en)

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109558081A (en) * 2018-11-23 2019-04-02 深圳市威赫科技有限公司 A kind of data storage mechanism and system
KR102002509B1 (en) * 2019-04-04 2019-07-22 주식회사 한국정보보호경영연구소 Privite blockchain system including notarizing center and notarial method thereof
KR102036618B1 (en) * 2019-01-31 2019-10-28 주식회사그린존시큐리티 Integrity vertfication chain for verifying integrity of device and method for verifying integrity of device using the same
KR102055880B1 (en) * 2018-09-04 2019-12-13 박영준 A system for providing hull cleaning information and the method of providing hull cleaning information using the same
KR20200049282A (en) * 2018-10-31 2020-05-08 상명대학교 천안산학협력단 Session key establishment method using blockchain
KR20200057438A (en) * 2018-11-16 2020-05-26 순천향대학교 산학협력단 Method for integrity mutual verification in a resource rich environment
KR20200062902A (en) 2018-11-27 2020-06-04 부산대학교 산학협력단 Comprehensive Vehicle Information System Based on Block Chain for Reliability and Integrity
KR20200069034A (en) 2018-12-06 2020-06-16 한국과학기술연구원 Method for preventing falsification data from being stored in network and system performing the method
CN111899097A (en) * 2018-12-28 2020-11-06 创新先进技术有限公司 Method and system for accepting block link deposit certificate transaction
KR20200131702A (en) 2019-05-14 2020-11-24 조선대학교산학협력단 A block chain system, a block chain provision system, a method for providing block chain for data, and a data structure in a block chain

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109685525B (en) * 2018-11-29 2020-12-29 河海大学 Self-destructible commodity tracing information storage method based on Merkle tree
WO2020124067A1 (en) 2018-12-14 2020-06-18 Carrier Corporation Alarm management system with blockchain technology
CN109840769B (en) * 2019-01-21 2022-01-25 中国联合网络通信集团有限公司 Block chain based evidence storing method, device, system and storage medium
US20200177390A1 (en) * 2019-04-18 2020-06-04 Alibaba Group Holding Limited Providing data verification in a blockchain ledger
CN110147410B (en) * 2019-04-18 2020-08-04 阿里巴巴集团控股有限公司 Data verification method, system, device and equipment in block chain type account book
CN110245518B (en) * 2019-05-31 2024-05-17 创新先进技术有限公司 Data storage method, device and equipment

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8806617B1 (en) * 2002-10-14 2014-08-12 Cimcor, Inc. System and method for maintaining server data integrity
US8676760B2 (en) * 2008-08-05 2014-03-18 International Business Machines Corporation Maintaining data integrity in data servers across data centers
US9608829B2 (en) * 2014-07-25 2017-03-28 Blockchain Technologies Corporation System and method for creating a multi-branched blockchain with configurable protocol rules
AU2016235539B2 (en) * 2015-03-20 2019-01-24 Rivetz Corp. Automated attestation of device integrity using the block chain
US20160283920A1 (en) * 2015-03-28 2016-09-29 Justin Fisher Authentication and verification of digital data utilizing blockchain technology

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102055880B1 (en) * 2018-09-04 2019-12-13 박영준 A system for providing hull cleaning information and the method of providing hull cleaning information using the same
KR20200049282A (en) * 2018-10-31 2020-05-08 상명대학교 천안산학협력단 Session key establishment method using blockchain
KR20200057438A (en) * 2018-11-16 2020-05-26 순천향대학교 산학협력단 Method for integrity mutual verification in a resource rich environment
CN109558081A (en) * 2018-11-23 2019-04-02 深圳市威赫科技有限公司 A kind of data storage mechanism and system
KR20200062902A (en) 2018-11-27 2020-06-04 부산대학교 산학협력단 Comprehensive Vehicle Information System Based on Block Chain for Reliability and Integrity
KR20200069034A (en) 2018-12-06 2020-06-16 한국과학기술연구원 Method for preventing falsification data from being stored in network and system performing the method
CN111899097A (en) * 2018-12-28 2020-11-06 创新先进技术有限公司 Method and system for accepting block link deposit certificate transaction
CN111899097B (en) * 2018-12-28 2023-10-27 创新先进技术有限公司 Method and system for accepting blockchain certification transaction
KR102036618B1 (en) * 2019-01-31 2019-10-28 주식회사그린존시큐리티 Integrity vertfication chain for verifying integrity of device and method for verifying integrity of device using the same
WO2020159053A1 (en) * 2019-01-31 2020-08-06 주식회사그린존시큐리티 Integrity verification chain for verifying integrity of device, and method for verifying integrity of device by using same
KR102002509B1 (en) * 2019-04-04 2019-07-22 주식회사 한국정보보호경영연구소 Privite blockchain system including notarizing center and notarial method thereof
KR20200131702A (en) 2019-05-14 2020-11-24 조선대학교산학협력단 A block chain system, a block chain provision system, a method for providing block chain for data, and a data structure in a block chain

Also Published As

Publication number Publication date
WO2018143694A1 (en) 2018-08-09

Similar Documents

Publication Publication Date Title
KR20180089682A (en) Electronic apparatus and method for verifing data integrity based on a blockchain
US10735427B2 (en) Method and apparatus for managing program of electronic device
CN107665426B (en) Method and electronic device for payment using biometric authentication
KR102294118B1 (en) Apparatus and method and for connecting security
KR102400477B1 (en) Apparatus and Method for Managing Application
KR102351042B1 (en) Method and device for authenticating in electronic device
KR20160105296A (en) Registering Method for Payment means information and electronic device supporting the same
US20180019994A1 (en) Method of authenticating user and electronic device supporting the same
KR20170081508A (en) Electronic apparatus and operating method thereof
CN106357599B (en) Electronic device, authentication proxy server, and payment system
KR101834849B1 (en) Electronic device and user authentication method thereof
KR102586443B1 (en) Electronic device for providing electronic payment and method thereof
KR20160056591A (en) Query processing apparatus and method
KR20160033409A (en) Electronic device and method for processing data in electronic device
KR102509594B1 (en) Method for detecting the tampering of application code and electronic device supporting the same
KR101775668B1 (en) Electronic device, certification agency server and payment system
KR20170098117A (en) Electronic device for authenticating based on biometric data and operating method thereof
KR20170004456A (en) A method for managing data and apparatuses therefor
KR20160049802A (en) Apparatus and method for payment using a secure module
KR20170084934A (en) Electronic apparatus and method for authentication of identification information thereof
KR20170054942A (en) Method for user authentication and electronic device implementing the same
KR20170108555A (en) Method for performing payment and electronic device supporting the same
KR20160057101A (en) Method for securing image data and electronic device implementing the same
KR20160033510A (en) Electronic Device Using Token for Setting Permission
KR20180046149A (en) Electronic apparatus and method for performing authentication