8

我最近开始开发一个相当大的网站。在网站上,我想允许用户上传他们的样本作品。我们目前非常有限,因此图像将存储在我们的服务器上。

我有点坚持逻辑。所以我的逻辑是这样的。

用户创建一个文件夹,其名称存储在数据库中,users id并附有附件

文件夹表

id | folder        | user_id 
1  | Some folder   | 1
2  | New folder    | 4
3  | Nother folder | 7

图像表

id | image_name        | folder_id |
1  | image1.jpg        | 1
2  | image2.jpg        | 1
3  | image3.jpg        | 1
4  | image4.jpg        | 2
5  | image5.jpg        | 2
6  | image6.jpg        | 2

关系

class Folder extends Eloquent 
{
    public function images()
    {
        return static::has_many('Images');
    }
}

class Image extends Eloquent 
{
    public function folder()
    {
        return static::belongs_to('Folder');
    }
}

服务器上的文件夹结构

- samples
  -user_id
   - folder_id
     - image1
     - image2
     - image3

如您所见,用户创建了一个文件夹,创建文件夹后,user将图像名称上传到数据库中folders id,并显示图像将是上面描述的方式。

所以我的问题。

  • 你认为这是一个很好的逻辑吗
  • 这会导致将来出现问题吗
  • 你会为这个功能提供什么

我最神圣的是两件事。

我认为这将导致一个巨大的数据库,其次是id's,在 x 次之后会有更多的用户,id's会增加,我知道这听起来很奇怪,但是由于很多用户会上传图片会导致巨大的 id,我的意思是它可能会达到数百万,有没有办法解决这个问题?

感谢您的帮助

4

2 回答 2

19

好的-让我们将其分解为几个子答案;

问题:

- Is this a good logic in your opinion
- Can this lead problems in the future
- What would you offer for this functionality

回答:

逻辑似乎听起来 - 但我很好奇你会将图像存储在哪里在 public_html 内部 - 还是在 Web 根目录之外?如果您在 public_html 中有图像 - 并允许浏览器直接访问它们,它将允许用户“猜测”其他用户文件夹并访问这些文件夹。您需要安全地存储数据。

要在 webroot 之外制作图像,并确保只有授权用户可以访问它们 - 您应该使用readfile()。像这样的东西可以解决问题

function user_file($file_name = "")
{
    if ($file_name)
    {
         // Ensure no funny business names to prevent directory transversal etc.
         $file_name = str_replace ('..', '', $file_name);
         $file_name = str_replace ('/', '', $file_name);

         // now do the logic to check user is logged in
         if (Auth::check())
         {
                // Serve file via readfile() - we hard code the user_ID - so they
                // can only get to their own images
               readfile('../your_app/samples/'.Auth::user()->id.'/'.$file);
         }
    }
}

问题:

我认为这会导致一个巨大的数据库,其次是 id 的,x 次之后会有更多的用户,id 会增加,我知道这听起来很奇怪,但是由于很多用户会上传图片会导致巨大的id,我的意思是它可能会达到数百万

回答:

根据mySQL 功能页面

我们将 MySQL 服务器与包含 5000 万条记录的数据库一起使用。我们还知道使用 MySQL 服务器的用户有 200,000 个表和大约 5,000,000,000 行。

所以那是 50 亿行。你可能会得到几百万。所以你在这里是安全的(取决于你的硬件)。

问题:

...但是由于很多用户会上传图片会导致巨大的 id,我的意思是它可能会达到数百万,有没有办法解决这个问题?

回答:

如果您不想存储数百万条记录,并且担心性能,一种选择是保留文件夹表,但删除图像表。相反,您可以在文件夹上使用scandir() - 并让 PHP 从目录本身检索文件名。那么你就没有那么多开销了。

<?php
    $list_of_user_files = scandir("$user_id/$folder_id");
    foreach ($list_of_user_files as $file) {
          echo "File: $file <br>";
    }
?>
于 2013-02-07T13:20:53.767 回答
1

存储文件夹表和使用scandir函数的方法是一个标准的过程。并允许 php 从文件夹中检索文件名。如果您有许多文件,请尝试使用 wordpress 中的年月顺序对它们进行分类。像

2012
  01
  02
  03
2013
  01
  02
  03 

文件夹ID内的等。所以一个文件夹中的图像总数会相对较少。

于 2013-02-11T15:56:08.827 回答