スキップしてメイン コンテンツに移動

node.js で Camellia 暗号を使ってみる

node.js で Camellia 暗号を使ってみる

概要

前回「node.js でAES暗号を使ってみる」という記事を書いていた時に、はるか昔に書いたCamellia暗号を C言語で利用する記事を書いたのを思い出したので node.js でCamellia暗号を使ってみる。「CamelliaをC言語に組み込むまで

Camellia暗号とはなにか?

Camellia暗号とは三菱電気とNTTのすごい方々が開発してくれた、しかも電子政府推奨暗号リスト掲載されている国産のブロック暗号アルゴリズムです。
AES 暗号と同等の暗号強度を持つそうです。

暗号化

node.js の内蔵モジュールにCamellia暗号が含まれているのでそれを使用します。
var crypto = require("crypto");
var key = "abcdefghijklmnop";
var data = "hello, OpenSSL! 123456789012345"; // OpenSSL ではなく node.js の内蔵モジュールを使用しているのだけども。。。
// 暗号化
var cipher = crypto.createCipher("CAMELLIA-128-CBC", key);
var crypted = cipher.update(data, "utf-8", "hex");
crypted += cipher.final("hex");
console.log(crypted); // 051a3b8c5557949755809b51ebae1041faf0eb2c5bbe97f2ccd7d75fcc0ecd30

復号化

var crypto = require("crypto");
var key = "abcdefghijklmnop";
// 復号化
var decipher = crypto.createDecipher("CAMELLIA-128-CBC", key);
var dec = decipher.update("051a3b8c5557949755809b51ebae1041faf0eb2c5bbe97f2ccd7d75fcc0ecd30", "hex", "utf-8");
dec += decipher.final("utf-8");
console.log(dec); // hello, OpenSSL! 123456789012345

ソースコード

"use strict";
var crypto = require("crypto");

var key = "abcdefghijklmnop";
var data = "hello, OpenSSL! 123456789012345"; // OpenSSL ではなく node.js の内蔵モジュールを使用しているのだけども。。。


// 暗号化
var cipher = crypto.createCipher("CAMELLIA-128-CBC", key);
var crypted = cipher.update(data, "utf-8", "hex");
crypted += cipher.final("hex");


// 復号化
var decipher = crypto.createDecipher("CAMELLIA-128-CBC", key);
var dec = decipher.update(crypted, "hex", "utf-8");
dec += decipher.final("utf-8");


console.log("CRYPTED   : " + crypted);
console.log("DECRYPTED : " + dec);


Console
CRYPTED   : 051a3b8c5557949755809b51ebae1041faf0eb2c5bbe97f2ccd7d75fcc0ecd30
DECRYPTED : hello, OpenSSL! 123456789012345

感想

Camellia暗号も内蔵モジュールに含まれている node.js すごい。
以上
参考
【Node.js】cryptを使って共通鍵暗号方式の使い方
CamelliaをC言語に組み込むまで




このブログの人気の投稿

記述試験の書き方(仮)

記述試験の書き方(仮) 1,まえがき   法学部の試験では記述式の試験が出てくる。   その試験では、あるテーマについて自由に論ぜよとされている。 しかし、論ぜよと言われても、どのように論じればいいのか、すなわち、記述の仕方について教わったことがない(よくよく考えると、法的文章力を習得させる事だけが目的の授業はないと思われる)。   本稿では、私自身が法学畜になり、見聞きし、実際に活用している論述方法についてまとめている、はずである。その要点は、①条文、判例、学説を使う。②単なる事実と法的事実を区別する。③文章内に一貫性を持たせる。である。 法律と、プログラミング

本サイトの今後について

告知 本サイトは今後更新されることは、おそらくありません。 過去記事等はこのまま放置するつもりです。内容の陳腐化並びにその正確性等については保証はできません。自己責任で活用いただければと思います。 This site won't update in future. And Thank's everyone. new site -> sysrigar

node.js で SQLite3 を使用するコードを書くときの予備録

node.js で SQLite3 を使用するコードを書くとき、予備録 まず、非同期処理。 C言語や Perl のように上から下に処理が続くと決して思ってはいけない。 SQLite3 の each は SQL 文実行完了時に呼び出す関数を指定できる SQLite をインストールします、 npm install sqlite3 [test.js] var sqlite3 = require('sqlite3').verbose(); var db = new sqlite3.Database(':memory:'); db.serialize(function() { db.run("CREATE TABLE lorem (info TEXT)"); var stmt = db.prepare("INSERT INTO lorem VALUES (?)"); for (var i = 0; i < 10; i++) { stmt.run("Ipsum " + i); } stmt.finalize(); var listInfo = new Array(); db.each("SELECT rowid AS id, info FROM lorem", function(err, row) { var tmp = new Object(); tmp.id = row.id; tmp.info = row.info; console.log("[ROW]\t" + row.id + ": " + row.info); listInfo.push(tmp); }, function() { // Each 完了時に呼び出される for (var i = 0; i < listInfo.length; i++) { console.log("[BUF]\t" + listInfo[i].id + ": " + listInfo[i].info); } console.lo