JP2018197832A - ブロックチェーン更新システム、サーバ装置、クライアント装置、ブロックチェーン更新方法、およびプログラム - Google Patents

ブロックチェーン更新システム、サーバ装置、クライアント装置、ブロックチェーン更新方法、およびプログラム Download PDF

Info

Publication number
JP2018197832A
JP2018197832A JP2017103300A JP2017103300A JP2018197832A JP 2018197832 A JP2018197832 A JP 2018197832A JP 2017103300 A JP2017103300 A JP 2017103300A JP 2017103300 A JP2017103300 A JP 2017103300A JP 2018197832 A JP2018197832 A JP 2018197832A
Authority
JP
Japan
Prior art keywords
calculation result
transaction
server device
block chain
search space
Prior art date
Legal status (The legal status 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 status listed.)
Granted
Application number
JP2017103300A
Other languages
English (en)
Other versions
JP6754319B2 (ja
Inventor
浩昭 大塚
Hiroaki Otsuka
浩昭 大塚
優太郎 清村
Yutaro Kiyomura
優太郎 清村
恆和 齋藤
Tsunekazu Saito
恆和 齋藤
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Nippon Telegraph and Telephone Corp
Original Assignee
Nippon Telegraph and Telephone Corp
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 Nippon Telegraph and Telephone Corp filed Critical Nippon Telegraph and Telephone Corp
Priority to JP2017103300A priority Critical patent/JP6754319B2/ja
Publication of JP2018197832A publication Critical patent/JP2018197832A/ja
Application granted granted Critical
Publication of JP6754319B2 publication Critical patent/JP6754319B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Abstract

【課題】安全かつ効率的にブロックチェーンを更新する。【解決手段】サーバ装置1は探索空間を並列計算可能な形式に分割し、分割後探索空間を依頼計算可能な形式に変換する。クライアント装置2はトランザクションをサーバ装置1へ要求する。サーバ装置1は変換後探索空間のいずれか一つをクライアント装置2へ送信する。クライアント装置2はサーバ装置1から受信した変換後探索空間を用いて一方向性関数を計算し、依頼計算結果とトランザクションの確認に必要な情報とをサーバ装置1へ送信する。サーバ装置1は依頼計算結果とトランザクションの確認に必要な情報とをクライアント装置2から受信し、依頼計算結果を逆変換した一方向性関数の計算結果とトランザクションの確認に必要な情報とが正しいか否かを検証し、所定の条件を満たす計算結果を用いてブロックチェーンを更新する。【選択図】図4

Description

この発明は、改ざん防止を目的とするブロックチェーン技術に関し、特に、ブロックチェーンの更新にクライアントサーバモデルの依頼計算を用いる技術に関する。
インターネットのようなオンラインネットワークにおいて他者に安全に計算を依頼する技術として、依頼計算(Server-aided Computation)が挙げられる(例えば、非特許文献1参照)。非特許文献1には、依頼計算の技術として、楕円曲線上のペアリング代理計算(Outsourcing Pairing Computation)が記載されている。
改ざん防止を目的とするブロックチェーンを用いた技術として、ビットコイン(例えば、非特許文献2参照)やイーサリアム(例えば、非特許文献3参照)が挙げられる。ビットコインやイーサリアムでは、一方向性関数の実装としてハッシュ関数を用いている。ビットコインではハッシュ関数としてSHA-256を用い、イーサリアムではハッシュ関数としてKeccak-256やKeccak-512(いわゆるSHA-3)などを用いている。
Aurora Guillevic and Damien Vergnaud、「Algorithms for Outsourcing Pairing Computation」、[online]、[平成29年5月15日検索]、インターネット<URL: https://www.cardis.org/proceedings/cardis_2014/pdf/CARDIS2014_12.pdf> Satoshi Nakamoto、「Bitcoin: A Peer-to-Peer Electronic Cash System」、[online]、[平成29年5月15日検索]、インターネット<URL: https://bitcoin.org/bitcoin.pdf> DR. GAVIN WOOD、「ETHEREUM: A SECURE DECENTRALISED GENERALISED TRANSACTION LEDGER」、[online]、[平成29年5月15日検索]、インターネット<URL: http://gavwood.com/Paper.pdf>
ビットコインやイーサリアムでは、マイニングの成功報酬としてマイナー(採掘者)に仮想通貨を提供している。つまり、ブロックチェーンの更新を進めるために、マイナーに積極的なインセンティブを与える施策が必要である。この成功報酬がマイナー間での自由なマイニング競争を生み出しているが、結果としてシステム全体で見た場合には計算の重複部分が増えてしまうという課題も生じている。
計算の重複部分をなくすために、中央集権的なサーバ装置を作成し、そのサーバ装置がマイニングを行うことが考えられる。しかしながら、この場合、サーバ装置にマイニングの負荷が集中する点が課題となる。また、サーバ装置に負荷が集中しないように、マイニング探索空間を分割してクライアント装置に再配布する仕組みが考えられる。しかしながら、この場合、クライアント装置がマイニングの結果をサーバ装置よりも先に知ってしまう点が課題になる。
この発明の目的は、上記のような点に鑑みて、安全かつ効率的にブロックチェーンを更新することができるブロックチェーン更新技術を実現することである。
上記の課題を解決するために、この発明のブロックチェーン更新システムは、少なくとも1台のサーバ装置と複数台のクライアント装置とを含む。サーバ装置は、ブロックチェーンのプルーフオブワークの探索空間を並列計算可能な形式に分割して複数の分割後探索空間を生成する探索空間分割部と、分割後探索空間それぞれを依頼計算可能な形式に変換して複数の変換後探索空間を生成する探索空間変換部と、変換後探索空間のいずれか一つを、トランザクションを要求したクライアント装置へ送信する依頼計算要求部と、変換後探索空間に対するブロックチェーンの一方向関数の依頼計算結果とトランザクションの確認に必要な情報とを、トランザクションを要求したクライアント装置から受信する計算結果受信部と、依頼計算結果を逆変換した一方向性関数の計算結果とトランザクションの確認に必要な情報とが正しいか否かを検証する計算結果検証部と、計算結果に所定の条件を満たすものがあれば、その計算結果を用いてブロックチェーンを更新するブロックチェーン更新部と、を含む。クライアント装置は、トランザクションをサーバ装置へ要求するトランザクション要求送信部と、サーバ装置から受信した変換後探索空間を用いて一方向性関数を計算して依頼計算結果を求める依頼計算実行部と、依頼計算結果とトランザクションの確認に必要な情報とをサーバ装置へ送信する計算結果送信部と、を含む。
この発明では、サーバ装置がクライアント装置に依頼計算を要求することで、クライアント装置から計算リソースを得られるため、サーバ装置のみがマイニングを行う場合と比較してサーバ装置の負荷が低減する。また、サーバ装置は依頼計算が正しく行われたことを検証できない限りトランザクションを提供しないため、クライアント装置からのトランザクションに関するカジュアルアタックや総当たり攻撃の試みを減らすことができる。また、サーバ装置が依頼計算を用いて元の情報が漏れない形式に変換するため、クライアント装置にはマイニングに関する情報が漏れない。さらに、サーバ装置がマイニング空間を並列に分割してクライアント装置に割り振ることで、自由競争のマイニングの場合と比較して計算の重複部分を減らすことができるため、システム全体の計算リソースをより効率的に利用できる。したがって、この発明によれば、安全かつ効率的にブロックチェーンを更新することができる。
図1は、ブロックチェーン更新システムの機能構成を例示する図である。 図2は、サーバ装置の機能構成を例示する図である。 図3は、クライアント装置の機能構成を例示する図である。 図4は、ブロックチェーン更新方法の処理手続きを例示する図である。 図5は、ブロックチェーンのデータ構造を説明するための図である。 図6は、プルーフオブワーク(PoW: Proof of Work)探索空間の分割と変換について説明するための図である。
以下、この発明の実施の形態について詳細に説明する。なお、図面中において同じ機能を有する構成部には同じ番号を付し、重複説明を省略する。
この発明の実施形態は、インターネットのようなオンラインネットワークにおいて、改ざん防止を目的としたブロックチェーンを、依頼計算を用いて更新するブロックチェーン更新システムおよび方法である。実施形態のブロックチェーン更新システムおよび方法では、ブロックチェーンにおける一方向性関数の実装方式として、例えば、楕円曲線上のペアリング演算を用いる。また、依頼計算の契機となるトランザクション要求として、例えば、サーバ装置がクライアント装置の正当性を検証するクライアント認証を用いる。また、依頼計算として、例えば、ペアリング代理計算を用いる。
図1を参照して、実施形態のブロックチェーン更新システムの構成例を説明する。ブロックチェーン更新システムは、少なくとも1台のサーバ装置1と複数台のクライアント装置21, …, 2N(N≧2)とを含む。この実施形態では、サーバ装置1とクライアント装置21, …, 2Nとはそれぞれ通信網3へ接続される。通信網3は、接続される各装置が相互に通信可能なように構成された回線交換方式もしくはパケット交換方式の通信網であり、例えばインターネットやLAN(Local Area Network)、WAN(Wide Area Network)などを用いることができる。
ブロックチェーン更新システムに含まれるサーバ装置1は、例えば、図2に示すように、ブロックチェーン記憶部10、探索空間分割部11、探索空間変換部12、トランザクション要求受信部13、依頼計算要求部14、計算結果受信部15、計算結果検証部16、およびブロックチェーン更新部17を含む。ブロックチェーン更新システムに含まれるクライアント装置2i(i=1, …, N)は、例えば、図3に示すように、トランザクション要求送信部21、依頼計算実行部22、および計算結果送信部23を含む。このサーバ装置1がクライアント装置2iと協調しながら図4に示す各ステップの処理を行うことにより実施形態のブロックチェーン更新方法が実現される。
サーバ装置1およびクライアント装置2iは、例えば、中央演算処理装置(CPU: Central Processing Unit)、主記憶装置(RAM: Random Access Memory)などを有する公知又は専用のコンピュータに特別なプログラムが読み込まれて構成された特別な装置である。サーバ装置1およびクライアント装置2iは、例えば、中央演算処理装置の制御のもとで各処理を実行する。サーバ装置1およびクライアント装置2iに入力されたデータや各処理で得られたデータは、例えば、主記憶装置に格納され、主記憶装置に格納されたデータは必要に応じて中央演算処理装置へ読み出されて他の処理に利用される。サーバ装置1およびクライアント装置2iの各処理部は、少なくとも一部が集積回路等のハードウェアによって構成されていてもよい。
以下、図4を参照して、実施形態のブロックチェーン更新システムが実行するブロックチェーン更新方法の処理手続きを説明する。
サーバ装置1のブロックチェーン記憶部10には、更新対象となるブロックチェーンが記憶されている。このブロックチェーンは、図5に示すように、1つ前のブロックの一方向性関数の出力結果と今回のブロック(block)で追加された値(item)とから求められた楕円曲線G1上の点Pと、ナンス(nonce)の代替として用いられる楕円曲線G2上の点Qとを用いて一方向性関数を計算する。点Pはブロックチェーンの更新のたびに一意に固定される。マイナーは点Qの値を任意に変更しながら、一方向性関数であるペアリング演算e(P, Q)の計算結果が所定の条件を満たす点Qを探索する。所定の条件は、例えば、先頭rビットが0(rは所定の整数)などである。なお、以下の説明では、G1, G2, GTを位数がnビットの群とし、e:G1×G2→Gtをペアリング演算とする。
ステップS11において、サーバ装置1の探索空間分割部11は、ブロックチェーン記憶部10に記憶されているブロックチェーンにおけるプルーフオブワーク(PoW: Proof of Work)の探索空間Qを、並列計算可能な形式となるようにm個に分割する(図6参照)。以降の説明では、分割された探索空間(分割後探索空間とも呼ぶ)をQ1, Q2, …, Qmとする。すなわち、Q:={Q1, Q2, …, Qm}である。mは所定の整数であり、例えば、クライアント装置2iの台数N、クライアント装置2iの計算リソース等を鑑みて適宜設定すればよい。探索空間Qは楕円曲線G2上の点の集合であるため、探索空間の分割は、各分割後探索空間Q1, Q2, …, Qmに含まれる点の数に基づいて行ってもよいし、楕円曲線G2上の範囲に基づいて行ってもよい。探索空間分割部11は、分割後探索空間Q1, Q2, …, Qmを探索空間変換部12へ入力する。
ステップS12において、サーバ装置1の探索空間変換部12は、探索空間分割部11から分割後探索空間Q1, Q2, …, Qmを受け取り、分割後探索空間Q1, Q2, …, Qmそれぞれを依頼計算可能な形式となるように変換する(図6参照)。また、ブロックチェーンの最後のブロックに対応する一方向性関数の出力Pを依頼計算可能な形式となるように変換する。以降の説明では、変換された分割後探索空間(変換後探索空間とも呼ぶ)をQ'1, Q'2, …, Q'mとし、変換された一方向性関数の出力(変換後一方向性関数出力とも呼ぶ)をP'とする。具体的には、kを1以上m以下の各整数とし、各kについて、P':=aP, Q'k:=bQkを計算する。ただし、a, bはあらかじめ定めた値a, b←{0, 1}nである。さらに、探索空間変換部12は、a, bを用いて、c:=(ab)-1を計算し、計算結果cを記憶しておく。a, bはセキュリティパラメータ長程度の長さで構わないため、通常の楕円スカラー倍算よりも平均的に高速に計算することができる。探索空間変換部12は、変換後探索空間Q'1, Q'2, …, Q'mおよび変換後一方向性関数出力P'を依頼計算要求部14へ入力する。
ステップS21において、クライアント装置2iのトランザクション要求送信部21は、所定のトランザクション要求をサーバ装置1へ送信する。このトランザクションはブロックチェーンの更新処理の契機として利用するものであり、ブロックチェーンとは無関係なものでよいが、定期的に発生するものであることが望ましい。ここでは、クライアント装置2iの正当性を検証するクライアント認証の要求をサーバ装置1へ送信するものとする。
ステップS13において、サーバ装置1のトランザクション要求受信部13は、クライアント装置2iが送信したトランザクション要求を受信する。トランザクション要求受信部13は、トランザクション要求を送信してきたクライアント装置2iを示す情報を依頼計算要求部14へ入力する。
ステップS14において、サーバ装置1の依頼計算要求部14は、探索空間変換部12から変換後探索空間Q'1, Q'2, …, Q'mおよび変換後一方向性関数出力P'を受け取り、変換後探索空間Q'1, Q'2, …, Q'mのいずれか一つである変換後探索空間Q'j(1≦j≦m)と変換後一方向性関数出力P'とを、トランザクション要求を送信してきたクライアント装置2iへ送信する。通常、変換後探索空間Q'jには楕円曲線G2上の点を変換した点が複数含まれるが、そのすべての点をクライアント装置2iへ送信する。
ステップS22において、クライアント装置2iの依頼計算実行部22は、サーバ装置1から変換後探索空間Q'jと変換後一方向性関数出力P'とを受信し、変換後探索空間Q'jと変換後一方向性関数出力P'とを用いてブロックチェーンの一方向性関数であるペアリング演算を計算して、依頼計算結果e(P', Q'j)を求める。変換後探索空間Q'jに楕円曲線G2上の点を変換した点が複数含まれる場合、そのすべての点についてペアリング演算を計算する。すなわち、依頼計算結果e(P', Q'j)は変換後探索空間Q'jに含まれる点の数だけ存在することになる。依頼計算要求部14は、依頼計算結果e(P', Q'j)を計算結果送信部23へ入力する。
ステップS23において、クライアント装置2iの計算結果送信部23は、依頼計算要求部14から依頼計算結果e(P', Q'j)を受け取り、依頼計算結果e(P', Q'j)とトランザクションの確認に必要な情報とをサーバ装置1へ送信する。トランザクションの確認に必要な情報は、トランザクションの種類に基づいて決定される。この実施形態ではトランザクションとしてクライアント認証を用いるため、トランザクションの確認に必要な情報は、例えば、ワンタイムパスワードの値などのクライアント装置2iに固有の認証情報とする。
ステップS15において、サーバ装置1の計算結果受信部15は、クライアント装置2iから依頼計算結果e(P', Q'j)とトランザクションの確認に必要な情報とを受信する。計算結果受信部15は、依頼計算結果e(P', Q'j)とトランザクションの確認に必要な情報とを計算結果検証部16へ入力する。
ステップS16において、サーバ装置1の計算結果検証部16は、計算結果受信部15から依頼計算結果e(P', Q'j)とトランザクションの確認に必要な情報とを受け取り、依頼計算結果e(P', Q'j)を逆変換した一方向性関数の計算結果e(P, Qj)とトランザクションの確認に必要な情報とが正しいか否かを検証する。依頼計算結果e(P', Q'j)が複数存在する場合は、そのすべての依頼計算結果e(P', Q'j)について正しいか否かを検証する。依頼計算結果e(P', Q'j)の逆変換は、ペアリング演算の双線形性を利用して、以下のように計算する。なお、「^」は上付き添え字中の上付き添え字を表す。すなわち、「(ab)^-1」は「ab-1」である。
e(P', Q'j)c = e(aP, bQj)(ab)^-1= e(P, Qj)(ab)(ab)^-1 = e(P, Qj)
トランザクションの確認に必要な情報が正しいか否かの判断は、認証情報の種類に応じて一般的な認証手段を用いて行えばよい。ペアリング演算の計算結果e(P, Qj)が正しいか否かの判断は、下記参考文献1の「5.1 双線形関数に対する自己訂正器」に記載された手順により実現できる。
〔参考文献1〕山本剛、小林鉄太郎、「準同型写像に対する自己訂正について」、The 2010 Symposium on Cryptography and Information Security (SCIS2010)、2D2-3
計算結果検証部16は、依頼計算結果e(P', Q'j)を逆変換した計算結果e(P, Qj)とトランザクションの確認に必要な情報との検証がいずれも正しい場合は、クライアント装置2iへアクセスを許可する。いずれかが正しくない場合は、クライアント装置2iのアクセスを拒否する。アクセスを許可する場合、計算結果検証部16は、計算結果e(P, Qj)をブロックチェーン更新部17へ入力する。
ステップS17において、サーバ装置1のブロックチェーン更新部17は、計算結果検証部16から計算結果e(P, Qj)を受け取り、その計算結果e(P, Qj)に所定の条件を満たすものが存在するか否かを検証する。所定の条件を満たすものが存在する場合、その計算結果e(P, Qj)を用いてブロックチェーンを更新する。具体的には、e(P, Qj)≦2n-r-1を満たす点Qjが存在すれば、その点Qjを用いてブロックチェーンを更新する。ブロックチェーンを更新することで次のブロックへ引き渡す一方向性関数の出力結果が定まる。
上記の実施形態では、トランザクションとしてワンタイムパスワードによるクライアント認証を挙げたが、下記参考文献2に記載されたM-Pinを用いてもよい。M-Pinでは、クライアント装置2iはサーバ装置1から得た値yを元に楕円曲線上のスカラー倍算を行い、その計算結果Vをサーバ装置1へ返却する。M-Pinは、クライアント装置2iがすでに楕円曲線上における計算処理能力を持っており、かつ、それを認証時に利用しているため、上記の実施形態と親和性が高いクライアント認証方式である。
〔参考文献2〕Michael Scott、「M-Pin Full Technology (Version 3.1)」、[online]、[平成29年5月15日検索]、インターネット<URL: https://www.miracl.com/hubfs/mpinfull_3.1.pdf>
上記のように構成することにより、実施形態のブロックチェーン更新システムによれば、以下の効果が得られる。まず、サーバ装置1がクライアント装置2iから計算リソースを得られるため、サーバ装置1のみがマイニングを行う場合と比較してサーバ装置1の負荷が低減する。また、サーバ装置1は依頼計算が正しく行われたことを検証できない限りトランザクションを提供しないため、クライアント装置2i側からのトランザクションに関するカジュアルアタックや総当たり攻撃の試みを減らすことができる。また、サーバ装置1が依頼計算を用いて元の情報が漏れない形式に変換するため、クライアント装置2iにはマイニングに関する情報が漏れない。さらに、サーバ装置1がマイニング空間を並列に分割してクライアント装置2iに割り振ることで、自由競争のマイニングの場合と比較して計算の重複部分を減らすことができるため、システム全体の計算リソースをより効率的に利用できる。したがって、この実施形態によれば、安全かつ効率的にブロックチェーンを更新することができる。
以上、この発明の実施の形態について説明したが、具体的な構成は、これらの実施の形態に限られるものではなく、この発明の趣旨を逸脱しない範囲で適宜設計の変更等があっても、この発明に含まれることはいうまでもない。実施の形態において説明した各種の処理は、記載の順に従って時系列に実行されるのみならず、処理を実行する装置の処理能力あるいは必要に応じて並列的にあるいは個別に実行されてもよい。
[プログラム、記録媒体]
上記実施形態で説明した各装置における各種の処理機能をコンピュータによって実現する場合、各装置が有すべき機能の処理内容はプログラムによって記述される。そして、このプログラムをコンピュータで実行することにより、上記各装置における各種の処理機能がコンピュータ上で実現される。
この処理内容を記述したプログラムは、コンピュータで読み取り可能な記録媒体に記録しておくことができる。コンピュータで読み取り可能な記録媒体としては、例えば、磁気記録装置、光ディスク、光磁気記録媒体、半導体メモリ等どのようなものでもよい。
また、このプログラムの流通は、例えば、そのプログラムを記録したDVD、CD-ROM等の可搬型記録媒体を販売、譲渡、貸与等することによって行う。さらに、このプログラムをサーバコンピュータの記憶装置に格納しておき、ネットワークを介して、サーバコンピュータから他のコンピュータにそのプログラムを転送することにより、このプログラムを流通させる構成としてもよい。
このようなプログラムを実行するコンピュータは、例えば、まず、可搬型記録媒体に記録されたプログラムもしくはサーバコンピュータから転送されたプログラムを、一旦、自己の記憶装置に格納する。そして、処理の実行時、このコンピュータは、自己の記憶装置に格納されたプログラムを読み取り、読み取ったプログラムに従った処理を実行する。また、このプログラムの別の実行形態として、コンピュータが可搬型記録媒体から直接プログラムを読み取り、そのプログラムに従った処理を実行することとしてもよく、さらに、このコンピュータにサーバコンピュータからプログラムが転送されるたびに、逐次、受け取ったプログラムに従った処理を実行することとしてもよい。また、サーバコンピュータから、このコンピュータへのプログラムの転送は行わず、その実行指示と結果取得のみによって処理機能を実現する、いわゆるASP(Application Service Provider)型のサービスによって、上述の処理を実行する構成としてもよい。なお、本形態におけるプログラムには、電子計算機による処理の用に供する情報であってプログラムに準ずるもの(コンピュータに対する直接の指令ではないがコンピュータの処理を規定する性質を有するデータ等)を含むものとする。
また、この形態では、コンピュータ上で所定のプログラムを実行させることにより、本装置を構成することとしたが、これらの処理内容の少なくとも一部をハードウェア的に実現することとしてもよい。
1 サーバ装置
2 クライアント装置
3 通信網
10 ブロックチェーン記憶部
11 探索空間分割部
12 探索空間変換部
13 トランザクション要求受信部
14 依頼計算要求部
15 計算結果受信部
16 計算結果検証部
17 ブロックチェーン更新部
21 トランザクション要求送信部
22 依頼計算実行部
23 計算結果送信部

Claims (8)

  1. 少なくとも1台のサーバ装置と複数台のクライアント装置とを含むブロックチェーン更新システムであって、
    上記サーバ装置は、
    ブロックチェーンのプルーフオブワークの探索空間を並列計算可能な形式に分割して複数の分割後探索空間を生成する探索空間分割部と、
    上記分割後探索空間それぞれを依頼計算可能な形式に変換して複数の変換後探索空間を生成する探索空間変換部と、
    上記変換後探索空間のいずれか一つを、トランザクションを要求した上記クライアント装置へ送信する依頼計算要求部と、
    上記変換後探索空間に対するブロックチェーンの一方向関数の依頼計算結果と上記トランザクションの確認に必要な情報とを、上記トランザクションを要求した上記クライアント装置から受信する計算結果受信部と、
    上記依頼計算結果を逆変換した上記一方向性関数の計算結果と上記トランザクションの確認に必要な情報とが正しいか否かを検証する計算結果検証部と、
    上記計算結果に所定の条件を満たすものがあれば、その計算結果を用いて上記ブロックチェーンを更新するブロックチェーン更新部と、
    を含み、
    上記クライアント装置は、
    上記トランザクションを上記サーバ装置へ要求するトランザクション要求送信部と、
    上記サーバ装置から受信した上記変換後探索空間を用いて上記一方向性関数を計算して上記依頼計算結果を求める依頼計算実行部と、
    上記依頼計算結果と上記トランザクションの確認に必要な情報とを上記サーバ装置へ送信する計算結果送信部と、
    を含むブロックチェーン更新システム。
  2. 請求項1に記載のブロックチェーン更新システムであって、
    上記トランザクションは、上記サーバ装置が上記クライアント装置の正当性を検証するクライアント認証である、
    ブロックチェーン更新システム。
  3. 請求項1または2に記載のブロックチェーン更新システムであって、
    上記一方向性関数は、楕円曲線上のペアリング演算である、
    ブロックチェーン更新システム。
  4. 請求項3に記載のブロックチェーン更新システムであって、
    m, rを所定の整数とし、kを1以上m以下の各整数とし、jを1以上m以下の整数とし、G1, G2, GTを位数がnビットの群とし、eをe:G1×G2→Gtのペアリングとし、a, b←{0, 1}nとし、c=(ab)-1とし、Pを上記ブロックチェーンの最後のブロックに対応する上記一方向性関数の出力である楕円曲線G1上の点とし、Qを上記ブロックチェーンのプルーフオブワークの探索空間である楕円曲線G2上の点の集合とし、
    上記探索空間分割部は、上記探索空間Qをm個に分割して、上記分割後探索空間Q1, Q2, …, Qmを生成するものであり、
    上記探索空間変換部は、各kについてP':=aP, Q'k:=bQkを計算して、上記変換後探索空間Q'1, Q'2, …, Q'mおよび変換後一方向性関数出力P'を生成するものであり、
    上記依頼計算要求部は、上記変換後探索空間Q'1, Q'2, …, Q'mに含まれる変換後探索空間Q'jと上記変換後一方向性関数出力P'とを上記クライアント装置へ送信するものであり、
    上記依頼計算実行部は、上記変換後探索空間Q'jと上記変換後一方向性関数出力P'とを用いてe(P', Q'j)を計算して、上記依頼計算結果を求めるものであり、
    上記計算結果検証部は、e(P', Q'j)c=e(P, Qj)を計算して、上記計算結果e(P, Qj)を求めるものであり、
    上記ブロックチェーン更新部は、e(P, Qj)≦2n-r-1を満たす上記計算結果e(P, Qj)を用いて上記ブロックチェーンを更新するものである、
    ブロックチェーン更新システム。
  5. ブロックチェーンのプルーフオブワークの探索空間を並列計算可能な形式に分割して複数の分割後探索空間を生成する探索空間分割部と、
    上記分割後探索空間それぞれを依頼計算可能な形式に変換して複数の変換後探索空間を生成する探索空間変換部と、
    上記変換後探索空間のいずれか一つを、トランザクションを要求したクライアント装置へ送信する依頼計算要求部と、
    上記変換後探索空間に対するブロックチェーンの一方向関数の依頼計算結果と上記トランザクションの確認に必要な情報とを、上記トランザクションを要求した上記クライアント装置から受信する計算結果受信部と、
    上記依頼計算結果を逆変換した上記一方向性関数の計算結果と上記トランザクションの確認に必要な情報とが正しいか否かを検証する計算結果検証部と、
    上記計算結果に所定の条件を満たすものがあればその計算結果を用いて上記ブロックチェーンを更新するブロックチェーン更新部と、
    を含むサーバ装置。
  6. トランザクションをサーバ装置へ要求するトランザクション要求送信部と、
    上記サーバ装置から受信した変換後探索空間を用いてブロックチェーンの一方向性関数を計算して上記一方向関数の依頼計算結果を求める依頼計算実行部と、
    上記依頼計算結果と上記トランザクションの確認に必要な情報とを上記サーバ装置へ送信する計算結果送信部と、
    を含み、
    上記変換後探索空間は、上記ブロックチェーンのプルーフオブワークの探索空間を並列計算可能な形式に分割した複数の分割後探索空間それぞれを依頼計算可能な形式に変換した複数の変換後探索空間のいずれか一つである、
    クライアント装置。
  7. 少なくとも1台のサーバ装置と複数台のクライアント装置とを含むブロックチェーン更新システムが実行するブロックチェーン更新方法であって、
    上記サーバ装置は、ブロックチェーンのプルーフオブワークの探索空間を並列計算可能な形式に分割して複数の分割後探索空間を生成し、
    上記サーバ装置は、上記分割後探索空間それぞれを依頼計算可能な形式に変換して複数の変換後探索空間を生成し、
    上記クライアント装置は、トランザクションを上記サーバ装置へ要求し、
    上記サーバ装置は、上記変換後探索空間のいずれか一つを、上記トランザクションを要求した上記クライアント装置へ送信し、
    上記クライアント装置は、上記サーバ装置から受信した上記変換後探索空間を用いて上記ブロックチェーンの一方向性関数を計算して上記ブロックチェーンの一方向性関数の依頼計算結果を求め、
    上記クライアント装置は、上記依頼計算結果と上記トランザクションの確認に必要な情報とを上記サーバ装置へ送信し、
    上記サーバ装置は、上記依頼計算結果と上記トランザクションの確認に必要な情報とを、上記トランザクションを要求した上記クライアント装置から受信し、
    上記サーバ装置は、上記依頼計算結果を逆変換した上記一方向性関数の計算結果と上記トランザクションの確認に必要な情報とが正しいか否かを検証し、
    上記サーバ装置は、上記計算結果に所定の条件を満たすものがあればその計算結果を用いて上記ブロックチェーンを更新する、
    ブロックチェーン更新方法。
  8. 請求項5に記載のサーバ装置もしくは請求項6に記載のクライアント装置としてコンピュータを機能させるためのプログラム。
JP2017103300A 2017-05-25 2017-05-25 ブロックチェーン更新システム、サーバ装置、クライアント装置、ブロックチェーン更新方法、およびプログラム Active JP6754319B2 (ja)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2017103300A JP6754319B2 (ja) 2017-05-25 2017-05-25 ブロックチェーン更新システム、サーバ装置、クライアント装置、ブロックチェーン更新方法、およびプログラム

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2017103300A JP6754319B2 (ja) 2017-05-25 2017-05-25 ブロックチェーン更新システム、サーバ装置、クライアント装置、ブロックチェーン更新方法、およびプログラム

Publications (2)

Publication Number Publication Date
JP2018197832A true JP2018197832A (ja) 2018-12-13
JP6754319B2 JP6754319B2 (ja) 2020-09-09

Family

ID=64663959

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2017103300A Active JP6754319B2 (ja) 2017-05-25 2017-05-25 ブロックチェーン更新システム、サーバ装置、クライアント装置、ブロックチェーン更新方法、およびプログラム

Country Status (1)

Country Link
JP (1) JP6754319B2 (ja)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102130961B1 (ko) * 2019-01-09 2020-07-07 금오공과대학교 산학협력단 블록체인을 이용한 무기류 및 탄약류 관리 시스템 및 그 방법
CN111698108A (zh) * 2019-03-13 2020-09-22 阿里巴巴集团控股有限公司 数据传递方法及装置
CN112037057A (zh) * 2020-04-10 2020-12-04 支付宝(杭州)信息技术有限公司 区块链数据的订正方法及装置
KR20210027012A (ko) * 2019-08-30 2021-03-10 주식회사 미디움 피어 노드와 그 정보 처리 방법 및 블록체인 플랫폼 시스템
KR20210027442A (ko) 2018-07-12 2021-03-10 가부시키가이샤 제트엠피 무인 배송 차량에 의한 무인 배송 시스템
CN112702419A (zh) * 2020-12-21 2021-04-23 杭州趣链科技有限公司 基于区块链的数据处理方法、装置、设备和存储介质

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0373990A (ja) * 1989-05-18 1991-03-28 Toshiba Corp 分散型情報処理装置
CN103927656A (zh) * 2014-05-05 2014-07-16 宋骊平 一种内嵌固定收款地址的比特币终端钱包及其比特币支付方法
JP2014138194A (ja) * 2013-01-15 2014-07-28 Mitsubishi Electric Corp 情報処理装置
US20150193350A1 (en) * 2012-07-27 2015-07-09 Tencent Technology (Shezhen) Comany Limited Data storage space processing method and processing system, and data storage server
JP2017123116A (ja) * 2016-01-08 2017-07-13 日本電気株式会社 負荷分散システム、負荷分散装置、負荷分散方法、および、プログラム

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0373990A (ja) * 1989-05-18 1991-03-28 Toshiba Corp 分散型情報処理装置
US20150193350A1 (en) * 2012-07-27 2015-07-09 Tencent Technology (Shezhen) Comany Limited Data storage space processing method and processing system, and data storage server
JP2014138194A (ja) * 2013-01-15 2014-07-28 Mitsubishi Electric Corp 情報処理装置
CN103927656A (zh) * 2014-05-05 2014-07-16 宋骊平 一种内嵌固定收款地址的比特币终端钱包及其比特币支付方法
JP2017123116A (ja) * 2016-01-08 2017-07-13 日本電気株式会社 負荷分散システム、負荷分散装置、負荷分散方法、および、プログラム

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
淵田 康之: "ブロックチェーンと金融取引の革新", 野村資本市場クォータリー, vol. 第19巻第2号(通巻74号), JPN6020017917, 1 November 2015 (2015-11-01), pages 11 - 35, ISSN: 0004274182 *

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20210027442A (ko) 2018-07-12 2021-03-10 가부시키가이샤 제트엠피 무인 배송 차량에 의한 무인 배송 시스템
KR20230162129A (ko) 2018-07-12 2023-11-28 가부시키가이샤 제트엠피 무인 배송 차량에 의한 무인 배송 시스템
KR102130961B1 (ko) * 2019-01-09 2020-07-07 금오공과대학교 산학협력단 블록체인을 이용한 무기류 및 탄약류 관리 시스템 및 그 방법
CN111698108A (zh) * 2019-03-13 2020-09-22 阿里巴巴集团控股有限公司 数据传递方法及装置
CN111698108B (zh) * 2019-03-13 2023-11-21 阿里巴巴集团控股有限公司 数据传递方法及装置
KR20210027012A (ko) * 2019-08-30 2021-03-10 주식회사 미디움 피어 노드와 그 정보 처리 방법 및 블록체인 플랫폼 시스템
KR102304953B1 (ko) 2019-08-30 2021-09-27 주식회사 미디움 피어 노드와 그 정보 처리 방법 및 블록체인 플랫폼 시스템
CN112037057A (zh) * 2020-04-10 2020-12-04 支付宝(杭州)信息技术有限公司 区块链数据的订正方法及装置
CN112037057B (zh) * 2020-04-10 2022-03-01 支付宝(杭州)信息技术有限公司 区块链数据的订正方法及装置
CN112702419A (zh) * 2020-12-21 2021-04-23 杭州趣链科技有限公司 基于区块链的数据处理方法、装置、设备和存储介质

Also Published As

Publication number Publication date
JP6754319B2 (ja) 2020-09-09

Similar Documents

Publication Publication Date Title
JP6754319B2 (ja) ブロックチェーン更新システム、サーバ装置、クライアント装置、ブロックチェーン更新方法、およびプログラム
Majeed et al. FLchain: Federated learning via MEC-enabled blockchain network
CN107657438B (zh) 一种区块链生成方法、数据验证方法、节点及系统
US10491396B2 (en) Method and server for providing notary service for file and verifying file recorded by notary service
Luu et al. Demystifying incentives in the consensus computer
US9967334B2 (en) Computing device configuration and management using a secure decentralized transaction ledger
KR101311057B1 (ko) 컴퓨터 구현 방법, 컴퓨터 판독가능 매체, 및 컴퓨팅 장치
JP2023155441A (ja) 未決定データに基づいたブロックチェーン・トランザクションの安全性確保
CN109889497B (zh) 一种去信任的数据完整性验证方法
KR20200096790A (ko) 증명 검증에 기초하여 오프-체인 데이터를 인증하기 위한 시스템 및 방법
Mahmoud et al. Research challenges and opportunities in blockchain and cryptocurrencies
Han et al. A lightweight and privacy-preserving public cloud auditing scheme without bilinear pairings in smart cities
KR20170040079A (ko) 블록 검증을 위한 복수의 일방향 함수를 지원하는 블록 체인
EP3394848A1 (en) Method for storing data on a storage entity
KR20200094173A (ko) 블록체인 기반 스마트 계약의 다중-당사지 생성을 위한 시스템 및 방법
US11651335B2 (en) Methods and devices for controlling a mining pool for multiple blockchain networks
JP2004537062A (ja) 暗号アプリケーションにおける一方向チェーンの効率的計算方法および装置
CN114661318A (zh) 针对资源受限设备定制的高效后量子安全软件更新
JP6951649B2 (ja) ブロック検証装置、ブロック検証方法、及びプログラム
Tan et al. An efficient method for checking the integrity of data in the cloud
CN108416221B (zh) 一种云环境中安全的相似数据拥有证明方案
Dwivedi et al. Smart contract and ipfs-based trustworthy secure data storage and device authentication scheme in fog computing environment
EP4357883A1 (en) Data verification method and apparatus, device and storage medium
He et al. Blockchain based data integrity verification for cloud storage with T-merkle tree
CN115459928A (zh) 数据共享方法、装置、设备及介质

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20190619

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20200327

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20200602

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20200731

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20200818

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20200821

R150 Certificate of patent or registration of utility model

Ref document number: 6754319

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150