Browse Source

Better Way to Detect Mflac Mask

20230320
MengYX 5 years ago
parent
commit
27b74ea5dd
No known key found for this signature in database GPG Key ID: E63F9C7303E8F604
  1. 66
      src/decrypt/mflac.js

66
src/decrypt/mflac.js

@ -29,7 +29,7 @@ async function Decrypt(file, raw_filename, raw_ext) {
// 读取Meta // 读取Meta
let tag = await musicMetadata.parseBlob(musicData); let tag = await musicMetadata.parseBlob(musicData);
const info = util.GetFileInfo(tag.common.artist, tag.common.title, raw_filename); const info = util.GetFileInfo(tag.common.artist, tag.common.title, raw_filename);
reportKeyInfo(new Uint8Array(fileBuffer.slice(-0x170)), seed.mask, reportKeyInfo(new Uint8Array(fileBuffer.slice(-0x170)), seed.mask128,
info.artist, info.title, tag.common.album, raw_filename); info.artist, info.title, tag.common.album, raw_filename);
// 返回 // 返回
@ -51,38 +51,56 @@ class Mask {
constructor() { constructor() {
this.index = -1; this.index = -1;
this.mask_index = -1; this.mask_index = -1;
this.mask = new Uint8Array(128); this.mask128 = new Uint8Array(128);
this.mask58_martix = new Uint8Array(56);
this.mask58_super1 = 0x00;
this.mask58_super2 = 0x00;
} }
DetectMask(data) { DetectMask(data) {
let search_len = data.length - 256, mask; let search_len = Math.min(0x8000, data.length), mask;
for (let block_idx = 0; block_idx < search_len; block_idx += 128) { for (let block_idx = 0; block_idx < search_len; block_idx += 128) {
let flag = true;
mask = data.slice(block_idx, block_idx + 128); mask = data.slice(block_idx, block_idx + 128);
let next_mask = data.slice(block_idx + 128, block_idx + 256); const mask58 = this.Convert128to58(mask);
for (let idx = 0; idx < 128; idx++) { if (mask58 === undefined) continue;
if (mask[idx] !== next_mask[idx]) {
flag = false; if (!FLAC_HEADER.every((val, idx) => {
break; return val === mask[idx] ^ data[idx];
} })) continue;
}
if (!flag) continue; this.mask128 = mask;
this.mask58_martix = mask58.matrix;
for (let test_idx = 0; test_idx < FLAC_HEADER.length; test_idx++) { this.mask58_super1 = mask58.super_8_1;
let p = data[test_idx] ^ mask[test_idx]; this.mask58_super2 = mask58.super_8_2;
if (p !== FLAC_HEADER[test_idx]) {
flag = false;
//todo: Check this
break;
}
}
if (!flag) continue;
this.mask = mask;
return true; return true;
} }
return false; return false;
} }
Convert128to58(mask128) {
const super_8_1 = mask128[0], super_8_2 = mask128[8];
let matrix = [];
for (let row_idx = 0; row_idx < 8; row_idx++) {
const len_start = 16 * row_idx;
const len_right_start = 120 - len_start;//16*(8-row_idx-1)+8
if (mask128[len_start] !== super_8_1 || mask128[len_start + 8] !== super_8_2) {
return
}
const row_left = mask128.slice(len_start + 1, len_start + 8);
const row_right = mask128.slice(len_right_start + 1, len_right_start + 8).reverse();
if (row_left.every((val, idx) => {
return row_right[idx] === val
})) {
matrix.push(row_left);
} else {
return
}
}
return {matrix, super_8_1, super_8_2}
}
NextMask() { NextMask() {
this.index++; this.index++;
this.mask_index++; this.mask_index++;
@ -93,7 +111,7 @@ class Mask {
if (this.mask_index >= 128) { if (this.mask_index >= 128) {
this.mask_index -= 128; this.mask_index -= 128;
} }
return this.mask[this.mask_index] return this.mask128[this.mask_index]
} }
} }

Loading…
Cancel
Save