问题描述
|
这篇文章更多是为了获得建议和想法,而不是解决问题。有点难以解释,但我会尽力而为。
我有一个文档存储库,其中包含一个带有PDF的唯一目录,这些文档必须在\“ virtual \\”文件夹中显示给最终用户,因为它们在许多文件夹中必须可见。我所谓的虚拟文件夹是文件系统中目录的正常层次结构,但是最终文档必须来自前面提到的PDF存储库。
例子 :
repo/{dozens of PDF}
rootfolder/sub-folder1/sub-folder11/contracts1.PHP
/sub-folder2/contracts1.PHP
/sub_folder3/sub-folder31/contracts2.PHP
/sub_folder4/sub-folder41/sub-folder42/sub-folder43/contracts3.PHP
/sub-folder5/contracts5.PHP
那是我老板想尽快准备好的一个项目,所以此刻,我一直在使用PHP-file-tree,它生成了一种类似树的方式来浏览文件夹,每个文件夹中的最终文件是一个带有PDF列表的PHP文件。效果很好,但是对于每一次更改,我都需要编辑那些PHP文件,将来,此任务应该由其他人(对HTML / PHP编辑一无所知的办公室用户)以简单的方式完成。
你们会推荐我什么?
2件重要的事情是:
PDF文件必须在一个文件中
位置,单个目录
最终用户必须看到一个类似树的页面
谢谢。
法比恩
解决方法
免责声明:这可能有点多,但是无论如何它也许很有用。
他们以这种方式我会做到:
将ExtJs与Ext.tree.Panel一起使用(其中一棵树是pdf的来源,第二棵树是虚拟目录)
将最终的树存储在数据库或xml文件中
为办公室用户构建一个迷你管理员gui
为最终用户构建一个视图,仅显示虚拟目录树及其pdf。
, 我将目录树设置为真正的虚拟树,即不是在文件系统中创建目录树,而是在数据库中创建目录树。文件列表也将在DB中(即DB中的文件名,文件-在文件系统上)。另一个数据库表将用于将文件链接到目录。
create table file (
id integer primary key,name varchar(64) not null
) engine = InnoDB;
create table directory (
id integer primary key,parent_id integer,name varchar(64) not null
) engine = InnoDB;
create table file_in_directory (
file_id integer not null,directory_id integer not null,primary key (file_id,directory_id)
) engine = InnoDB;
insert into directory (id,parent_id,name) values
(1,null,\'rootfolder\'),(2,1,\'sub-folder1\'),(3,\'sub-folder2\'),(4,\'sub-folder3\'),(5,\'sub-folder4\'),(6,\'sub-folder5\'),(7,2,\'sub-folder11\'),(8,4,\'sub-folder31\'),(9,5,\'sub-folder41\'),(10,9,\'sub-folder42\'),(11,10,\'sub-folder43\');
insert into file (id,\'contracts1.php\'),\'contracts2.php\'),\'contracts3.php\'),\'contracts5.php\');
insert into file_in_directory (file_id,directory_id) values
(1,7),-- rootfolder/sub-folder1/sub-folder11/contracts1.php
(1,3),-- rootfolder/sub-folder2/contracts1.php
(2,8),-- rootfolder/sub_folder3/sub-folder31/contracts2.php
(3,11),-- rootfolder/sub_folder4/sub-folder41/sub-folder42/sub-folder43/contracts3.php
(4,6); -- rootfolder/sub-folder5/contracts5.php