Request zu api von mega.nz, Parse-URL für den privaten Schlüssel des Ordners, und versuchen, Namen von Dateien von Responde der Anfrage zu entschlüsseln, durch Krypto von Nodejs.erhalten Namen Dateien eines Mega.nz-Ordners in Nodejs
Mein Code:
const crypto = require('crypto')
const parse = require('url').parse
const request = require('request')
const link = 'https://mega.nz/#F!gE5WkDpS!Yh6AQtYHPgi-rEkir_gAEw'
const api = 'https://eu.api.mega.co.nz/cs?id=-1771463320&n=MBwjmCqR'
function d64 (s) {
s += '=='.substr((2 - s.length * 3) & 3)
s = s.replace(/-/g, '+').replace(/_/g, '/').replace(/,/g, '')
return new Buffer(s, 'base64')
}
function from256to128 (s) {
var o = new Buffer(16)
for (var i = 0; i < 16; i++) {
o[i] = s[i]^s[i + 16]
}
return o
}
function decodeName (at) {
var end = at.length
while (!at.readUInt8(end - 1)) end--
return at.slice(0, end).toString()
}
const url = parse(link)
const split = url.hash.split('!')
const k0 = d64(split[2])
request({
method: 'POST', uri: api, body: '[{"a":"f","c":1,"r":1,"ca":1}]'
}, (e, r, b) => {
if (!e && r.statusCode === 200) {
for (let file of JSON.parse(b)[0].f) {
if (file.t === 1) {
let k = d64(file.k.split(':')[1])
let a = d64(file.a)
let aes = crypto.createDecipheriv('aes-128-ecb', k0, Buffer(0))
aes.setAutoPadding(false)
let kdec = aes.update(k)
aes = crypto.createDecipheriv('aes-128-cbc', kdec, Buffer(16))
aes.setAutoPadding(false)
let name = decodeName(aes.update(a))
console.log(name)
} else {
let k = d64(file.k.split(':')[1])
let a = d64(file.a)
let aes = crypto.createDecipheriv('aes-128-ecb', k0, Buffer(0))
aes.setAutoPadding(false)
let k2dec = from256to128(aes.update(k))
aes = crypto.createDecipheriv('aes-128-cbc', k2dec, Buffer(16))
aes.setAutoPadding(false)
let name = decodeName(aes.update(a))
console.log(name)
}
}
}
})
Meine Ausgabe gebrochener Text, ich ändern url versuchen und mehr gebrochen Text erhalten:
�MzM�ݾ��+,�BW���p�K����
Sie fordern Informationen für den Ordner 'MBwjmCqR' an und versuchen, ihn mit dem Schlüssel' gE5WkDpS' zu entschlüsseln. Aber es scheint nicht das einzige Problem zu sein. –
Das Problem gefunden: Verwenden Sie den richtigen Schlüssel (wie oben erwähnt) und verwenden Sie 'Buffer.alloc (0)' und 'Buffer.alloc (16)' anstelle von 'Buffer (0)' und 'Buffer (16)'. –