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 PDFInfo
- 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
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/32—Cryptographic 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/3263—Cryptographic 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
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/06—Cryptographic 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
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/06—Cryptographic 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/0618—Block ciphers, i.e. encrypting groups of characters of a plain text message using fixed encryption transformation
- H04L9/0637—Modes of operation, e.g. cipher block chaining [CBC], electronic codebook [ECB] or Galois/counter mode [GCM]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/06—Cryptographic 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/0643—Hash functions, e.g. MD5, SHA, HMAC or f9 MAC
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/32—Cryptographic 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
Description
본 발명은 데이터의 무결성을 검증하는 것으로서, 서버에 저장된 데이터의 무결성을 블록체인을 이용하여 검증하는 전자 장치 및 방법에 관한 것이다.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
다양한 실시 예에 따른 서버(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
다양한 실시 예에 따르면, 상기 서버(101)는, 상기 저장할 내용을 블록체인 트랜잭션으로 만들어 블록체인 네트워크에 참여한 적어도 하나의 전자 장치(102)로 전송할 수 있다. 상기 블록체인 트랜잭션에 저장할 데이터는 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함할 수 있다. 상기 서버(101)는 미리 결정된 시간 및 상기 저장된 데이터의 개수 중 적어도 하나에 기반하여 상기 저장된 블록체인에 저장된 적어도 하나의 요소와 상기 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교하여 상기 저장된 데이터의 무결성을 검증할 수 있다. 상기 서버(101)는 상기 저장된 데이터가 무결성하지 않는 경우, 입출력 인터페이스(230)를 통해 상기 무결성 여부를 출력할 수 있다. 상기 서버(101)는 상기 저장된 데이터가 위조 또는 변조되거나 손상된 경우, 상기 서버(101)를 관리하는 관리자가 이러한 사항을 알 수 있도록 입출력 인터페이스(230)를 통해 상기 무결성 여부를 출력할 수 있다. 상기 프로세서(210)는 상기 저장된 블록체인의 무결성 여부를 판단하기 위한 증명서(certificate)를 생성하여 적어도 하나의 전자 장치로 전송할 수 있다. 상기 증명서는, 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 저장된 블록체인의 정보를 포함할 수 있다. 상기 증명서는 전자 장치(102)가 데이터의 무결성 여부를 판단하는데 이용될 수 있다. 상기 프로세서(210)는 상기 저장된 블록체인에 대한 적어도 하나의 요소의 요청이 상기 적어도 하나의 전자 장치로부터 수신되면, 상기 요청된 적어도 하나의 요소를 상기 전자 장치로 전송할 수 있다.According to various embodiments, the
다양한 실시 예에 따른 전자 장치(102)는, 서버(101)로부터 수신되어 메모리(280)에 저장된 증명서에 기반하여 블록체인(281)에 저장된 요소들을 상기 서버(101)로 요청할 수 있다. 상기 전자 장치(102)는 메모리(280)에 저장된 증명서를 이용하여 상기 메모리(280)에 저장된 블록체인(281)에 저장된 요소들에 대응하는 그룹화된 데이터를 상기 서버(101)로 요청할 수 있다. 상기 메모리(280)는 서버(101)에서 그룹화된 각각의 데이터에 대한 적어도 하나의 블록체인을 저장할 수 있다. 상기 전자 장치(102)는 상기 획득된 요소들과 상기 그룹화된 데이터를 비교하여 데이터의 무결성을 검증할 수 있다. 상기 전자 장치(102)는 미리 결정된 시간 및 저장된 데이터의 개수 중 적어도 하나에 기반하여 블록체인에 저장된 적어도 하나의 요소와 상기 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교하여 상기 데이터의 무결성을 검증할 수 있다. 예를 들면, 상기 전자 장치(102)는 상기 데이터가 무결성하지 않는 경우, 상기 입출력인터페이스(270) 및 상기 디스플레이(290) 중 적어도 하나를 통해 무결성 여부를 출력할 수 있다.The
도 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
다양한 실시 예에 따르면, 상기 서버(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
다양한 실시 예에 따르면, 서버(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
다양한 실시 예에 따르면, 상기 서버(101)의 입출력인터페이스(230) 또는 상기 전자 장치(102)의 입출력인터페이스(270)는 전자 장치(102), 서버(101) 또는 다른 외부 기기(미도시)로부터 입력된 명령 또는 데이터를 다른 구성요소(들)에 전달할 수 있는 인터페이스의 역할을 할 수 있다. 또한, 입출력 인터페이스(230, 270)는 다른 구성요소(들)로부터 수신된 명령 또는 데이터를 전자 장치(102), 서버(101) 또는 다른 외부 기기(미도시)로 출력할 수 있다.According to various embodiments, the input /
다양한 실시 예에 따르면, 상기 서버(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
다양한 실시 예에 따르면, 상기 서버(101)의 프로세서(210) 또는 상기 전자 장치(102)의 프로세서(210)는 중앙처리장치(central processing unit(CPU)), 어플리케이션 프로세서(application processor(AP)), 또는 커뮤니케이션 프로세서(communication processor(CP)) 중 하나 또는 그 이상을 포함할 수 있다. 프로세서(210)는, 예를 들면, 서버(101)의 적어도 하나의 다른 구성요소들의 제어 및/또는 통신에 관한 연산이나 데이터 처리를 실행할 수 있다.According to various embodiments, the
다양한 실시 예에 따르면, 상기 서버(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
다양한 실시 예에 따르면, 상기 서버(101)의 프로세서(210)는 미리 결정된 시간 및 저장된 데이터의 개수 중 적어도 하나에 기반하여 블록 체인에 저장된 데이터의 적어도 하나의 요소와 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교하여 상기 저장된 데이터의 무결성을 검증할 수 있다. 상기 서버(101)의 프로세서(210)는 그룹화된 데이터의 체인화가 깨져 있는지도 검증할 수 있다.According to various embodiments, the
다양한 실시 예에 따르면, 상기 서버(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
다양한 실시 예에 따르면, 상기 서버(101)의 프로세서(210)는 상기 저장된 데이터가 무결성하지 않는 경우, 입출력 인터페이스(230)를 통해 상기 무결성 여부를 출력할 수 있다. 상기 프로세서(210)는 상기 저장된 데이터가 위조 또는 변조되거나 손상된 경우, 상기 서버(101)를 관리하는 관리자가 이러한 사항을 알 수 있도록 입출력 인터페이스(230)를 통해 상기 무결성 여부를 출력할 수 있다. 상기 프로세서(210)는 상기 저장된 블록체인의 무결성 여부를 판단하기 위한 증명서(certificate)를 생성하여 적어도 하나의 전자 장치로 전송할 수 있다. 상기 증명서는, 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 저장된 블록체인의 정보를 포함할 수 있다. 상기 증명서는 전자 장치(102)가 데이터의 무결성 여부를 판단하는데 이용될 수 있다. 상기 프로세서(210)는 상기 저장된 블록체인에 대한 적어도 하나의 요소의 요청이 상기 적어도 하나의 전자 장치로부터 수신되면, 상기 요청된 적어도 하나의 요소를 상기 전자 장치로 전송할 수 있다.According to various embodiments, the
다양한 실시 예에 따르면, 상기 전자 장치(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
다양한 실시 예에 따르면, 상기 전자 장치(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
다양한 실시 예에 따르면, 본 발명은 데이터의 무결성을 검증하는 서버에 있어서, 적어도 하나의 데이터를 저장하는 메모리; 및 상기 저장된 데이터를 그룹화하고, 상기 그룹화된 데이터의 요소들을 체인화하고, 상기 체인화된 데이터를 블록체인(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
다양한 실시 예에 따르면, 동작 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
다양한 실시 예에 따르면, 서버(101)는 블록 체인에 데이터를 저장하기 위해서 블록체인 네트워크에 참여하고 있는 적어도 하나의 전자 장치(102)로 블록체인 트랜잭션을 전송할 수 있다. 상기 블록체인 트랜잭션에는 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자 등의 요소를 포함할 수 있다. 서버(101)는 블록 체인에 저장된 데이터의 사본을 서버(101)와 연결된 적어도 하나의 전자 장치(102)로 전송할 수 있다. 서버(101)는 블록 체인에 저장된 데이터의 무결성 여부를 판단하기 위한 증명서를 생성하여 적어도 하나의 전자 장치(102)를 전송할 수 있다. 상기 증명서는 전자 장치(102)가 데이터가 위조 되었는지 또는 변조 되었는지를 판단하기 위해 이용될 수 있다. 상기 증명서는 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 블록체인의 정보를 포함할 수 있다. 서버(101)는 블록 체인에 저장된 데이터의 적어도 하나의 요소에 대한 요청이 전자 장치(102)로부터 수신되면, 서버(101)는 상기 요청된 적어도 하나의 요소를 상기 요청을 전송한 전자 장치(102)로 전송할 수 있다.According to various embodiments, the
도 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
다양한 실시 예에 따르면, 동작 410에서, 서버(101)(예: 프로세서(210))는 블록 체인에 저장된 요소들과 그룹화된 데이터의 요소들을 비교할 수 있다. 서버(101)는 메모리(240)에 저장된 데이터가 위조 되었는지 또는 변조되었는지를 판단하기 위해, 블록 체인에 저장된 요소들과 그룹화된 데이터의 요소들을 비교할 수 있다. 서버(101)는 메모리(240)의 데이터 저장 영역(241)에 저장된 데이터와 블록 체인(242)에 저장된 데이터를 비교할 수 있다. 상기 서버(101)는 메모리(240)에 저장된 데이터가 위조 되었는지 또는 변조되었는지를 미리 결정된 시간 단위로 비교할 수 있다. 서버(101)는 메모리(240)에 저장된 데이터의 개수가 미리 결정된 개수를 초과하는 경우, 상기 저장된 데이터가 위조 되었는지 또는 변조되었는지를 비교할 수 있다. According to various embodiments, at
다양한 실시 예에 따르면, 동작 412에서, 서버(101)는 블록 체인에 저장된 요소들과 그룹화된 데이터를 비교하여 메모리(240)에 저장된 데이터가 무결성한지를 판단할 수 있다. 서버(101)(예: 프로세서(210))는 블록 체인에 저장된 요소들과 그룹화된 데이터의 구성 요소들을 비교하여 메모리(240)에 저장된 데이터의 무결성을 판단할 수 있다. 서버(101)는 블록 체인에 저장된 요소들과 그룹화된 데이터의 구성 요소들을 비교하여 메모리(240)에 저장된 데이터가 위조 되었는지 또는 변조되었는지를 판단할 수 있다. 서버(101)는 메모리(240)의 데이터 저장 영역(241)에 저장된 데이터와 블록 체인(242)에 저장된 데이터를 비교하여 상기 데이터 저장 영역(241)에 저장된 데이터가 무결성한지를 판단할 수 있다. 서버(101)는 메모리(240)에 저장된 데이터의 무결성 여부를 미리 결정된 시간 단위로 판단할 수 있다. 서버(101)는 메모리(240)에 저장된 데이터의 개수가 미리 결정된 개수를 초과하는 경우, 상기 저장된 데이터가 위조 되었는지 또는 변조되었는지를 판단할 수 있다.According to various embodiments, at
다양한 실시 예에 따르면, 동작 414에서, 서버(101)는 무결성 여부를 관리자에게 통지할 수 있다. 예를 들면, 메모리(240)에 저장된 데이터가 위조 되었거나 또는 변조되는 경우, 상기 데이터가 무결성하지 않음을 상기 서버(101)의 관리자에게 통지할 수 있다. 서버(101)는 상기 저장된 데이터가 무결성하지 않는 경우, 상기 서버(101)를 관리하는 관리자가 인지할 수 있도록 서버(101)의 입출력 인터페이스(230)를 통해 무결성 여부를 출력할 수 있다.According to various embodiments, at
도 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
다양한 실시 예에 따르면, 동작 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
다양한 실시 예에 따르면, 동작 422에서, 전자 장치(102)(예: 프로세서(250)는 무결성 체크 요청이 입력되는지 판단할 수 있다. 전자 장치(101)는 무결성 체크를 요청하는 입력을 사용자로부터 입력받을 수 있다. 전자 장치(101)는 디스플레이(290)(예: 터치 스크린)를 통해 무결성 체크를 요청하는 입력을 사용자로부터 수신할 수 있다. 사용자는 상기 증명서에 기반하여 자신의 중요 데이터가 위조 되었는지 또는 변조 되었는지를 블록 체인에 저장된 데이터를 기반으로 검증할 수 있다. According to various embodiments, at
다양한 실시 예에 따르면, 동작 424에서, 전자 장치(102)(예: 프로세서(250)는 메모리(280)에 저장된 증명서에 기반하여 블록 체인에 저장된 요소들을 획득할 수 있다. 상기 전자 장치(102)는 상기 메모리(280)에 저장된 증명서를 이용하여 상기 메모리(280)에 저장된 블록체인(281)에 저장된 요소들에 대응하는 그룹화된 데이터를 요청할 수 있다. 전자 장치(102)는 무결성 체크 요청이 입력되면, 상기 메모리(280)에 저장된 증명서를 이용하여 상기 메모리(280)에 저장된 블록체인(281)에 저장된 요소들에 대응하는 그룹화된 데이터를 블록체인 네트워크에 요청하고 수신할 수 있다. 전자 장치(102)는 상기 메모리(280)에 저장된 증명서를 이용하여 상기 메모리(280)에 저장된 블록체인(281)에 저장된 요소들을 블록체인 네트워크에 요청하고, 블록체인 네트워크로부터 상기 요청에 대응한 요소들을 획득할 수 있다. 예를 들면, 전자장치가 블록체인을 가지고 있지 않다면, 특정 서버(예: 블록체인에 참여하고 있거나 또는 자신의 요청을 대신 수행할 수 있는 특정 서버)에게 요청할 수 있겠지만, 전자장치가 블록체인을 가지고 있는 경우(예: 전자장치가 블록체인 네트워크에 참여하고 있는 경우)에는 직접 블록체인 네트워크에 요청할 수 있다.According to various embodiments, at
다양한 실시 예에 따르면, 동작 426에서, 전자 장치(102)(예: 프로세서(250)는 획득된 요소들과 그룹화된 데이터의 요소들을 비교할 수 있다. 전자 장치(102)는 메모리(260)에 저장된 데이터가 위조 되었는지 또는 변조되었는지를 판단하기 위해, 블록 체인에 저장된 요소들을 블록체인 네트워크로부터 획득하고, 상기 획득된 요소들과 상기 증명서에 저장된 그룹화된 데이터의 요소들을 비교할 수 있다. 전자 장치(102)는 메모리(280)에 저장된 데이터의 요소들과 상기 블록체인 네트워크로부터 획득된 요소들을 비교할 수 있다. 상기 전자 장치(102)는 메모리(280)에 저장된 데이터가 위조 되었는지 또는 변조되었는지를 미리 결정된 시간 단위로 비교할 수 있다. 상기 전자 장치(102)는 메모리(280)에 저장된 데이터의 개수가 미리 결정된 개수를 초과하는 경우, 상기 저장된 데이터가 위조 되었는지 또는 변조되었는지를 비교할 수 있다.According to various embodiments, at
다양한 실시 예에 따르면, 동작 428에서, 전자 장치(102)(예: 프로세서(250)는 무결성 여부를 판단할 수 있다. 전자 장치(102)는 블록 체인에 저장된 요소들과 그룹화된 데이터의 요소들을 비교하여 메모리(280)에 저장된 데이터가 무결성한지를 판단할 수 있다. 전자 장치(102)는 블록 체인에 저장된 요소들과 그룹화된 데이터의 요소들을 비교하여 메모리(280)에 저장된 데이터의 무결성을 판단할 수 있다. 전자 장치(102)는 블록 체인에 저장된 요소들과 그룹화된 데이터의 요소들을 비교하여 메모리(280)에 저장된 데이터가 위조 되었는지 또는 변조되었는지를 판단할 수 있다. 전자 장치(102)는 메모리(280)에 저장된 데이터와 블록 체인(281)에 저장된 데이터를 비교하여 상기 메모리(280)에 저장된 데이터가 무결성한지를 판단할 수 있다. 전자 장치(102)는 메모리(280)에 저장된 데이터의 무결성 여부를 미리 결정된 시간 단위로 판단할 수 있다.According to various embodiments, at
다양한 실시 예에 따르면, 동작 430에서, 전자 장치(102)(예: 프로세서(250)는 관리자에게 통지할 수 있다. 예를 들면, 전자 장치(102)는 메모리(240)에 저장된 데이터가 위조 되었거나 또는 변조되는 경우, 상기 데이터가 무결성하지 않음을 상기 서버(101)의 관리자에게 통지할 수 있다. 또는 전자 장치(102)는 메모리(240)에 저장된 데이터가 위조 되었거나 또는 변조되는 경우, 상기 데이터가 무결성하지 않음을 상기 전자 장치(102)의 사용자에게 통지할 수 있다. 전자 장치(102)는 상기 저장된 데이터가 무결성하지 않는 경우, 상기 서버(101)를 관리하는 관리자 또는 상기 전자 장치(102)의 사용자가 인지할 수 있도록 서버(101)로 무결성 여부를 전송하거나, 상기 전자 장치(102)의 입출력 인터페이스(270)를 통해 무결성 여부를 출력할 수 있다.According to various embodiments, at
다양한 실시 예에 따르면, 본 발명은 서버에서 데이터의 무결성을 검증하는 방법에 있어서, 메모리에 저장된 적어도 하나의 데이터를 그룹화하는 동작; 상기 그룹화된 데이터를 체인화하는 동작; 및 상기 체인화된 데이터를 블록체인에 저장하는 동작을 포함할 수 있다.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
다양한 실시 예에 따르면, 서버(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
다양한 실시 예에 따르면, 서버(101)는 블록 체인(530)에 저장된 그룹화된 데이터의 무결성 여부를 판단하는 증명서를 생성할 수 있다. 상기 서버(101)는 상기 저장된 블록체인의 무결성 여부를 판단하기 위한 증명서(certificate)를 생성하여 적어도 하나의 전자 장치(102)로 전송할 수 있다. 상기 증명서는 전자 장치(102)가 데이터가 위조 되었는지 또는 변조 되었는지를 판단하기 위해 이용될 수 있다. 상기 증명서는 데이터 저장 영역(241)에 저장된 데이터의 정보, 상기 데이터 저장 영역(241)에 저장된 데이터를 그룹화한 데이터 그룹 정보 및 상기 그룹화된 데이터가 저장된 블록 체인의 정보를 포함할 수 있다. 상기 서버(101)의 데이터 저장 영역(241)에 저장된 데이터의 정보는 데이터 식별자 및 데이터의 내용에 관한 정보를 포함할 수 있다. 상기 그룹화된 데이터의 그룹 정보는 그룹화된 데이터의 식별자 및 머클 해쉬 식별자를 포함할 수 있다. 상기 블록 체인의 정보는 블록 체인의 식별자 및 타임 스탬프를 포함할 수 있다. 상기 블록 체인의 정보는 전자 장치(102)에 저장된 데이터의 블록 체인에 대한 정보를 포함할 수 있다.According to various embodiments, the
본 발명에 사용된 용어 "모듈"은, 예를 들어, 하드웨어, 소프트웨어 또는 펌웨어(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 요소를 제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.
상기 프로세서는,
미리 결정된 시간, 미리 결정된 데이터 개수, 데이터 종류 및 데이터의 중요도 중 적어도 하나에 기반하여 상기 저장된 데이터를 그룹화하는 서버.
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.
상기 프로세서는,
상기 저장된 데이터에 기반하여 머클 해쉬(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.
상기 적어도 하나의 데이터는, 개인 정보, 헬스 정보 및 공증 데이터 중 적어도 하나를 포함하는 서버.
The method according to claim 1,
Wherein the at least one data comprises at least one of personal information, health information, and notarized data.
상기 프로세서는,
미리 결정된 시간 및 상기 저장된 데이터의 개수 중 적어도 하나에 기반하여 상기 블록체인에 저장된 데이터의 적어도 하나의 요소와 상기 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교하여 상기 저장된 데이터의 무결성을 검증하는 서버.
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, .
입출력 인터페이스를 더 포함하며,
상기 프로세서는,
상기 저장된 데이터가 무결성하지 않는 경우, 상기 입출력 인터페이스를 통해 상기 무결성 여부를 출력하는 서버.
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.
상기 프로세서는,
상기 블록체인에 저장된 데이터의 무결성 여부를 판단하기 위한 증명서를 생성하여 적어도 하나의 전자 장치로 전송하며,
상기 증명서는, 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 블록체인의 정보를 포함하는 서버.
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.
상기 프로세서는,
상기 블록체인에 저장된 데이터에 대한 적어도 하나의 요소에 대한 요청이 상기 적어도 하나의 전자 장치로부터 수신되면, 상기 요청에 해당되는 요소의 종류에 따라 데이터의 포맷을 변환하여 상기 요청된 적어도 하나의 요소를 상기 전자 장치로 전송하는 서버.
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.
상기 그룹화된 데이터를 체인화하는 동작은,
상기 그룹화된 데이터 중에서 제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.
상기 적어도 하나의 데이터를 그룹화하는 동작은,
미리 결정된 시간, 미리 결정된 데이터 개수, 데이터 종류 및 데이터의 중요도 중 적어도 하나에 기반하여 그룹화하는 것을 특징으로 하는 방법.
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.
상기 적어도 하나의 데이터를 그룹화하는 동작은,
상기 저장된 데이터에 기반하여 머클 해쉬(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.
상기 그룹화된 데이터는, 머클 해쉬 식별자, 그룹 식별자 및 이전 그룹의 식별자를 포함하는 방법.
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.
미리 결정된 시간 및 상기 저장된 데이터의 개수 중 적어도 하나에 기반하여 상기 블록체인에 저장된 데이터의 적어도 하나의 요소와 상기 그룹화된 데이터에 포함된 적어도 하나의 요소를 비교하여 상기 저장된 데이터의 무결성을 검증하는 동작을 더 포함하는 방법.
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 >
상기 저장된 데이터가 무결성하지 않는 경우, 상기 무결성 여부를 출력하는 동작을 더 포함하는 방법.
16. The method of claim 15,
And outputting the integrity if the stored data is not integrity.
상기 블록체인에 저장된 데이터의 무결성 여부를 판단하기 위한 증명서를 생성하여 적어도 하나의 전자 장치로 전송하는 동작을 더 포함하며,
상기 증명서는, 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 블록체인의 정보를 포함하는 방법.
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.
상기 프로세서는,
상기 블록체인에 저장된 데이터의 무결성 여부를 판단하기 위한 증명서를 상기 서버로부터 수신하며,
상기 증명서는, 상기 저장된 적어도 하나의 데이터의 정보, 상기 그룹화된 데이터의 정보 및 상기 블록체인의 정보를 포함하는 전자 장치.
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.
상기 프로세서는,
상기 저장된 데이터가 무결성하지 않는 경우, 상기 무결성 여부를 출력하는 전자 장치.19. The method of claim 18,
The processor comprising:
And if the stored data is not integrity, outputs the integrity.
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)
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 (7)
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 |
US11557195B2 (en) | 2018-12-14 | 2023-01-17 | 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 |
CN110147410B (en) * | 2019-04-18 | 2020-08-04 | 阿里巴巴集团控股有限公司 | Data verification method, system, device and equipment in block chain type account book |
US20200177390A1 (en) * | 2019-04-18 | 2020-06-04 | Alibaba Group Holding Limited | Providing data verification in a blockchain ledger |
CN110245518B (en) * | 2019-05-31 | 2024-05-17 | 创新先进技术有限公司 | Data storage method, device and equipment |
CN118331967A (en) * | 2024-06-13 | 2024-07-12 | 长江三峡集团实业发展(北京)有限公司 | Merck tree generation method, device, equipment and storage medium |
Family Cites Families (5)
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 |
CA2980002A1 (en) * | 2015-03-20 | 2016-09-29 | 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 |
-
2017
- 2017-02-01 KR KR1020170014325A patent/KR20180089682A/en unknown
-
2018
- 2018-02-01 WO PCT/KR2018/001388 patent/WO2018143694A1/en active Application Filing
Cited By (12)
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 | |
KR102441758B1 (en) | Electronic device, certification agency server and payment system | |
KR20160026293A (en) | Method for managing beacon, terminal device, server and storage medium | |
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 | |
KR102509594B1 (en) | Method for detecting the tampering of application code and electronic device supporting the same | |
KR20160075228A (en) | Electronic apparatus, cloud server, game service providing system and game service providing method thereof | |
KR20170098117A (en) | Electronic device for authenticating based on biometric data and operating method thereof | |
KR20170004456A (en) | A method for managing data and apparatuses therefor | |
KR20170109433A (en) | Device for performing security transaction and method thereof | |
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 | |
KR20170039642A (en) | Electronic device, certification agency server and payment system | |
KR20160057101A (en) | Method for securing image data and electronic device implementing the same | |
KR20160033510A (en) | Electronic Device Using Token for Setting Permission |