【发布时间】:2015-08-07 20:22:24
【问题描述】:
我的应用收到一个同样经过加密的 base64 编码值。数据可以以几种不同的方式出现,所以我想创建可链接的方法来保持代码的干净和模块化。
我希望能够写:decryptionChain.decodeBase64(b64Value).stringToBuffer().finallyDecrypt();
当我运行代码时,最后一个属性方法“finallyDecrypt”返回为未定义。
为什么“finallyDecrypt”方法返回为未定义?其余的一切正常,如果我运行encryptionChain.decodeBase64(b64Value).stringToBuffer(),我会得到我期望的缓冲区。只有当finallyDecrypt 被链接时,我才会出错。
代码如下:
function decrypt(encrypted) {
var decipher = crypto.createDecipheriv(algorithm, password, iv);
decipher.setAuthTag(encrypted.tag);
var dec = decipher.update(encrypted.content, 'hex', 'utf8');
dec += decipher.final('utf8');
return dec;
}
var decryptionChain = {
currentValue:"",
decodeBase64: function (encryptedValue){
this.currentValue = new Buffer(encryptedValue.toString(), "base64");
return this;
},
stringToBuffer: function() {
if (this.currentValue) {
myBuffer = JSON.parse(this.currentValue, function (key, value) {
return value && value.type === 'Buffer'
? new Buffer(value.data)
: value;
});
}
return myBuffer;
},
finallyDecrypt : function(myBuffer){
if(myBuffer){
decrypt(myBuffer);
}
return this;
}
};
【问题讨论】:
标签: javascript method-chaining chain