IP Force 特許公報掲載プロジェクト 2022.1.31 β版

知財求人 - 知財ポータルサイト「IP Force」

▶ エヌチェーン ホールディングス リミテッドの特許一覧

特許7495885資源へのアクセスを制御するために使用されるトークンの格納、生成および検証のための改善されたシステムおよび方法
<>
  • 特許-資源へのアクセスを制御するために使用されるトークンの格納、生成および検証のための改善されたシステムおよび方法 図1
  • 特許-資源へのアクセスを制御するために使用されるトークンの格納、生成および検証のための改善されたシステムおよび方法 図2
  • 特許-資源へのアクセスを制御するために使用されるトークンの格納、生成および検証のための改善されたシステムおよび方法 図3
< >
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-05-28
(45)【発行日】2024-06-05
(54)【発明の名称】資源へのアクセスを制御するために使用されるトークンの格納、生成および検証のための改善されたシステムおよび方法
(51)【国際特許分類】
   H04L 9/32 20060101AFI20240529BHJP
   H04L 9/08 20060101ALI20240529BHJP
【FI】
H04L9/32 200Z
H04L9/32 200B
H04L9/08 C
H04L9/08 F
【請求項の数】 13
(21)【出願番号】P 2020562184
(86)(22)【出願日】2019-05-13
(65)【公表番号】
(43)【公表日】2021-09-09
(86)【国際出願番号】 IB2019053945
(87)【国際公開番号】W WO2019220318
(87)【国際公開日】2019-11-21
【審査請求日】2022-04-15
(31)【優先権主張番号】1807813.9
(32)【優先日】2018-05-14
(33)【優先権主張国・地域又は機関】GB
(31)【優先権主張番号】PCT/IB2018/053347
(32)【優先日】2018-05-14
(33)【優先権主張国・地域又は機関】IB
(31)【優先権主張番号】1807816.2
(32)【優先日】2018-05-14
(33)【優先権主張国・地域又は機関】GB
(31)【優先権主張番号】PCT/IB2018/053350
(32)【優先日】2018-05-14
(33)【優先権主張国・地域又は機関】IB
(31)【優先権主張番号】1807807.1
(32)【優先日】2018-05-14
(33)【優先権主張国・地域又は機関】GB
(31)【優先権主張番号】PCT/IB2018/053346
(32)【優先日】2018-05-14
(33)【優先権主張国・地域又は機関】IB
(31)【優先権主張番号】1807811.3
(32)【優先日】2018-05-14
(33)【優先権主張国・地域又は機関】GB
(31)【優先権主張番号】PCT/IB2018/053349
(32)【優先日】2018-05-14
(33)【優先権主張国・地域又は機関】IB
(73)【特許権者】
【識別番号】318001991
【氏名又は名称】エヌチェーン ライセンシング アーゲー
(74)【代理人】
【識別番号】100107766
【弁理士】
【氏名又は名称】伊東 忠重
(74)【代理人】
【識別番号】100070150
【弁理士】
【氏名又は名称】伊東 忠彦
(74)【代理人】
【識別番号】100135079
【弁理士】
【氏名又は名称】宮崎 修
(72)【発明者】
【氏名】ライト,クレイグ スティーヴン
【審査官】金沢 史明
(56)【参考文献】
【文献】特開2008-113426(JP,A)
【文献】米国特許出願公開第2017/0207917(US,A1)
【文献】国際公開第2017/127238(WO,A1)
【文献】特表2014-526155(JP,A)
【文献】米国特許出願公開第2007/0186105(US,A1)
(58)【調査した分野】(Int.Cl.,DB名)
H04L 9/00- 9/40
G09C 1/00
(57)【特許請求の範囲】
【請求項1】
クライアントとサーバーの間でコンピュータ実装されるアクセス方法であって、当該方法は:
(i)前記クライアントによって、派生公開鍵に宛てられたアクセス・ブロックチェーン・トランザクションをブロックチェーンに提出する段階であって、前記派生公開鍵は少なくとも部分的に秘密値および公開鍵から生成される、段階と;
(ii)前記クライアントによって、少なくとも部分的に前記秘密値および前記公開鍵に基づいて検証公開鍵を生成する段階と;
(iii)前記サーバーによって、前記派生公開鍵と前記検証公開鍵を比較する段階と;
(iv)段階(iii)の比較に基づいて:(a)前記サーバーによって、前記派生公開鍵および前記検証公開鍵の少なくとも一方を、さらなる派生公開鍵を検証するためのさらなる公開鍵として割り当て;(b)前記サーバーによって前記クライアントに対して、前記秘密値および前記派生公開鍵の少なくとも一方に関連する資源へのアクセスを承認する段階とを含み、
前記秘密値は、データ項目の第1の一方向性関数チェーンのデータ項目であり、当該方法はさらに:
(v)前記クライアントによって、前記第1の一方向性関数チェーンの検証データ項目を提供する段階と;
(vi)前記クライアントによって、そのデータ項目に前記第1の一方向性関数を適用する段階と;
(vii)前記サーバーによって、段階(vi)の出力を前記検証データ項目と比較する段階と;
(viii)段階(vii)の帰結にも基づいて段階(iv)を実行する段階とを含む、
方法。
【請求項2】
段階(iii)は、少なくとも1つの試験または基準の適用を含む、請求項1に記載の方法。
【請求項3】
前記試験または基準は、前記派生公開鍵が前記検証公開鍵と一致する、または同一であるかどうかについての評価を含む、請求項2に記載の方法。
【請求項4】
前記試験または基準は、閾値に基づく評価を含む、請求項2または3に記載の方法。
【請求項5】
さらなる秘密値および前記さらなる公開鍵を用いて段階(ii)~(iv)を繰り返すことをさらに含む、請求項1ないし4のうちいずれか一項に記載の方法。
【請求項6】
(ix)第2のクライアントによって、データ項目の第2の一方向性関数チェーンの検証データ項目を提供する段階と;
(x)前記第2のクライアントによって、前記第1のチェーンの少なくとも1つの検証項目および前記第2のチェーンの前記検証データ項目の提供に際してロック解除可能な交換ブロックチェーン・トランザクションを前記ブロックチェーンに提出する段階であって、そのようなロック解除は、前記第2のチェーンの少なくとも1つのデータ項目を資源に関連付けさせる、段階とをさらに含む、
請求項1に記載の方法。
【請求項7】
前記第1のクライアントによって、前記交換ブロックチェーン・トランザクションをロックを解除する段階と、前記第2のチェーンのデータ項目および前記第2のチェーンの前記検証データ項目を用いて段階(ii)~(iv)を繰り返すこととをさらに含む、請求項6に記載の方法。
【請求項8】
前記第2のクライアントによって、ロック時間経過後に前記交換ブロックチェーン・トランザクションの入力の制御を返すように構成された、返還ブロックチェーン・トランザクションを前記ブロックチェーンに提出する段階をさらに含む、請求項6または7に記載の方法。
【請求項9】
前記サーバーによって、一方向性関数チェーンの初期データ項目を格納する段階をさらに含み、該初期データ項目から、前記一方向性関数チェーンの少なくとも1つのデータ項目が計算可能である、請求項6ないし8のうちいずれか一項に記載の方法。
【請求項10】
段階(viii)は、前記検証データ項目を削除することをさらに含む、請求項1ないし9のうちいずれか一項に記載の方法。
【請求項11】
アクセス・ブロックチェーン・トランザクションが、前記資源を識別する情報を含む、請求項1ないし10のうちいずれか一項に記載の方法。
【請求項12】
クライアントおよびサーバーを有するシステムであって:
前記クライアントおよび前記サーバーのそれぞれは:
プロセッサと;
前記プロセッサによる実行の結果として、当該システムに請求項1ないし11のうちいずれか一項に記載されるコンピュータ実装される方法を実行させる実行可能命令を含むメモリと
を有するシステム。
【請求項13】
コンピュータ・システムのプロセッサによって実行される結果として、該コンピュータ・システムに請求項1ないし11のうちいずれか一項に記載のコンピュータ実装される方法の実施形態を少なくとも実行させる実行可能命令が記憶されている非一時的コンピュータ読取可能記憶媒体。
【発明の詳細な説明】
【技術分野】
【0001】
本発明は、概括的には、デジタル資源の移転およびアクセスの制御のための安全で効率的な解決策に、より詳細にはアクセス鍵のはたらきをする電子/デジタル・トークンの移転、格納、通信、生成および検証に関する。本発明は、限定されるものではないが、たとえばビットチェーン・ブロックチェーンのようなブロックチェーンと一緒の使用に特に好適である。
【背景技術】
【0002】
本稿では、「ブロックチェーン」という用語を、電子的、コンピュータベース、分散型のあらゆる形態の台帳を含むものとして使う。これらは、コンセンサスに基づくブロックチェーンおよびトランザクションチェーン技術、公開および私的な台帳、許可式および非許可式の台帳、共有される台帳、およびそれらの変形を含む。ブロックチェーン技術の最も広く知られている応用はビットコイン台帳であるが、他のブロックチェーン実装が提案され、開発されている。本明細書では、便宜上、説明のためにビットコインに言及することがあるが、本発明は、ビットコイン・ブロックチェーンと一緒に使用することに限定されず、代替的なブロックチェーン実装およびプロトコルが、本発明の範囲内にはいることに注意しておくべきである。用語「ユーザー」は、本明細書中では、人間またはプロセッサ・ベースの資源を指しうる。また、用語「ビットコイン」は、本明細書中では、ビットコイン・プロトコル/プラットフォームから派生するまたはそれに基づくプロトコル/プラットフォームのすべてのバージョンおよび変形を含むものとして使用される。
【0003】
ブロックチェーンは、ピアツーピアの電子台帳であり、これは、ブロックから構成される、コンピュータベースの脱中心化された分散型のシステムとして実装され、ブロックはトランザクションから構成される。各トランザクションは、ブロックチェーン・システムにおける参加者間のデジタル資産の制御〔コントロール〕の移転をエンコードするデータ構造であり、少なくとも1つの入力および少なくとも1つの出力を含む。各ブロックは、前のブロックのハッシュを含み、それにより諸ブロックがチェーン化されて、ブロックチェーンの端緒以来、そのブロックチェーンに書き込まれたすべてのトランザクションの永続的で変更不可能なレコードを作成する。トランザクションは、その入力および出力に埋め込まれた、スクリプトとして知られる小さなプログラムを含んでおり、それが、トランザクションの出力に誰がどのようにアクセスできるかを指定する。ビットコイン・プラットフォームでは、これらのスクリプトはスタック・ベースのスクリプト言語を使用して書かれる。
【0004】
トランザクションがブロックチェーンに書き込まれるためには、トランザクションは「有効確認」される必要がある。ネットワーク・ノード(採鉱者)が、各トランザクションが有効であることを保証するために作業を実行し、無効なトランザクションはネットワークから拒否される。ノードにインストールされているソフトウェア・クライアントが、そのロック・スクリプトおよびアンロック・スクリプトを実行することによって、未使用トランザクション(unspent transaction、UTXO)に対してこの有効確認(validation)作業を実行する。ロックおよびアンロック・スクリプトの実行が真と評価される場合、そのトランザクションは有効であり、そのトランザクションはブロックチェーンに書き込まれる。このように、トランザクションがブロックチェーンに書き込まれるためには、トランザクションは、i)そのトランザクションを受け取る最初のノードによって有効確認されなければならない。もし、トランザクションが有効確認されれば、ノードはそれをネットワーク内の他のノードに中継する。トランザクションは、ii)採鉱者によって構築された新しいブロックに追加され、iii)採掘されなければならない。すなわち、過去のトランザクションの公開台帳に追加される。
【0005】
ブロックチェーン技術は、暗号通貨実装の使用について最も広く知られているが、デジタル起業家は、ビットコインのベースとなる暗号セキュリティ・システムと、ブロックチェーンに格納できるデータの両方を使用して、新しいシステムを実装することを検討し始めている。ブロックチェーンが、暗号通貨の領域に限定されない自動化されたタスクおよびプロセスに使用できれば、非常に有利であろう。そのような解決策は、応用がより多様でありながら、ブロックチェーンの恩恵(たとえば、イベントの恒久的な、改竄不能な記録、分散処理など)を利用することができるであろう。
【発明の概要】
【発明が解決しようとする課題】
【0006】
現在の研究の1つの分野は、ブロックチェーンを介して、資源またはその制御を表現および移転し、またはそれらの資源へのアクセスを許容するためのトークンの使用である。トークンに関連付けられた資源は、電子的な資源または物理的な資源、仮想的な資源または現実世界の資源でありうる。潜在的に機微なまたは秘密の資源は、見分けられる意味や値をもたないトークンによって表現できる。このように、トークンは、現実世界の資源がブロックチェーンから参照されることを許容する識別子として機能する。
【0007】
コンピューティング資源の使用を最小限にしながら、トークンを通信、格納、生成、および/またはあるユーザーから別のユーザーに移転する安全で効率的な仕方を提供することが望ましい。そのような改善された解決策がこのたび考案された。
【課題を解決するための手段】
【0008】
そこで、本発明によれば、添付の特許請求の範囲に定義される方法が提供される。
【0009】
本発明によれば、以下の段階を含むコンピュータ実装されるアクセスまたは制御方法が提供されてもよい。
(i)少なくとも部分的に秘密値および公開鍵から導出された派生公開鍵に宛てられたアクセス・ブロックチェーン・トランザクションをブロックチェーンに提出する;
(ii)少なくとも部分的に前記秘密値および前記公開鍵に基づいて検証公開鍵を生成する;
(iii)前記派生公開鍵と前記検証公開鍵を比較する;
(iv)段階(iv)の比較に基づいて:(a)前記派生公開鍵および/または前記検証公開鍵を、さらなる派生公開鍵を検証するためのさらなる公開鍵として割り当てるまたは指定し;(b)前記秘密値および/または前記派生公開鍵の少なくとも一方に関連する資源へのアクセスを承認する。
【0010】
段階(i)および(ii)は、第1の当事者によって実行されてもよい。段階(iii)および(iv)は、第2の当事者によって実行されてもよい。用語「ユーザー」は、本明細書において「当事者」と交換可能に使用されることがある。用語「当事者」および「ユーザー」は、人間のユーザー、コンピューティング資源、クライアント、サーバーおよび/またはネットワーク・ノードを含むことが意図されている。
【0011】
本方法は、前記秘密値を第1のユーザーから第2のユーザーに送信するステップを含んでいてもよい。
本方法は、前記秘密値を生成する段階を含んでいてもよい。前記秘密値は、トークンであってもよい。これは、第1のユーザーによって実行されてもよい。
【0012】
段階(iii)の比較は、少なくとも1つの試験または基準の適用を含んでいてもよい。試験または基準は、派生公開鍵が検証公開鍵と一致する、または同一であるかどうかについての評価を含んでいてもよい。この試験または基準は、閾値に基づく評価を含んでいてもよい。
【0013】
そのような方法は、各データ項目の出所のチェックを提供することによって安全性および信頼性を向上させ、検証目的のために必要とされる記憶スペースおよびメモリの量を減らすことによって効率を向上させ、通信されるデータの量を減らすことによって安全性を向上させるとともに、誤りが発生する可能性を低下させる。
【0014】
本方法は、さらなる秘密値および前記さらなる公開鍵を用いて段階(ii)~(iv)を繰り返すことをさらに含んでいてもよい。
【0015】
これは、イベントをブロックチェーン上に記録し、それにより記録が公開され、変更不能になるという利点を提供する。よって、ブロックチェーンは、あるユーザーから別のユーザーに公開鍵を共有、伝送または移転するための通信媒体または機構として機能しうる。第2のユーザーは、ブロックチェーンから公開鍵を見ることができる。このことは、第1のユーザーと第2のユーザーとの間の鍵の直接的な通信を回避または最小化する。そのような通信は、認可されていない当事者による傍受を引き起こす可能性がある。本発明は、ユーザーどうしが互いに知られていない、または信頼関係を有していないことがありうる場合の解決策を提供する。これは、データ項目の移転のための改善された安全性および改善された通信解決策を提供する。さらに、ブロックチェーンの公開性および変更不能性は、発生したイベント(単数または複数)および第1のユーザーが使用した公開鍵(単数または複数)を検証するために使用できる。
【0016】
前記秘密値は、データ項目の第1の一方向性関数チェーンのデータ項目であってもよく、本方法はさらに次の段階を含んでいてもよい:
(v)第1の一方向性関数チェーンの検証データ項目を提供する;
(vi)そのデータ項目に第1の一方向性関数を適用する;
(vii)段階(vi)の出力を前記検証項目と比較する;
(viii)段階(vii)の帰結にも基づいて段階(iv)を実行する。
【0017】
データ項目に暗号学的ハッシュ関数などの一方向性関数を適用する結果として、さらなるデータ項目が生じる。該さらなるデータ項目に前記一方向性関数をその後適用する結果として、さらにさらなるデータ項目が生じる。このようにして、データ項目のチェーンが生成され、ここで、データ項目のチェーンのメンバーは、一方向性関数の適用を介して互いに決定論的にリンクされる。そのようなチェーンは、データ項目の一方向性関数チェーンと呼ばれる。検証データ項目は、一方向性関数チェーンのメンバーであり、検証目的のために使用されるデータ項目であり、のちに詳細に記載される。
【0018】
これは、それぞれ少なくとも1つのデータ項目に関連する少なくとも1つの資源にアクセスする能力をユーザー間で移転する安全で、記録される方法を提供する。
【0019】
本方法は、以下の段階をさらに含んでいてもよい:
(ix)データ項目の第2の一方向性関数チェーンの検証データ項目を提供する;
(x)第1のチェーンの少なくとも1つの検証項目および第2のチェーンの前記検証データ項目の提供に際してロック解除可能な交換ブロックチェーン・トランザクションをブロックチェーンに提出する。ここで、そのようなロック解除は、第2のチェーンの少なくとも1つのデータ項目を資源に関連付けさせる。
これは、ユーザー間で、それぞれの少なくとも1つのデータ項目に関連する少なくとも1つの資源にアクセスする能力を移転する、安全で記録される方法を提供する。
【0020】
本方法は、さらに、交換ブロックチェーン・トランザクションをロックを解除する段階と、第2のチェーンのデータ項目および第2のチェーンの前記検証データ項目を用いて段階(ii)~(iv)を繰り返すことを含んでいてもよい。
【0021】
これは、新規ユーザーが少なくとも1つの資源に安全にアクセスできるようにするという利点を提供する。
【0022】
本方法は、ロック時間経過後に交換ブロックチェーン・トランザクションの入力の制御を返すように構成された、返還ブロックチェーン・トランザクションをブロックチェーンに提出することをさらに含んでいてもよい。
【0023】
これは、不正直なユーザーが交換ブロックチェーン・トランザクションの入力を無期限にロックすることを防止し、それにより、本方法の多用途性を増すという利点を提供する。
【0024】
本方法は、一方向性関数チェーンの初期データ項目を格納する段階をさらに含んでいてもよく、該データ項目から、一方向性関数チェーンの少なくとも1つのデータ項目が計算可能である。
これは、記憶要件をさらに低減し、対応して方法の効率を向上させるという利点を提供する。
【0025】
段階(vii)は、検証データ項目を削除することをさらに含んでいてもよい。
【0026】
これは、記憶要件をさらに低減し、対応して方法の効率を向上させるという利点を提供する。
【0027】
アクセス・ブロックチェーン・トランザクションは、資源を識別する情報を含んでいてもよい。たとえば、ブロックチェーン・トランザクションは、資源に関する情報を含むオフチェーン・データ・リポジトリをポイントするURLまたはそのハッシュを含み得る。URLはトランザクションのメタデータに格納されてもよい。
これは、資源に関する情報が安全に通信されうるという利点を提供する。
【0028】
本発明は、システムであって:
プロセッサと;
プロセッサによる実行の結果として、当該システムに本明細書に記載されるコンピュータ実装される方法の任意の実施形態を実行させる実行可能命令を含むメモリと
を有するシステムをも提供する。
【0029】
本発明は、コンピュータ・システムのプロセッサによって実行される結果として、該コンピュータ・システムに本明細書に記載されるコンピュータ実装される方法の実施形態を少なくとも実行させる実行可能命令が記憶されている非一時的コンピュータ読取可能記憶媒体をも提供する。
【0030】
本発明のこれらおよび他の側面は、本明細書に記載される実施形態から明白となり、それを参照して解明されるであろう。本発明の実施形態を、ここで、単なる例として、添付の図面を参照して説明する。
【図面の簡単な説明】
【0031】
図1】トークンを生成し、アクティブ化するための段階を示すフローチャートである。
図2】トークンの制御を交換するための段階を示すフローチャートである。
図3】公開鍵を使用してトークンをアクティブ化するための段階を示すフローチャートである。
【発明を実施するための形態】
【0032】
本発明は、ハッシュ・チェーンのような暗号的に安全な一方向性関数チェーンを用いてトークンを効率的に生成し、記憶することを可能にする。本方法は、パフォーマンス、記憶、スケーラビリティ、および信頼性の利点を有する。トークンは他のユーザーに安全に販売されることができる。トークンは、証明可能に公開鍵にリンクされることができ、それにより、プライベートで安全な、トークンをアクティブ化し検証する普遍的な方法を提供する。
【0033】
トークンとは、ネットワークを通じた、一または複数の異なる当事者間での信頼される通信を保証するデータ構造またはデータ項目である。たとえば、トークンは、一の当事者から別の当事者への資源の制御の移転を表わすため、および/または商品またはサービスのような制御される資源にアクセスするために使用できる。たとえば、トークンをアクティブ化することによって、顧客は、コンピューティングまたは電子資源、ホテルの部屋、ハイヤーまたは有料道路;処方箋薬、消費者製品、またはサプライチェーン内のアイテムのような商品;およびウェブサイトまたはコンピュータ・アプリケーション上のセッションのようなサービスのような資源へのアクセスを承認されうる。トークン自体は、これらの資源をロック解除するための鍵として使用されてもよく、あるいは分散ハッシュテーブル(Distributed Hash Table、DHT)のような前記資源に関するさらなる情報を含む外部状態をポイントしてもよい。
【0034】
トークンは、典型的には256ビットの数として表現され、いったんアクティブ化されると、時間的な制限をもつことがあり(たとえば、トークンが安全なデータ・リポジトリへのアクセスを24時間許可される場合)、有限の使用回数をもつことがある(たとえば、ひとたびトークンがアクティブ化されて24時間が経過したら、安全なデータ・リポジトリへのアクセスは、新しい、異なるトークンが発行され、アクティブ化されるまで撤回される)。
【0035】
トークンをアクティブ化したい当事者を「クライアント」と称し、トークンがアクティブ化されたことを検証したい当事者を「サーバー」と称する。
【表1】
【0036】
クライアントは、トークンをサーバーに提供することによって、トークンをアクティブ化する。これは、ブロックチェーン上でトークンを公に開示することによって実行されうる。これは、トークンの値を記録するトランザクションを、サーバーが検証しうるトランザクション・データまたはメタデータ内で完成させることによって達成される。このトランザクションの出力は、使用される必要がないことを注意しておく。
【0037】
必要とされるトークンの量は、その利用を必要とするイベントの量とともに線形にスケーリングすることができる。たとえば、ユーザーがある回数、安全なデータ・リポジトリへのアクセスを要求する場合、同じ数のトークンが生成されてもよい。将来の使用のために複数のトークンを作成するための既知の方法は、各トークンが別々に生成されるというものである。たとえば各トークンがランダムに生成される。その際、すべてのトークンが、クライアントとサーバーの両方によってデータベースに記憶される。
【0038】
しかしながら、本発明では、クライアントとサーバーのそれぞれによって一度に記憶される必要があるのは、1つのトークンのみである。これは、各トークンが、ハッシュ関数のような、暗号学的に安全な一方向性関数の逐次の適用を通じて/介して、直前のトークンに関連するという規則を実装することによって達成される。たとえば、トークンtiは規則:
ti=H(ti-1) (1)
に従ってトークンti-1に関係付けられる。ここで、HはSHA-256などのハッシュ関数である。
【0039】
トークンti-1をアクティブ化するために、ti-1を含むトランザクションがブロックチェーンに提出される。ここでti-1は、その前のトークンtiのハッシュ・パズルに対する解であり、それにより、ti-1を公に明かすことが、チェーン内の各トークンを証明可能にリンクする。
【0040】
本発明の利点は、下記を含む:
・クライアントとサーバーは、任意の所与の時刻においてトークンを1つ記憶している必要があるだけであり、これはメモリを節約する。1つのトークンが256ビットの数であり、アリスがn個のトークンを使用したい場合、各トークンをデータベースに個別に格納するのと比較して、この方法を使用すれば、アリスは(n-1)*256ビットのスペースを節約する。
・クライアントとサーバーの間で通信される必要のあるデータは少量のみであり、これはパフォーマンス、安全性および信頼性を改善する。
・トークンは記憶されるのではなく計算されるため、破壊やデータの破損を通じたトークンの偶発的な損失を防ぐ。
・各トークンがハッシュ・パズルへの解を通じて前のトークンに証明可能にリンクされているため、トークンについて、検査可能なレコードが利用可能である。
【0041】
図1を参照して、ここで、クライアント(アリス)がサーバー(ボブ)が検証できるトークンのシーケンスをアクティブ化する方法(100)について説明する。トークンは、ハッシュ・チェーンを使用してアリスによって生成される。以下の段階が実行される。
【0042】
1.アリスとボブが、アクセスするためにトークンのアクティブ化を要求する資源の数nについて合意する(105)。
【0043】
2.アリスが256ビットの数t0を生成する(110)。これは、何らかの入力データをハッシュすることによって達成することができ、あるいはランダムな数であってもよい。値t0は、アリスが使用する最後のトークンになる。アリスはこの数をn回ハッシュして、
tn=Hn(t0)
を計算する。ここで、tnはトークンではなく検証データ項目である。アリスはtnをボブに送る(115)。
【0044】
アリスは、t0を記憶し、他の値は記憶しない。アリスは、規則(1)を使ってn個のトークンtn-1,…,t1,t0を計算するためにこの値を使用する。これは、次を満たすトークンのアクセス・チェーンまたはハッシュ・チェーンを生成する:
tn-1=H(tn-2)
tn-2=H(tn-3)

t1=H(t0)
また、tn=H(tn-1)であることにも注意。
【0045】
アリスが最初に使うトークンはtn-1であり、最後に使うトークンはt0である。検証データ項目tnは検証目的のためにのみ使用され、それ自体はトークンではない。
【0046】
3.ボブはtnを記憶し(120)、他の値は記憶しない。ボブはt0,t1,…,tn-1を計算できないことに注意。
【0047】
4.アリスが、最初のトークンtn-1=Hn-1(t0)の値を計算し(125)、そのトークンを含むトランザクションを生成する(130)ことによって、それをアクティブ化する。トークンは、たとえば、トランザクション・メタデータ内に、またはロックまたはロック解除スクリプト内に格納されてもよい。それは、受信者のアドレス自体の公開鍵に格納されてもよい;この詳細は、以下の本発明のさらなる実施形態に関連して議論される。アリスはトランザクションをブロックチェーンに提出し、そのことがトークンを明かす(135)。
【0048】
5.ボブは今や、明かされたトークンを見て、読むことができ、tn=H(tn-1)となることをチェックすることによって、アリスが正しいトークンをアクティブ化したことを検証する(140)。ブロックチェーン上で明かされたトークンのハッシュが、ボブが格納した検証項目と同一でない場合(145)、ボブは資源へのアクセスを拒否する(150)。それ以外の場合は、ボブはアクセスを許容し(155)、tn-1を記憶し、tnを削除する。tn-1がシーケンスにおける次の検証データ項目となる。
【0049】
6.アリスは、tn-2を用いて段階4を繰り返すことによって別のトークンをアクティブ化する。ボブは、段階5を繰り返すことによってこのトークンを検証する。ただし、チェックするのはtn-1=H(tn-2)である。このプロセスは、n個のトークンがアクティブ化され、検証される(165)まで、逐次反復的に繰り返される(160)。
【0050】
資源にアクセスする能力を移転するための方法(200)が、図2を参照して説明される。
【0051】
アリスが自分のトークンのうちのm個tn-1,…,tn-mをすでにアクティブ化しており、チャーリーが一つまたは複数の条件を満たすために残りのn-m個のトークンtn-m-1,…,t0の制御を得ることを望むとする。チャーリーは次のようにして、(アリスを信頼することなく)これを行なうことができる。
【0052】
アリスとチャーリーは、アリスの残りのトークンをチャーリーに譲渡することに合意する(205)。アリスは、チャーリーに次の未使用トークンのハッシュH(tm-n-1)を送る。
【0053】
チャーリーは新しいトークンs0を作成する。次いで、チャーリーは、規則
sm-n-1=H(sm-n-2)
sm-n-2=H(sm-n-3)

s1=H(s0)
を使用してn-m個のトークンの系列sm-n-1,…,s0を生成する(210)。
【0054】
チャーリーはまた、検証目的のために使用される検証データ項目sm-n=H(sm-n-1)も計算する。チャーリーはsm-nをアリスに送る(215)。
【0055】
チャーリーは、前記一つまたは複数の条件を満たすトランザクションをブロックチェーンに提出する(220)。ここで、このトランザクションのロック解除スクリプトは
LockingScript=CheckSigH(PA) AND SolveH(tn-m-1) AND SolveH(sn-m)
の形である。ここで、PAはアリスの公開鍵である。このアドレスは、アリスによって制御される、公開鍵ハッシュへの支払い(Pay To Public Key Hash、P2PKH)アドレスまたはスクリプト・ハッシュへの支払い(Pay To Script Hash、P2SH)アドレスであることができる。
【0056】
ここで、アリスはサーバー、ボブに、トークンをチャーリーに移転したことを通知する。アリスは、次のトークンtm-n-1および検証データ項目sm-nをボブに知らせる(225)ことによってこれを行なう。ボブは、アリスのみがこれを行なうことができると確信することができる。なぜなら、ハッシュされて現在の検証項目tm-n=H(tm-n-1)になるトークンであることをボブが検証できるtm-n-1の値を知っているのはアリスだけであるからである。
【0057】
アリスが不正直であり、サーバー、ボブにこの情報を与えない場合、ひとたびアリスがチャーリーからのトランザクションを使用すれば(230)、この情報はいずれにせよブロックチェーン上で公に開示される。なぜなら、トランザクション・ロック解除スクリプトは
UnlockingScript=[sm-n][tn-m-1][SigPA][PA]
の形をもつからである。
【0058】
ハッシュが現在の検証項目と同一の場合(240)、ボブはトークンの制御をチャーリーに移転し(245)、次の検証データ項目としてtn-m-1をsn-mで置き換える(250)。それ以外の場合、ボブはトークンの制御をチャーリーに移転しない(260)。
【0059】
これで、ボブはsm-n=H(sm-n-1)をチェックすることによってチャーリーの最初のトークンsm-n-1を有効確認することができる(255)。
したがって、チャーリーはアリスからトークンを受け取ったことをボブに証明することができる。
【0060】
また、チャーリーからアリスへのトランザクションの時間ロック〔タイムロック〕返金を含めることも可能である。それにより、アリスはチャーリーが提出したトランザクションの入力を無期限にロックすることはできない。
【0061】
上述のアクセス・チェーン内のトークンは、証明可能に公開鍵/秘密鍵にリンクされることができる。公開鍵/秘密鍵をトークンとリンクするこの方法は、前述のようにトークンが一方向性関数またはハッシュ・チェーンを通じてリンクされることを要求せず、各トークンが前のトークンとの関連なしに個別に作成される場合に機能することを注意しておく。しかしながら、トークン・アクセス・チェーンを使用する利点は、リンクされた鍵に移行される。その際、リンクされた鍵がアクセス・チェーンを形成し、アクセス・チェーンの前記一方向性関数を通じて互いに証明可能にリンクされた、公開鍵/秘密鍵の検査可能なシーケンスを形成する。
【0062】
これのための一つの適用は、アリスが、これらの公開鍵アドレスへのトランザクションを行なうことによって、自分のトークンをアクティブ化することである。ボブは、公開鍵アドレス自体を観察することによって、トークンがアクティブ化されていることを検証できる。
【0063】
これは、トークン・スキームに関係するカスタム・トランザクションではなく標準的なトランザクションが必要とされるだけなので、トランザクションのサイズを可能な限り小さく保つことを助け、プライバシーを改善する。それは、任意のブロックチェーン・プロトコルまたはプラットフォーム上で有効な任意の公開鍵/秘密鍵システムのための普遍的な方法でもある。
【0064】
図3を参照して、ここで、クライアント、アリスが、サーバー、ボブが検証できるトークンのシーケンスをアクティブ化する方法(300)が説明される。
【0065】
P0がアリスの公開鍵を表わし、S0がアリスの秘密鍵を表わすとする。楕円曲線デジタル署名アルゴリズム(elliptic curve digital signature algorithm、ECDSA)システムでは、公開鍵/秘密鍵ペアはP0=S0・Gによって関係付けられる。ここで、Gは楕円曲線の生成点である。しかしながら、本方法の段階を実行するためには、任意の同等の公開鍵/秘密鍵システムが使用されうる。
【0066】
トークンの数について合意し(305)、初期値t0から諸トークンを生成し(310)、チェーンの検証データ項目tnをボブに送信(315)した後、アリスは自分の公開鍵P0をボブと共有する(320)。ボブはこれを検証データ項目として記憶する(325)。
【0067】
最初のトークンtn-1を生成した(330)アリスは、それを派生公開鍵
P1=(S0+tn-1)・G=P0+tn-1・G
を作成するために使用する(335)。
【0068】
アリスだけがtn-1を知っているので、この公開鍵を作成できるのはアリスだけである。公開鍵P1は、アリスのアクセス・チェーンにおいて最初のトークンと証明可能にリンクされることができる。
【0069】
アリスは、この公開鍵を、自分の最初のトークンをアクティブ化するためにトランザクションを送信できる送信先のアドレスとして使用することができる。アリスは、この公開鍵に宛てたブロックチェーン・トランザクションを生成し(340)、それをブロックチェーンに提出し(345)、それにより、公開鍵を公に開示する。
【0070】
その後、アリスはtn-1をボブに送信する(350)。次いで、ボブは、アリスがP1=P0+tn-1・Gに対してトランザクションを行なったことを確認する(355)ことにより、トークンtn-1がアクティブ化されたことを検証できる。提出されたトランザクションによって明かされた公開鍵が、公開鍵P0およびトークンtn-1を使用してボブによって計算されたものと同一である場合(360)、ボブは、資源へのアクセスをアリスに許可する(370)。それ以外の場合、ボブはアクセスを拒否する(365)。
【0071】
このプロセスは、逐次反復的に繰り返されることができる(375):最終トークンがまだアクティブ化されていない場合、ボブは、次の検証データ項目(380)として、開示された公開鍵を記憶し、プロセスは継続される;それ以外の場合は、プロセスは終了する(385)。
【0072】
この方法は、アクセス・チェーン内のトークンにそれぞれ一意的に証明可能にリンクされているn個の公開鍵を、次のように作成する:
P1=P0+tn-1・G
P2=P1+tn-2・G

Pn=Pn-1+t0・G
【0073】
このプロセスは、トークンが秘密鍵と同じグループ内の値をとることに頼っている。該グループは、ビットコインscep256k1プロトコルの場合、Zn *である。ここで、nは楕円曲線生成子Gの位数である。この数は2256よりわずかに小さい。トークンがこのグループ内でない場合、SHA-256のようなハッシュ関数に通して、nに関するモジュラスをとることができる。このプロセスにかけた後、トークンのいずれかが0の場合、アリスはやりなおし、異なるシード・トークンt0を選ぶ必要がある。
【0074】
上述の実施形態は、本発明を限定するのではなく、例解するものであり、当業者は、添付の特許請求の範囲によって定義される本発明の範囲から逸脱することなく、多くの代替実施形態を設計することができることに注意しておくべきである。特許請求の範囲においては、括弧内に付した参照符号があったとしても、請求項を限定するものと解釈してはならない。「含む」および「有する」等の語は、いずれかの請求項または明細書全体に列挙されたもの以外の要素または段階の存在を除外するものではない。本明細書において、「含む」は「…を含むまたは…からなる」ことを意味し、「有する」は「…を含むまたは…からなる」を意味する。要素の単数形での言及は、そのような要素の複数形での言及を除外するものではなく、その逆もまた同様である。本発明は、いくつかの別個の要素を有するハードウェアによって、および好適にプログラムされたコンピュータによって実装されうる。いくつかの手段を列挙する装置請求項においては、これらの手段のいくつかは、同一のハードウェア項目によって具現されてもよい。ある種の措置が相互に異なる従属請求項に記載されているというだけの事実が、これらの措置の組み合わせが有利に利用できないことを示すものではない。
図1
図2
図3