gpt4 book ai didi

php - 使用PHP根据单选按钮选择插入图像MYSQL

转载 作者:行者123 更新时间:2023-11-29 00:07:02 27 4
gpt4 key购买 nike

我有一个网站。在这个网站上,我可以上传图像,然后将这些图像放入我的 SQL 数据库中。从这里我从数据库中选择图像并将它们显示为照片库中的缩略图,当单击图像时它会显示一个大版本,您可以在其中投票/喜欢和评论等。

现在我要做的是制作 3 个类别页面,基本上是显示缩略图的照片库的 3 倍。

我的数据库中有 3 个不同的表,我将图像插入其中。所以我复制了照片库 3x 和数据库中的原始上传表 3x。我怎么不想为每个照片 gallery.php 文件创建 3 个 upload.php 文件。

我想要做的是在我的上传页面上选择 3 个单选按钮,并在此处做出选择,图像将上传到匹配的数据库表(照片 1、2 或 3)中。

我一直在尝试使用 Functions 等来做到这一点,但我就是无法让它工作,我可能正在做一些非常简单、非常愚蠢的事情。

这是我用于单选按钮和获取图像的代码:

    $titel = "Image";
$query = "SELECT * FROM `i268296_studie`.`fotos` ORDER BY foto_ID DESC";
$result = mysqli_query($conn, $query) or die("query error " . mysqli_error($conn) );
$fotos = array();
//create array from images in database
while($data = mysqli_fetch_assoc($result))
{
$fotos[] = array('src' => $data['src'], 'id' => $data['foto_ID']);
}
?>

<section id="upload">
<form method="post" action="upload.php" enctype="multipart/form-data">

<label for="bestand">Upload image:</label><br><br>
<input type="file" name="bestand" id="file"><br><br>
<label for="categorie"> Categorie: </label>
<input type="radio" name="cat" value="cat1">Portrait
<input type="radio" name="cat" value="cat2">Landscape
<input type="radio" name="cat" value="cat3">Other
<input type="submit" name="submit" value="Upload">
</form>
</section>
<?php
}
?>
<section class="images">
<?php
//show image thumbnails in photogallery
foreach($fotos as $foto)
{
?>
<a href="fotoinfo.php?foto_ID=<?php echo $foto['id'];?>"><img class="image" src="<?php echo 'upload/thumb/t_'.$foto['src'];?>"></a>
<?php
}
?>
</section>

上面的代码我有 3 次(用 HTML 等包围作为图片库页面)。

这是我的上传文件(我将保留大部分缩略图制作代码,因为它只涉及上传部分)。

$titel = "Image";
$dir='upload/';
$allowedExts = array("jpg", "jpeg", "gif", "png");
$answer= $_POST['cat'];
//Properties of the to be uploaded file
$fileName = $_FILES["bestand"]["name"]; //file name
$fileType = $_FILES["bestand"]["type"]; //file format
$fileSize = $_FILES["bestand"]["size"]; //file size
$tmpName = $_FILES["bestand"]["tmp_name"]; //temporary save location for file
$error = $_FILES["bestand"]["error"]; //error check for file

$fp = fopen($tmpName, 'r');
$content = fread($fp, filesize($tmpName));
$content = addslashes($content);
fclose($fp);
if(!get_magic_quotes_gpc())
{
$fileName = addslashes($fileName);
}
//select image from database and check if it already exists
$sql = "SELECT * FROM `i268296_studie`.`fotos` WHERE src = '$fileName'";
$result = mysqli_query($conn, $sql) or die("query error " . mysqli_error($conn) );
$data = mysqli_fetch_assoc($result);
$num_rows=mysqli_num_rows($result);
if($num_rows > 0)
{
echo 'File already exists <br>';
echo '<a href="fotogallerij.php">Return to homepage/a>';
}
else
{
// if file doesn't exist move to database, create thumbnail path
if (move_uploaded_file( $tmpName,$dir.$fileName))
{
function category($cat, $titel, $filename)
{
global $conn;
$query = "INSERT INTO `i268296_studie`.`$cat` (`titel`, `src`) VALUES ('$titel', '$fileName')"; //INSERT file into database
$result = mysqli_query($conn, $query) or die("query error " . mysqli_error($conn) );
}
$tname = 't_'.$fileName;
$tpath = $dir.'thumb/';
$tnamestate = $tpath.$tname;
$tptype = substr($fileType,6);
$ttype = "imagecreatefrom$tptype";
$name = $fileName;
$path = $dir;
$namestate = $path.$name;
$width = 100;
$height = 100;
list($width_orig, $height_orig) = getimagesize("$namestate");
$ratio_orig = $width_orig/$height_orig;
if ($width/$height > $ratio_orig)
{
$width = $height*$ratio_orig;
}
else
{
$height = $width/$ratio_orig;
}

我怎么会盯着自己看,不知道如何修复它或将它放在哪里才能正常工作。我希望我的解释和问题对你们试图帮助我的人来说是清楚的,如果不是,请告诉我我可以改变或做些什么来帮助 :)

编辑:我得到的错误是:

Undefined variable: titel
Undefined variable: fileName
Undefined variable: conn
mysqli_query() expects parameter 1 to be mysqli, null given

当我没有选择单选按钮而是直接上传时,我只收到 1 个错误:

Undefined index: cat

然后上传到第三类

编辑 2:更改了其中包含全局 $conn 的函数。

最佳答案

1 function category($cat, $titel, $fileName) {
2 global $conn;
3 $query = "INSERT INTO `i268296_studie`.`$cat` (`titel`, `src`) VALUES ('$titel', '$fileName')";
4 $result = mysqli_query($conn, $query) or die("query error " . mysqli_error($conn) );
5 }

1: you need these variables from the context calling the function
2: you need the global $conn variable in the function context to be able to run the query
3: use a function parameter for the table to upate call
4: it would be better to return results instead of breaking inside the function

调用代码如下:

if ($answer == "cat1") {          
category("fotos", $titel, $fileName); // or "foto2", $titel, $fileName .....
}

请注意有关注入(inject)漏洞的评论。另请阅读:http://php.net/manual/it/language.variables.scope.php

关于php - 使用PHP根据单选按钮选择插入图像MYSQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27050072/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com