[英]How to extract embedded files from pdf using MuPDF
我在iOS上的應用從PDF提取嵌入式文件。 現在,我嘗試使用MuPDF使Android應用程序具有相同的功能。
在iOS上,我可以使用Quartz2d提取嵌入式文件:
CGPDFDocumentGetCatalog
) NSData
並保存。 MuPDF有什么辦法做到這一點?
基於pdfextact.c的解決方案看起來像蠻力的,但它的工作原理是:
pdf_load_object
) isembed
) saveembed
) 在大多數測試案例中,嵌入式文件存儲在文件末尾,因此,reverce迭代具有意義。
static int isembed(pdf_obj *obj) {
pdf_obj *type = pdf_dict_gets(obj, "Type");
return pdf_is_name(type) && !strcmp(pdf_to_name(type), "Filespec");
}
static void saveembed(pdf_obj *dict) {
char *filename;
pdf_obj *obj = pdf_dict_gets(dict, "F");
if (obj) filename = pdf_to_str_buf(obj);
obj = pdf_dict_gets(dict, "EF");
if (!obj) return;
pdf_obj *stream = pdf_dict_gets(obj, "F");
if (!stream) return;
FILE *f;
fz_buffer *buf;
int n, len;
unsigned char *data;
buf = pdf_load_stream(doc, pdf_to_num(stream), pdf_to_gen(stream));
printf("extracting embedded file %s\n", filename);
f = fopen(filename, "wb");
len = fz_buffer_storage(ctx, buf, &data);
n = fwrite(data, 1, len, f);
fclose(f);
fz_drop_buffer(ctx, buf);
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.