Запустите PHP-Файл По Нажатию Кнопки


Интересно, может ли кто-нибудь мне помочь, пожалуйста.

Я просматривал этот и многие другие сайты и учебные пособия, чтобы узнать, как добавить кнопку в форму, которая открывает файл PHP, в данном случае всплывающую форму, которая позволяет пользователю загружать файл в базу данных MySQL.

В дополнение к открытию файла я хотел бы перенести значение поля "идентификатор" из основной формы в всплывающую форму "Загрузка файла".

Из исследования, которое я провел, кажется, что есть несколько способов сделать это, но с точки зрения новичков я не уверен, что это лучший способ сделать это.

Не мог бы кто-нибудь, пожалуйста, посоветовать, как лучше всего это сделать.

Большое спасибо и наилучшие пожелания

Author: IRHM, 2011-12-18

2 answers

Для передачи значений между страницами:

Основная форма:

<form action="myuploadform.php" method="get">
ID: <input type="text" name="id">
<input type="submit" value="Open Form">
</form>

Значение текстового поля идентификатора будет доступно как $_GET['id'] в myuploadform.php.

Использование параметров GET является самым простым способом передачи значений. Другой способ передать это значение GET был бы в URL:

.../myuploadform.php?id=35 где идентификатор затем становится 35.

 3
Author: Tim, 2011-12-18 16:29:13

Вот пример с моего сайта. Все, что он делает, - это позволяет загружать файлы на сервер. Это должно послужить учебным пособием.

<html>
<head>
<script type="text/javascript">
var form_object = null;
var button_object = null;

function submit_form(obj)
         {
         form_object = obj.parentNode;
         form_object.submit();
         form_object.disabled = true;

         button_object = obj;
         button_object.disabled = true;
         }

function enable_form()
         {
         form_object.disabled = false;
         button_object.disabled = false;
         }

function Add_HTML(html)
         {
         if(navigator.appName == 'Microsoft Internet Explorer')
           {
           document.body.insertAdjacentHTML('beforeEnd', html);
           }

           //Firefox uses the Netscape engine (the Netscape version that really sucked)
           if(navigator.appName == 'Netscape' && parseInt(navigator.appVersion) == 5)
             {
             var freaky_object = document.createRange();
             freaky_object.setStartBefore(document.body);
             html = freaky_object.createContextualFragment(html);
             document.body.appendChild(html);
             }
         }
</script>
</head>

<body>

    <form action="upload.php" method="post" enctype="multipart/form-data" target="upload">
          <label>File:</label> <input type="file" name="file" />
          <br />
          <label>File:</label> <input type="file" name="swntic" />
          <br />
          <input type="button" value="SUBMIT"
                 onclick="submit_form(this);" />
    </form>

    <iframe src="about:blank" style="display:none;" id="upload" name="upload"></iframe>

</body>
</html>

Код на стороне сервера:

<?
$confirmation = "";

while(list($name) = each($HTTP_POST_FILES)) {
?>

<? if(is_uploaded_file($HTTP_POST_FILES[$name]["tmp_name"])) { ?>
<?= $HTTP_POST_FILES[$name]["name"] ?>
<br />
<?= $HTTP_POST_FILES[$name]["type"] ?>
<br />
<?= $HTTP_POST_FILES[$name]["tmp_name"] ?>
<br />
<?= $HTTP_POST_FILES[$name]["error"] ?>
<br />
<?= $HTTP_POST_FILES[$name]["size"] ?>
<br /><br />
<? } ?>

<?
if(is_uploaded_file($HTTP_POST_FILES[$name]["tmp_name"]))
  {
  move_uploaded_file($HTTP_POST_FILES[$name]["tmp_name"], "./uploads/" . $HTTP_POST_FILES[$name]["name"]);
  chmod("./uploads/" . $HTTP_POST_FILES[$name]["name"], 0644);

  $confirmation .= "<a href=\"./uploads/" . $HTTP_POST_FILES[$name]["name"] . "\">" .
                   $HTTP_POST_FILES[$name]["tmp_name"] . "</a> " . $HTTP_POST_FILES[$name]["type"] . ", " . $HTTP_POST_FILES[$name]["size"] . " bytes<br />";
  }
}
?>

<html>

<script>
var confirmation = '<?= $confirmation ?>';
</script>

<body onload="parent.enable_form(); parent.Add_HTML(confirmation);">
</body>
</html>

Это не идеально, но может быть использовано в качестве инструмента обучения.

 -1
Author: Frank, 2011-12-18 16:24:12