web简易开发(二){html5+php实现文件上传及通过关键字搜索已上传图片)}

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS AI 助手,专业版
简介: web简易开发(二){html5+php实现文件上传及通过关键字搜索已上传图片)}

web简易开发(二){html5+php实现文件上传及通过关键字搜索已上传图片)}

index.php

(此处需要结合之前的文章验证是否登录:https://developer.aliyun.com/article/1481918?spm=a2c6h.13148508.setting.24.78f94f0eD8R7xx)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>首页</title>
</head>
<body>
<?php
    if(isset($_COOKIE['username'])) {
        echo "帐户信息:<br/>";
        echo "用户名:" . $_COOKIE['username'] . "<br/>";
        echo '<a href="out.php">退出登录</a><br>';
        echo '<a href="floget.html">修改密码</a>';
        echo '<br><a href="upload.php">上传图片</a>';
        echo '<form action="upload.php" method="post" enctype="multipart/form-data">
              <label>文件名:
              <br><input type="text" placeholder="文件名称" name="image_user_name"><br>
              <br><input type="file" name="image_upload"></label><br>
              <br><button type="submit" name="upload">上传图片</button><br>
              </form>';
        echo '<form action="search.php" method=get" name="notice"> <!--action="search.php"-->
              <label>搜索图片:
              <br><input type="text" name="photo" placeholder="请输入图片名"><br>
              <br><button type="submit">搜索</button><br>
              </form>';
        echo '<form action="search.php" method=get" name="notice"> <!--action="search.php"-->
              <label>搜索图片:
              <br><input type="text" name="photo_user" placeholder="你想查询谁上传的图片"><br>
              <br><button type="submit">搜索</button><br>
              </form>';
        } else {
            echo '<h1>您未登录,请<a href="login.html" style="text-decoration:none;">点击登录</h1>';
        }

未登录:

屏幕截图 2024-05-02 084559.png

已登录:

屏幕截图 2024-05-02 084718.png

conn.php

<?php
$root_sevsername="localhost";
$root_username="root";
$root_password="123456";
$root_dbname="users";
// 连接到MySQL数据库
$conn= mysqli_connect($root_sevsername,$root_username,$root_password,$root_dbname);

upload.php

<?php
include "conn.php";//引用conn.php连接数据库
$cookie_name = $_COOKIE['username'];
$image_user_name = $_POST['image_user_name'];
//echo "<script>alert('$image_user_name');</script>";
if (!$conn) {
    die("连接失败: " . mysqli_connect_error());
}
// 检查上传文件是否存在
if (!isset($_FILES['image_upload'])) {
    echo "<script>alert('未上传文件,请重新上传!');location.href='index.php'</script>";
    exit;
}
// 生成新的随机文件名
$newFileName = uniqid() . ".png";
//echo "<script>alert('$newFileName');</script>";
// 获取上传文件相关信息
$image_name = $_FILES['image_upload']['name'];
$tmp_name = $_FILES['image_upload']['tmp_name'];
$file_type = $_FILES['image_upload']['type'];
$file_extension = strtolower(pathinfo($image_name, PATHINFO_EXTENSION));
$allowedTypes = array('png', 'gif', 'jpg');
$target_dir = "./image_upload/";
// 设置目标文件名(使用新生成的随机文件名)
$target_file = $target_dir . $newFileName;
$target_file1 = explode(".",$target_file);
// 检查文件类型和移动文件
if (in_array($file_extension, $allowedTypes)) {
    // 移动文件并更改文件扩展名为PNG(这里假设所有上传的图片都将被转换为PNG格式)
    if (move_uploaded_file($tmp_name, $target_file)) {
        // 若移动成功,记录数据库的新文件名与地址
        $address = $target_file;
        $address1 =$target_file1[1].'.'.$target_file1[2] ;
        // 预处理SQL语句并执行
        $stmt = mysqli_prepare($conn, "INSERT INTO `image_upload` (`image_user_name`,`image_name`, `image_address`, `image_user`) VALUES (?, ?, ?, ?)");
        mysqli_stmt_bind_param($stmt, "ssss",$image_user_name, $newFileName, $address1, $cookie_name); // 这里记录的是新文件名
        mysqli_stmt_execute($stmt);
        if (mysqli_stmt_errno($stmt)===0) {
            echo "<script>alert('上传成功!,文件位置: {$address},即将返回首页: ');window.location.href='index.php'</script>";
        } else {
            echo "<script>alert('上传失败!');location.href='index.php'</script>";
        }
    } else {
        echo "<script>alert('文件移动失败,请重试!');location.href='index.php'</script>";
    }
} else {
    echo "<script>alert('上传文件类型错误,请重新上传!');location.href='index.php'</script>";
}

图片上传:

屏幕截图 2024-05-02 090815.png

search.php

<?php
include "conn.php";//引用conn.php连接数据库
// 检查连接是否成功
if (!$conn) {
    die("Connection failed: " . mysqli_connect_error());
}
$photo_name = $_GET['photo'] ?? null;
$photo_user = $_GET['photo_user'] ?? null;
// 准备SQL查询
if ($photo_name != null) {
    $search_sql = mysqli_prepare($conn, "SELECT `image_address` FROM `image_upload` WHERE `image_user_name`=?");
// 绑定参数
    mysqli_stmt_bind_param($search_sql, "s", $photo_name);
// 执行预处理语句
    $search_sql_executed = mysqli_stmt_execute($search_sql);
// 获取结果集(必须先执行才能获取结果)
    $search_result = mysqli_stmt_get_result($search_sql);
// 检查是否有匹配结果
    // 更改mysqli_fetch_array为mysqli_fetch_assoc以获取关联数组
    if ($search_result) {
        echo '<tr>';
        while ($row = mysqli_fetch_assoc($search_result)) { // 更改mysqli_fetch_array为mysqli_fetch_assoc并使用while循环遍历所有结果
            $url = "http://127.0.0.1" . $row['image_address'];
            // 直接在页面上输出图片
            echo '<td style="display: inline-block"><a href="' . $url . '" style=""><img src="' . $url . '" style="width: 400px;margin: 1px" ></a></td>'; // 使用<li>标签包裹每个图片,以形成有序或无序列表
        }
        echo '</tr>'; // 结束 ul 标签,假定你在循环外有一个开始的<ul>标签
    } elseif (!$search_sql_executed) {
        echo "<script>alert('搜索失败!');location.href='index.php'</script>";
    } else {
        echo "SQL执行错误:" . mysqli_error($conn);
    }
// 关闭预处理语句和数据库连接
    mysqli_stmt_close($search_sql);
    mysqli_close($conn);

}
//--------------------------------------------------------------------------
if($photo_user != null) {
    $search_sql = mysqli_prepare($conn, "SELECT `image_address` FROM `image_upload` WHERE `image_user`=?");
// 绑定参数
    mysqli_stmt_bind_param($search_sql, "s", $photo_user);
// 执行预处理语句
    $search_sql_executed = mysqli_stmt_execute($search_sql);
// 获取结果集(必须先执行才能获取结果)
    $search_result = mysqli_stmt_get_result($search_sql);
// 检查是否有匹配结果
    // 更改mysqli_fetch_array为mysqli_fetch_assoc以获取关联数组
    if ($search_result) {
        echo '<tr>';
        while ($row = mysqli_fetch_assoc($search_result)) { // 更改mysqli_fetch_array为mysqli_fetch_assoc并使用while循环遍历所有结果
            $url = "http://127.0.0.1" . $row['image_address'];
            // 直接在页面上输出图片
            echo '<td style="display: inline-block"><a href="' . $url . '" style=""><img src="' . $url . '" style="width: 400px;margin: 1px" ></a></td>'; // 使用<li>标签包裹每个图片,以形成有序或无序列表
        }
        echo '</tr>'; // 结束 ul 标签,假定你在循环外有一个开始的<ul>标签
    } elseif (!$search_sql_executed) {
        echo "<script>alert('搜索失败!');location.href='index.php'</script>";
    } else {
        echo "SQL执行错误:" . mysqli_error($conn);
    }
// 关闭预处理语句和数据库连接
    mysqli_stmt_close($search_sql);
    mysqli_close($conn);
}

搜索图片名(即使多个图片共用同一名)

屏幕截图 2024-05-02 090109.png

搜索谁上传了什么图片

屏幕截图 2024-05-02 090436.png

out.php

<?php
setcookie("username",time()-3600);
header('Refresh:3; url="login.html"');
echo "<h2>三秒后返回登入页面</h2>";

屏幕截图 2024-05-02 091124.png

MySQL结构样式(我用的phpMyAdmin图形化管理):

屏幕截图 2024-05-02 091519.png

屏幕截图 2024-05-02 091527.png

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
8月前
|
安全 PHP
PHP 8 新特性实战:提升开发效率的利器
PHP 8 新特性实战:提升开发效率的利器
243 87
|
8月前
|
安全 PHP
PHP 8 新特性实战:提升开发效率的利器
PHP 8 新特性实战:提升开发效率的利器
267 88
|
8月前
|
安全 编译器 PHP
PHP 8 新特性:现代开发的强力引擎
PHP 8 新特性:现代开发的强力引擎
246 89
|
8月前
|
安全 编译器 PHP
PHP 8 新特性:现代化开发的飞跃
PHP 8 新特性:现代化开发的飞跃
343 89
|
8月前
|
安全 大数据 PHP
PHP 7+ 新特性实战指南:提升开发效率
PHP 7+ 新特性实战指南:提升开发效率
244 87
|
6月前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
652 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
10月前
|
存储 消息中间件 前端开发
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
校园圈子系统校园论坛小程序采用uni-app前端框架,支持多端运行,结合PHP后端(如ThinkPHP/Laravel),实现用户认证、社交关系管理、动态发布与实时聊天功能。前端通过组件化开发和uni.request与后端交互,后端提供RESTful API处理业务逻辑并存储数据于MySQL。同时引入Redis缓存热点数据,RabbitMQ处理异步任务,优化系统性能。核心功能包括JWT身份验证、好友系统、WebSocket实时聊天及活动管理,确保高效稳定的用户体验。
559 4
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
|
8月前
|
SQL 敏捷开发 安全
PHP 的精髓:灵活高效,为 Web 而生
PHP 的精髓:灵活高效,为 Web 而生
|
11月前
|
前端开发 PHP 开发者
Wordpress主题开发之index.php
本文介绍了 WordPress 主题开发中页面结构与模板文件的使用方法。通过 header.php、sidebar.php、footer.php 和 index.php 等模板文件,实现网站模块化设计,便于统一管理和代码重用。Header 部分包含 logo、导航条等;Content 展示主体内容;Side bar 显示推荐信息或广告;Footer 则呈现版权和备案信息等内容。文章还提供了各模板文件的具体代码示例,帮助开发者快速理解和应用 WordPress 模板机制。
294 9