index.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. <?php
  2. require('functions.php');
  3. ?>
  4. <!DOCTYPE html>
  5. <html lang="de">
  6. <head>
  7. <meta charset="utf-8">
  8. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  9. <meta name="viewport" content="width=device-width, initial-scale=1">
  10. <title>WebVideoViewer</title>
  11. <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css" integrity="sha512-dTfge/zgoMYpP7QbHy4gWMEGsbsdZeCXz7irItjcC3sPUFtf0kuFbDz/ixG7ArTxmDjLXDmezHubeNikyKGVyQ==" crossorigin="anonymous">
  12. <style>
  13. .col-sm-3 > div > a > img {
  14. width: 100%;
  15. }
  16. .col-sm-3 {
  17. padding-bottom: 15px;
  18. min-height: 500px;
  19. }
  20. .image-zoom {
  21. overflow: hidden;
  22. }
  23. .image-zoom img {
  24. -webkit-transition: all 1s ease; /* Safari and Chrome */
  25. -moz-transition: all 1s ease; /* Firefox */
  26. -ms-transition: all 1s ease; /* IE 9 */
  27. -o-transition: all 1s ease; /* Opera */
  28. transition: all 1s ease;
  29. }
  30. .image-zoom:hover img {
  31. -webkit-transform:scale(1.15); /* Safari and Chrome */
  32. -moz-transform:scale(1.15); /* Firefox */
  33. -ms-transform:scale(1.15); /* IE 9 */
  34. -o-transform:scale(1.15); /* Opera */
  35. transform:scale(1.15);
  36. }
  37. </style>
  38. </head>
  39. <body>
  40. <div class="container-fluid">
  41. <?php
  42. $CONFIG = array(
  43. "paths" => array(
  44. "/media/Serien",
  45. "/media/Filme"
  46. )
  47. );
  48. if(!isset($_GET['path']) || !$_GET['path']) {
  49. foreach($CONFIG['paths'] as $path) {
  50. $folderName = split('/', $path);
  51. echo "<h1>" . $folderName[sizeof($folderName) - 1] . "</h1>";
  52. $list = scandir($path);
  53. $list = array_diff($list, array('.', '..'));
  54. echo "<div class=\"row\">";
  55. foreach($list as $object) {
  56. echo "<div class=\"col-sm-3\"><div class=\"image-zoom\">";
  57. echo "<a href=\"?path=" . $path . "/" . $object . "\">" . "<img class=\"img-responsive\" src=\"" . getImageByName($path . "/" . $object) . "\" alt=\"" . $object . "\">" . "</a><br>";
  58. echo "</div></div>";
  59. }
  60. echo "</div>";
  61. }
  62. } else {
  63. $_GET['path'] = str_replace('/..', '', $_GET['path']);
  64. $_GET['path'] = str_replace('../', '', $_GET['path']);
  65. $_GET['path'] = str_replace('..', '', $_GET['path']);
  66. echo "<h1>" . $_GET['path'] . "</h1>";
  67. if(is_dir($_GET['path'])) {
  68. $list = scandir($_GET['path']);
  69. $list = array_diff($list, array('.'));
  70. echo "<div class=\"row\">";
  71. foreach($list as $object) {
  72. if($object == "..") {
  73. if(in_array($_GET['path'], $CONFIG['paths'])) {
  74. echo "<a href=\"?path=\">Home</a><br>";
  75. } else {
  76. $paths = explode('/', $_GET['path']);
  77. $paths = array_diff($paths, array($paths[sizeof($paths) - 1]));
  78. $pathv = "";
  79. foreach($paths as $key => $path) {
  80. if($key == sizeof($paths) - 1) {
  81. $pathv .= $path;
  82. } else {
  83. $pathv .= $path . "/";
  84. }
  85. }
  86. echo "<a href=\"?path=" . $pathv . "\">" . $object . "</a><br>";
  87. }
  88. } else {
  89. echo "<div class=\"col-sm-3\"><div class=\"image-zoom\">";
  90. echo "<a href=\"?path=" . $_GET['path'] . "/" . $object . "\">" . "<img class=\"img-responsive\" src=\"" . getImageByName($_GET['path'] . "/" . $object) . "\" alt=\"" . $object . "\">" . "</a><br>";
  91. echo "</div></div>";
  92. }
  93. }
  94. echo "</div>";
  95. } else {
  96. $paths = explode('/', $_GET['path']);
  97. $paths = array_diff($paths, array($paths[sizeof($paths) - 1]));
  98. $pathv = "";
  99. foreach($paths as $key => $path) {
  100. if($key == sizeof($paths) - 1) {
  101. $pathv .= $path;
  102. } else {
  103. $pathv .= $path . "/";
  104. }
  105. }
  106. $mime = explode(';', finfo_file(finfo_open(FILEINFO_MIME), $_GET['path']));
  107. echo "<a href=\"?path=" . $pathv . "\">Back</a> | <a href=\"readfile.php?file=" . $_GET['path'] . "\">Download</a><br>";
  108. echo "<video width=\"auto\" height=\"auto\" controls>";
  109. echo "<source src=\"readfile.php?file=" . $_GET['path'] . "\" type=\"" . $mime[0] . "\">";
  110. echo "Your browser does not support the video tag.";
  111. echo "</video>";
  112. }
  113. }
  114. ?>
  115. </div>
  116. <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
  117. <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js" integrity="sha512-K1qjQ+NcF2TYO/eI3M6v8EiNYZfA95pQumfvcVrTHtwQVDG+aHRqLi/ETn2uB+1JqwYqVG3LIvdm9lj6imS/pQ==" crossorigin="anonymous"></script>
  118. </body>
  119. </html>