文档资料库PHP

问题描述

| 这篇文章更多是为了获得建议和想法,而不是解决问题。有点难以解释,但我会尽力而为。 我有一个文档存储库,其中包含一个带有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
    

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...