Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
マイナンバーカードで署名する / mynumbercard
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Mako
August 09, 2021
Technology
3.4k
2
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
マイナンバーカードで署名する / mynumbercard
seccamp2021 LT大会での発表内容
Mako
August 09, 2021
More Decks by Mako
See All by Mako
マイナンバーカードの暗号技術とセキュリティ
tex2e
2
2.9k
SELinuxで堅牢化する / selinux
tex2e
3
1.7k
TLS 1.3自作入門 / tls13
tex2e
0
1.2k
プロトコルの形式的安全性検証ツールProVerif / proverif
tex2e
0
1.4k
Other Decks in Technology
See All in Technology
Rancherの紹介&Update情報(RancherJP Online Meetup #09)
yoshiyuki_kono
0
140
新規事業を牽引する技術選定 〜フルスタックTypeScript開発の実践事例〜
nullnull
3
380
脆弱性対応、どこで線を引くか
rymiyamoto
0
190
TypeScript Compiler APIとPHP-Parserを活用し、TypeScriptとPHPで型を共有する
shuta13
1
390
protovalidate-es を導入してみた
bengo4com
0
160
Dario Amodi『Policy on the AI Exponential』を理解する
nagatsu
0
210
GoとSIMDとWasmの今。
askua
3
520
「速く作る」から「正しく作る」へ ─ 生成AI時代の開発フロー改革の ロードマップと実行 ─
starfish719
0
9.5k
PHP と TypeScript の型システム比較:AI 時代の「型」は誰のためにあるのか? #frontend_phpcon_do / frontend_phpcon_do_2026
shogogg
1
280
2026.06.13_AI時代に事業会社が「SIer出身エンジニア」を求める理由 / Why Businesses Seek Engineers with a System Integrator Background in the AI Era
jumtech
0
990
AIにフローを作らせようとして挫折した話
hamatsutaichi
0
250
価格.comをAI駆動で全面刷新する ー 30年分の技術的負債を返し、次の30年の土台をつくる ー / AI Engineering Summit Tokyo 2026
tkyowa
53
58k
Featured
See All Featured
State of Search Keynote: SEO is Dead Long Live SEO
ryanjones
0
200
Fantastic passwords and where to find them - at NoRuKo
philnash
52
3.7k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.7k
HU Berlin: Industrial-Strength Natural Language Processing with spaCy and Prodigy
inesmontani
PRO
0
410
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
360
30k
The AI Search Optimization Roadmap by Aleyda Solis
aleyda
1
5.9k
WCS-LA-2024
lcolladotor
0
620
Building Experiences: Design Systems, User Experience, and Full Site Editing
marktimemedia
0
530
16th Malabo Montpellier Forum Presentation
akademiya2063
PRO
0
140
What’s in a name? Adding method to the madness
productmarketing
PRO
24
4.1k
Abbi's Birthday
coloredviolet
2
8k
From Legacy to Launchpad: Building Startup-Ready Communities
dugsong
0
230
Transcript
マイナンバーカードで署名する @tex2e 2021/8/9
マイナンバーカード 個人番号が書かれた ICカード。内部に認証用・署名用の証明書 (公開鍵)と秘密鍵を持つ ↑※QRコードにも個人番号がある点に注意
マイナンバーカードでできる処理 <処理> • 認証用証明書の取得 • 認証用秘密鍵による署名 • 署名用証明書の取得 • 署名用秘密鍵による署名
• 個人番号の取得 • 基本4情報の取得 <出力> (DER形式のデータ) (データに対する署名) (DER形式のデータ) (データに対する署名) (文字列) (UTF-8文字列)
認証用証明書・署名用証明書 署名用証明書のみ基本 4情報(名前, 生年月日, 性別, 住所)あり↓ ↑J-LIS 地方公共団体情報システム機構
公開鍵基盤 ←HTTPS証明書 ↓認証用・署名用証明書 左図:プロフェッショナル SSL/TLS, p. 62 https://www.lambdanote.com/collections/ssl-tls 右図:富士通, 2017-7月号
マイナンバー特集 マイナンバーカードの技術仕様と利活用方式 , p.62 https://www.fujitsu.com/jp/about/resources/publications/magazine/backnumber/vol68-4.html
デジタル署名 改ざん・なりすまし・否認を防ぐための技術 鍵生成 署名 検証 公開鍵 ※RSA署名のため、 検証鍵=公開鍵 署名鍵=秘密鍵 ※メッセージは
文書のハッシュ値を使う 秘密鍵 メッセージ 署名 公開鍵 (メッセージ, 署名) OK / NG
マイナンバーカードで署名する手順 公的個人認証AP を選択 署名用PIN を選択 署名用PIN送信 署名用秘密鍵 を選択 署名対象データ送信 署名データ
認証 root/ +-- 公的個人認証AP/ +-- 署名用証明書 +-- 署名用PIN +-- 署名用秘密鍵
通信プロトコル (APDU) 00 A4 04 0C 0A D3 92 F0
00 26 01 00 00 00 01 00 A4 02 0C 02 00 1B 00 20 00 80 06 31 32 33 34 35 36 00 A4 02 0C 02 00 17 80 2A 00 80 33 (...署名対象データ ...) 00 (...署名データ...) 90 00 90 00 ←SHA256RSA署名に必要な データの構造は「DigestInfo」 SELECT FILE VERIFY COMPUTE DIGITAL SIGNATURE
SHA256RSA 署名に必要な DigestInfo マイナンバーカードに署名させるデータを送るためのデータ構造( RFC, ASN.1参照) (1) RFC 2315 (PKCS
#7: Cryptographic Message Syntax Version 1.5) (2) RFC 5280 (Internet X.509 Public Key Infrastructure Certificate and Certificate Revocation List (CRL) Profile) 以上をまとめると: DigestInfo ::= SEQUENCE { SEQUENCE { algorithm OBJECT IDENTIFIER, parameters ANY DEFINED BY algorithm OPTIONAL } digest OCTET STRING }
ASN.1 と SHA256のOID algorithm: RFC 5754 (Using SHA2 Algorithms with
Cryptographic Message Syntax) parameters: NULL必須 05 00 ← タグがNULL(0x05)、長さが0x00のデータ、内容はなし(ASN.1参照) digest: 文書 (ファイル) のハッシュ値 以上でDERエンコードするとDigestInfoは: DigestInfo ::= SEQUENCE { SEQUENCE { algorithm OBJECT IDENTIFIER, parameters ANY DEFINED BY algorithm OPTIONAL } digest OCTET STRING } 30 31 30 0B 06 09 60 86 48 01 65 03 04 02 01 05 00 04 20 22 D6 28 B5 3B C6 B3 56 F5 91 3E 98 C5 A3 BC 8A E1 A5 BE 91 C2 91 68 02 35 8E 0E C2 BC FE 71 E7 (Tag, Len, Value) Tag: 0x30 : SEQUENCE 0x05 : NULL 0x04 : OCTET STRING
署名データ SHA256RSA (SHA256 with RSA Encryption) メッセージ→SHA256ハッシュ値(32byte)→RSA暗号化→署名(256byte) 0000000 6d 79
3e d3 0a d5 25 84 58 63 66 06 9c 0e 87 ad 0000010 87 82 65 16 6e 87 b6 35 5a 0a a2 6f 09 8b f6 43 0000020 45 9c 4b 73 65 93 2c 3b b9 7b 19 56 54 d7 0b 63 0000030 6c 13 e4 9d 0c b9 f5 1f d4 7b 03 88 95 73 6b d5 0000040 1a 27 fc 70 05 9e 62 45 69 22 6b 8b 3a 93 a4 6c 0000050 24 8a 33 be d3 84 3e d1 6e f6 f7 e3 0b da 46 7b 0000060 10 be 97 1a 28 81 8c 0e 75 9d 25 8b 24 1e 8d ec 0000070 28 d2 35 9d c6 e5 02 ad cd 77 2c 59 1a 47 62 91 0000080 8f e6 eb 6f 52 ed c9 17 b1 a6 43 81 9a b6 60 e3 0000090 ff 94 13 94 03 52 87 c6 bf c5 8c ed ed 17 ed 75 00000a0 da 6e d1 54 45 6a 20 24 ed 4b 41 dc d8 4f 16 be 00000b0 a5 0e e5 7a e4 29 22 60 64 10 3d b4 1a 23 bf 5e 00000c0 45 86 ce 32 18 d9 40 49 b7 43 af b3 44 41 63 40 00000d0 8a a0 94 d1 6b c5 5d 49 e0 7d 83 54 70 5c a0 6c 00000e0 02 7f ae 83 20 ef a2 5c 1c af e2 d5 2e cf ac 1e 00000f0 8b a3 95 76 fa cc 82 a0 3b 82 46 d5 10 77 9a aa 0000100
署名データの検証 検証者には (文書, 文書のハッシュ, 署名データ) と 証明書 が与えられる 1. マイナンバーカードから署名用証明書を取り出す
2. 署名用証明書から公開鍵を取り出す openssl x509 -in SignCert.der -inform der -out SignCert.pem -outform pem openssl x509 -pubkey -noout -in SignCert.pem -out SignPub.pem 3. OpenSSLに公開鍵と文書と署名データを渡して検証する openssl dgst -verify SignPub.pem -signature TARGET.pdf.sig TARGET.pdf 4. 「Verified OK」で検証成功 検証 公開鍵 (メッセージ, 署名) OK / NG
より詳細な解説 マイナンバーカードとAPDUで通信して署名データ作成 | 晴耕雨読 https://tex2e.github.io/blog/protocol/jpki-mynumbercard-with-apdu ASN.1 のタグ一覧 | 晴耕雨読 https://tex2e.github.io/blog/protocol/ans1-tags
おわりに マイナンバーカードは民間利用が可能です!どんどん使いましょう! マイナンバーカード マイナンバー (個人番号) 電子証明書 ↑ 個人番号は社会保障、税、 災害対策にしか使えない ↑
認証用証明書、署名用証明書は 民間でも利用可能
Thank you!