我的问题是:如何成功使用Evernote API的方法getResourceByHash(...)
?
我做了什么:
我在注释内容中获得了em-media的十六进制哈希:80ad525cd14de8f925487c02afc9ab21
然后我使用以下函数将十六进制String
转换为字节:
function hex2bin(hex){
var bytes = [];
for(var i=0; i< hex.length-1; i+=2) {
bytes.push(parseInt(hex.substr(i, 2), 16));
}
return String.fromCharCode.apply(String, bytes);
}
var bin = hex2bin("80ad525cd14de8f925487c02afc9ab21");
接下来,我以这种方式将变量应用于函数getResourceByHash(...)
:
noteStore.getResourceByHash(GUID, bin, true, true, true,
function(err,result){
console.log(err);
console.log(result);
}
);
但输出结果是:
{identifier: 'Resources', key: 'c280c2ad525cc3914dc3a8c3b925487c02c2afc389c2ab21'}
undefined
总之,我很困惑。
答案 0 :(得分:5)
此外,您不能简单地将类型Integer
的值推送到字节数组。整数用32位(4字节)表示,所以你首先必须&#34; split&#34;在逐个计算单个字节时这样的数字:
intToByteArray = function(intToConvert) {
var byteArray = new Array(4)
for(var i = 0; i < byteArray.length; i++) {
var byte = intToConvert & 0xff;
byteArray[i] = byte;
intToConvert = (intToConvert - byte) / 256 ;
}
return byteArray;
};
Demonstration of back and forth conversion (JS-Fiddle)
首先,我们声明一个字节数组:
var byteArray = new Array(4)
数组:[00000000,00000000,00000000,00000000]
使用bit-wise AND
operator &
,我们&#34;捕获&#34;将结果值分配给新变量时的前8位:
var byte = intToConvert & 0xff;
我们的变量发生了什么:
intToConvert: 10101010 10101010 10101010 10101010
AND "0xff": 11111111 -------- -------- --------
Results in: 10101010
然后,我们将得到的单个字节放到临时字节数组的实际索引中:
byteArray[i] = byte;
数组:[10101010,00000000,00000000,00000000]
现在,我们只需要减去刚刚添加到数组中的值,并从整数变量中删除一个字节:
intToConvert = (intToConvert - byte) / 256 ;
2863311530 - 170 = 2863311360
2863311360/256 = 111848102863311360 => 10101010 10101010 10101010 00000000 11184810 => 10101010 10101010 10101010
继续此循环将逐字节地从整数传输到临时字节数组。因此,我们将获得一个包含4个单字节的字节数组,表示十六进制Character
的一个整数或两个String
。
如何将byte
转换为Integer
is well explained here
因此,您更新的hex2bin(String)
应如下所示:
function hex2bin(hexString) {
var bytes = new Array(hexString.length / 2);
for(var i = 0; i < hexString.length-1; i+=2) {
bytes.push(
intToByteArray(
parseInt(hexString.substr(i, 2), 16)
)
);
}
StringBuilder sb = new StringBuilder(bytes.length * 8);
for(byte b : bytes) {
sb.append(Integer.toBinaryString((b & 0xFF) + 0x100).substring(1));
}
return sb.toString();
}