我正在尝试将一个文件上传到localhost服务器,但它不起作用。我正在尝试使用chmod授予文件所在文件夹的权限,但我不明白。表单在一个名为index.php的文件中动态打印,当单击提交时,数据将被收到名为recExpediente.php的同一个php文件。
PHP
<?
ini_set('error_reporting', E_ALL);
require('conectaDemo.php');
if (is_uploaded_file($_FILES['Foto']['tmp_name'])) {
$cSQL="SELECT NIF FROM CLIENTES WHERE ID_CLIENTE=?";
$stmt=$oConni->prepare($cSQL) or die($oConni->error);
$stmt->bind_param('i',$_POST['selDesc2']);
$stmt->execute();
$stmt->bind_result($DNI);
if ($stmt->fetch()) {
chmod('/var/www/pracRemesas/'.$DNI.'/', 0777);
echo '/var/www/pracRemesas/'.$DNI.'/';
$uploaddir='/var/www/pracRemesas/'.$DNI.'/';
}
$stmt->close();
$uploadfile = $uploaddir . basename($_FILES['Foto']['name']);
move_uploaded_file($_FILES['Foto']['tmp_name'], $uploadfile);
$cFoto=basename($_FILES['Foto']['name']);
$xSQL = "INSERT INTO EXPEDIENTES (ID_CLIENTE, DOCUMENTO,
OBSERVACIONES) VALUES(?,?,?)";
$stmt = $oConni->prepare($xSQL);
$stmt->bind_param('iss', $_POST['selDesc2'], $cFoto, $_POST['observ']);
$stmt->execute();
$stmt->close();
}
if (isset($_POST['newid'])) {
$cSQL="SELECT ID_CLIENTE, NOMBRE FROM CLIENTES";
$stmt=$oConni->prepare($cSQL) or die($oConni->error);
$stmt->execute();
$stmt->bind_result($ID_CLIENTE, $NOMBRE);
echo'<form name="nuevoExp" id="frmLogin" action="recExpediente.php" method="POST" enctype="multipart/form-data">';
echo'<select id="selDesc2" name="selDesc2">';
echo'<option value=-1>Seleccione cliente</option>';
while ($stmt->fetch()) {
echo'<option value="'.$ID_CLIENTE.'">'.$NOMBRE.'</option>';
}
$stmt->close();
echo'</select><br>';
echo'<input type="file" name="Foto" id="Foto"><br>';
echo'Observaciones<input type="text" name="observ" id="observ"><br>';
echo'<input type="submit" name="butEnv" id="butEnv" value="Enviar"/>';
echo'</form>';
}?>
答案 0 :(得分:1)
您的问题是可变范围。您可以在if语句中定义$uploaddir
,它仅适用于该语句。您需要先定义它,然后在if语句中修改它。
这导致您的代码实际上是
$uploadfile = basename($_FILES['Foto']['name']);
我建议您在代码中进行更多检查并使保险箱失效。您可以在if ($stmt->fetch()) {
中添加上传代码和插入内容。如果您在if
语句中移动所有内容,则无需为$uploaddir
问题更改任何内容。