问题:每当我改变我的HTML表单上的enctype
到multipart/form-data
, $_POST
变量不填充在我的php脚本。用户上传文件并填写表单,文件上传到服务器,但$_POST
变量不填充。
代码:
收集数据文本/图片的HTML表单。
<我> index . php 我>
<form name="myForm" METHOD="POST" ACTION="" enctype="multipart/form-data">
<input type="text" name="text1" id="text1">
<input type="text" name="text2" id="text2">
<input type="file" name="filebutton" id="filebutton">
<input type="submit" name="submit" id="submit">
</form>
我的php脚本试图更新我的MySQL数据库,以及上传我的文件到我的Ubuntu服务器如下。
<我> upload.php 我>
<?php
$uploaddir = "/var/www/img/pictures/";
$uploadfile = $uploaddir . basename($_FILES['filebutton']['name']);
move_uploaded_file($_FILES['filebutton']['tmp_name'], $uploadfile);
if (isset($_POST['filebutton'])) {
$pictureUpdate = ", PICTURE_FILEPATH = '" . $_POST['filebutton'] . "'";
} else {
$pictureUpdate = "";
}
$connection = mysqli_connect("1.2.3.4","xxxx","xxxx","xxxx") or die("Caonnot connect to database.");
$update = "UPDATE table SET COLUMN1='" . $_POST['text1'] . "', COLUMN2='" . $_POST['text2'] . "' . $pictureUpdate . " where COLUMN3 = " . $_POST['text1'] . " ";
$update_sql = mysqli_query($connection, $update) or die("Cannot connect to mysql table. ". $update);
header("Location: " . $_SERVER['REQUEST_URL'] . "?success=1");
exit();
What I've try:这是第一次这样做,所以我在这里有点自由,因为我似乎无法让它工作。
- 将
enctype
更改为application/x-www-form-urlencoded
。$_POST
和$_FILE
数据都没有出现在upload.php文件中。 - 完全移除
application/x-www-form-urlencoded
。当我这样做时,我的$_POST
变量工作,但我的文件不上传。 - 检查php.ini为
post_max_size
。在互联网上搜索时,我遇到了几个关于类似问题的StackOverflow主题。从我收集到的信息来看,如果试图上传的文件超过了post_max_size
中的值,那么$_POST
变量将无法通过。我的php.ini文件中post_max_size
的值为"8M",正在上传的测试文件图片为103 KiB。
我如何得到$_POST
数据的工作,以及从相同的形式上传文件?
您只需要将文件内容移动到if语句中,并将$_POST['filebutton']
更改为$_FILES['filebutton']
无论何时进行文件上传,文件将在$_FILES
全局变量中填充,而其他字段将在$_POST
全局变量中填充。
<?php
$uploaddir = "/var/www/img/pictures/";
if (isset($_FILES['filebutton'])) {
$uploadfile = $uploaddir . basename($_FILES['filebutton']['name']);
move_uploaded_file($_FILES['filebutton']['tmp_name'], $uploadfile);
$pictureUpdate = ", PICTURE_FILEPATH = '" . $_FILES['filebutton'] . "'";
} else {
$pictureUpdate = "";
}
$connection = mysqli_connect("1.2.3.4","xxxx","xxxx","xxxx") or die("Caonnot connect to database.");
$update = "UPDATE table SET COLUMN1='" . $_POST['text1'] . "', COLUMN2='" . $_POST['text2'] . "' . $pictureUpdate . " where COLUMN3 = " . $_POST['text1'] . " ";
$update_sql = mysqli_query($connection, $update) or die("Cannot connect to mysql table. ". $update);
header("Location: " . $_SERVER['REQUEST_URL'] . "?success=1");
exit();
试试这段代码,看看它能为你做什么,如果这段有效,而另一段不行,那么这意味着我们需要更多的代码来解决问题。
test.php
<form name="myForm" METHOD="POST" ACTION="" enctype="multipart/form-data">
<input type="text" name="text1" id="text1">
<input type="text" name="text2" id="text2">
<input type="file" name="filebutton" id="filebutton">
<input type="submit" name="submit" id="submit">
</form>
<xmp><?php if ($_SERVER['REQUEST_METHOD'] === 'POST') { var_dump($_FILES, $_POST); } ?></xmp>
输出
array(1) {
["filebutton"]=>
array(5) {
["name"]=>
string(21) "scanParser.properties"
["type"]=>
string(24) "application/octet-stream"
["tmp_name"]=>
string(14) "/tmp/phpRm1Ytp"
["error"]=>
int(0)
["size"]=>
int(264)
}
}
array(3) {
["text1"]=>
string(1) "1"
["text2"]=>
string(1) "2"
["submit"]=>
string(6) "Submit"
}