为了账号安全,请及时绑定邮箱和手机立即绑定

如何更改表格内容而不是转到目录

如何更改表格内容而不是转到目录

PHP
SMILET 2021-12-03 14:36:32
我完成了一个列出当前目录的表格。我希望的是,当我单击目录时,表格会刷新并加载目录的内容,而不是转到实际目录。我应该使用的正确代码是什么?<?phpfunction view_size($size){    if($size >= 1073741824)    {        $size = @round($size / 1073741824 * 100) / 100 . " GB";    }    elseif($size >= 1048576)    {        $size = @round($size / 1048576 * 100) / 100 . " MB";    }    elseif($size >= 1024)    {        $size = @round($size / 1024 * 100) / 100 . " KB";    }    else    {        $size = $size . " B";    }    return $size;}function dirlist(){    $myDirectory = opendir(".");    while($entries = readdir($myDirectory))    {        $dirListArray[] = $entries;    }    $fileCount = count($dirListArray);    sort($dirListArray);    print("<p style='color:#CCC;padding:0px;margin:5px;'>$fileCount FILES / FOLDER FOUND</p>");    print("<table style='color:#FFF' width=100% border=1 cellpadding=5 cellspacing=0 class=whitelinks>\n");    print("<tr><th>FILE/FOLDER NAME</th><th>FILE TYPE</th><th>FILE SIZE</th></tr>");    for($index=0;$index<$fileCount;$index++)    {        print("<tr><td><a href='./$dirListArray[$index]/.'>$dirListArray[$index]</a></td>");        print("<td>");        print(filetype($dirListArray[$index]));        print("</td>");        print("<td>");        print(view_size(filesize($dirListArray[$index])));        print("</td>");        print("</tr>\n");    }    print("</table>");}?><html><head><style type="text/css">#directory-list-container {    margin: 7px;    padding: 0px;    border: 3px solid #000;    outline: 1px solid #666;}#directory-list-content {    margin: 0px;    padding: 5px;    border: 2px solid #666;}#directory-list-content a {    color: #FFF;    text-decoration: none;}#directory-list-container a:link {    color: #FFF;    text-decoration: none;}#directory-list-container a:hover {    color: #0F0;    text-decoration: none;}#directory-list-container a:active {    color: #090;    text-decoration: none;}它显示为一个表格,但是当我单击目录或文件时,它会转到该目录或打开文件而不是刷新表格以列出我单击的目录。
查看完整描述

1 回答

?
翻翻过去那场雪

TA贡献2065条经验 获得超14个赞

当您单击一个链接时,它会在您的浏览器中导航,除非您在服务器上设置了 URL 重写,否则将加载该 URL 上的任何内容。您需要使用 GET(查询)参数将您选择的目录传递给您的 PHP 文件,并在显示锚点时使用它。


我对下面的代码有一些自由,但我相信它可以满足您的需求。脚本的名称是从从任何查询参数中剥离的当前 URL 中读取的,并且dir查询参数用于将文件夹名称传递给锚点中的脚本。将这些结合起来,URL 看起来像这样,具体取决于您如何运行它:


/folder/script.php?dir=foldername%2Ffolder2

请注意,该值是 URL 编码的,这通常是一种很好的做法,每当您将任意字符串作为查询参数传递时。在下面的代码中,文件名输出也包含在htmlspecialchars()其中转义浏览器可能识别为标记并尝试解析的任何 HTML 字符,从而导致页面分崩离析。


为了增加安全性,我调用了在运行时ini_set将open_basedir设置更改为当前目录的调用,以避免目录遍历攻击,例如?dir=../../../../etc/passwd可用于访问敏感系统信息的攻击。虽然不是您最初的要求,但我相信这也应该在您的情况下处理,我强烈建议保留此安全措施。


此外,还对点文件(.和..)进行了一些处理,以确保未列出当前目录,并且您无法从基本目录向上导航。


我还使用HEREDOC使代码比多次调用print. 随之而来的唯一小不便是您不能在字符串中放入太复杂的表达式,因此您必须将它们移动到上面的变量中,但我相信这也有助于提高可读性。


<?php


// Credit to http://jeffreysambells.com/2012/10/25/human-readable-filesize-php

function human_file_size($bytes, $decimals = 2) {

  $size = array('B', 'KB', 'MB', 'GB');

  $factor = (int)floor((strlen($bytes) - 1) / 3);


  return round($bytes / pow(1024, $factor), 2).' '.@$size[$factor];

}


function dirlist() {

  // Prevent malicious users from reading files in directories above

  ini_set('open_basedir', __DIR__);


  $baseDirectory = '.'.DIRECTORY_SEPARATOR;

  // Get directory from query parameter

  $directoryPath = $baseDirectory.(!empty($_GET['dir']) ? rtrim($_GET['dir'], '\\/').DIRECTORY_SEPARATOR : '');

  $myDirectory = opendir($directoryPath);

  $isTopLevel = $directoryPath === $baseDirectory;


  while ($entry = readdir($myDirectory)){

    if ($entry === '.' || ($isTopLevel && $entry === '..')){

      continue;

    }

    $dirListArray[] = $entry;

  }


  $fileCount = count($dirListArray);

  sort($dirListArray);

  print <<<HTML

    <p class="heading">$fileCount FILES / FOLDER FOUND</p>


    <table width="100%" border="1" cellpadding="5" cellspacing="0" class="whitelinks">

      <tr>

          <th>FILE/FOLDER NAME</th>

          <th>FILE TYPE</th>

          <th>FILE SIZE</th>

      </tr>

HTML;


  // Get current URL without query parameters

  // Trim everything after and including "?"

  $scriptPath = strtok($_SERVER['REQUEST_URI'], '?');


  foreach ($dirListArray as $indexValue){

    $htmlEncodedIndex = htmlspecialchars($indexValue);

    $fileType = filetype($directoryPath.$indexValue);

    $fileSize = human_file_size(filesize($directoryPath.$indexValue));

    if ($fileType === 'dir'){

      if ($indexValue === '..'){

        // Link to top level, no rectory separator in string

        if (strpos($indexValue, DIRECTORY_SEPARATOR) === false)

          $queryParam = '';

        // Link to subdirectory

        else {

          $parts = explode(DIRECTORY_SEPARATOR, $indexValue);

          array_pop($parts);

          // Assemble query param (make sure to URL encode!)

          $queryParam = '?dir='.urlencode(implode(DIRECTORY_SEPARATOR, $parts));

        }

      }

      // Assemble query param (make sure to URL encode!)

      else $queryParam = '?dir='.urlencode($indexValue);

      $href = $scriptPath.$queryParam;

    }

    else $href = $directoryPath.$indexValue;


    print <<<HTML

      <tr>

        <td>

          <a href='$href'>$htmlEncodedIndex</a>

        </td>

        <td>$fileType</td>

        <td>$fileSize</td>

      </tr>

HTML;

  }


  print '</table>';

}


?>

<!DOCTYPE html>

<html>

<head>


  <style type="text/css">

    .heading {

      color: #CCC;

      padding: 0;

      margin: 5px;

    }

    #directory-list-container {

      margin: 7px;

      padding: 0;

      border: 3px solid #000;

      outline: 1px solid #666;

    }


    #directory-list-content {

      margin: 0;

      padding: 5px;

      border: 2px solid #666;

    }


    #directory-list-content a,

    #directory-list-container a:link {

      color: #00f;

      text-decoration: none !important;

    }

    #directory-list-container a:hover {

      color: #0F0;

    }

    #directory-list-container a:active {

      color: #090;

    }

    #directory-list-container a:visited {

      color: #DDD;

    }

  </style>


</head>

<body>

<div id="directory-list-container">

  <div id="directory-list-content">

    <?php dirlist(); ?>

  </div>

</div>

</body>

</html>


查看完整回答
反对 回复 2021-12-03
  • 1 回答
  • 0 关注
  • 190 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号