网易首页 > 网易号 > 正文 申请入驻

使用PHP获取本地上传的图片

0
分享至

htmlspecialchars($newFileName) . '" alt="上传的图片">';htmlspecialchars($newFileName) . '" alt="上传的图片">';

使用PHP获取本地上传的图片

在PHP中处理本地图片上传是一个常见的需求,以下是完整的实现方法,包括HTML表单和PHP处理代码。

1. 基本HTML上传表单

首先创建一个HTML表单,允许用户选择并上传图片文件:

html

html>

《title>

head>

选择图片上传:label>

form>

body>

html>

关键点

  • 必须设置,否则文件无法上传
  • enctype="multipart/form-data"
  • 限制只能选择图片文件
  • accept="image/*"
  • 属性确保用户必须选择文件
  • required

2. PHP处理上传的图片 (upload.php)

php

// 检查是否通过POST方法提交

if ($_SERVER['REQUEST_METHOD'] === 'POST') {

// 检查是否有文件上传错误

if (isset($_FILES['image']) && $_FILES['image']['error'] === UPLOAD_ERR_OK) {

// 获取文件信息

$fileTmpPath = $_FILES['image']['tmp_name'];

$fileName = $_FILES['image']['name'];

$fileSize = $_FILES['image']['size'];

$fileType = $_FILES['image']['type'];

// 允许的文件类型

$allowedTypes = ['image/jpeg', 'image/png', 'image/gif'];

// 验证文件类型

if (!in_array($fileType, $allowedTypes)) {

die('错误: 只允许上传 JPG, PNG 或 GIF 格式的图片。');

// 验证文件大小 (例如限制为5MB)

$maxSize = 5 * 1024 * 1024; // 5MB

if ($fileSize > $maxSize) {

die('错误: 文件大小不能超过 5MB。');

// 生成唯一文件名防止覆盖

$fileExt = pathinfo($fileName, PATHINFO_EXTENSION);

$newFileName = uniqid('img_', true) . '.' . $fileExt;

// 设置上传目录 (确保目录存在且有写入权限)

$uploadDir = __DIR__ . '/uploads/';

if (!is_dir($uploadDir)) {

mkdir($uploadDir, 0755, true);

// 移动文件到目标目录

$destPath = $uploadDir . $newFileName;

if (move_uploaded_file($fileTmpPath, $destPath)) {

// 上传成功,显示图片

echo '';

图片上传成功!

echo '

echo '';

文件路径: uploads/' . htmlspecialchars($newFileName) . '

} else {

echo '错误: 文件上传失败。';

} else {

// 处理上传错误

$uploadErrors = [

UPLOAD_ERR_INI_SIZE => '文件大小超过服务器限制。',

UPLOAD_ERR_FORM_SIZE => '文件大小超过表单限制。',

UPLOAD_ERR_PARTIAL => '文件只有部分被上传。',

UPLOAD_ERR_NO_FILE => '没有文件被上传。',

UPLOAD_ERR_NO_TMP_DIR => '缺少临时文件夹。',

UPLOAD_ERR_CANT_WRITE => '写入磁盘失败。',

UPLOAD_ERR_EXTENSION => 'PHP扩展停止了文件上传。'

$errorCode = $_FILES['image']['error'] ?? UPLOAD_ERR_NO_FILE;

echo '错误: ' . ($uploadErrors[$errorCode] ?? '未知上传错误。');

3. 安全增强措施

  1. 文件类型验证
    • 不要依赖客户端提供的MIME类型 ()
  • $_FILES['image']['type']
    • 使用函数验证实际文件内容
  • getimagesize()
  1. php
  2. $imageInfo = getimagesize($fileTmpPath);
  3. if (!$imageInfo) {
  4. die('错误: 上传的文件不是有效图片。');
  5. $realMimeType = $imageInfo['mime'];
  6. 文件扩展名验证
  7. php
  8. $allowedExtensions = ['jpg', 'jpeg', 'png', 'gif'];
  9. $fileExt = strtolower(pathinfo($fileName, PATHINFO_EXTENSION));
  10. if (!in_array($fileExt, $allowedExtensions)) {
  11. die('错误: 不允许的文件扩展名。');
  12. 防止文件名注入
  13. php
  14. // 清理文件名
  15. $fileName = preg_replace("/[^a-zA-Z0-9._-]/", "_", $fileName);

4. 完整增强版示例

php

if ($_SERVER['REQUEST_METHOD'] === 'POST') {

if (isset($_FILES['image']) && $_FILES['image']['error'] === UPLOAD_ERR_OK) {

$fileTmpPath = $_FILES['image']['tmp_name'];

// 验证图片

$imageInfo = getimagesize($fileTmpPath);

if (!$imageInfo) {

die('错误: 上传的文件不是有效图片。');

$realMimeType = $imageInfo['mime'];

$allowedTypes = ['image/jpeg', 'image/png', 'image/gif'];

if (!in_array($realMimeType, $allowedTypes)) {

die('错误: 只允许上传 JPG, PNG 或 GIF 格式的图片。');

// 获取原始文件名并清理

$originalName = $_FILES['image']['name'];

$cleanName = preg_replace("/[^a-zA-Z0-9._-]/", "_", $originalName);

// 生成安全文件名

$fileExt = pathinfo($cleanName, PATHINFO_EXTENSION);

$newFileName = uniqid('img_', true) . '.' . $fileExt;

// 设置上传目录

$uploadDir = __DIR__ . '/secure_uploads/';

if (!is_dir($uploadDir)) {

mkdir($uploadDir, 0755, true);

$destPath = $uploadDir . $newFileName;

// 移动文件

if (move_uploaded_file($fileTmpPath, $destPath)) {

// 可选: 调整图片大小

// resizeImage($destPath, $destPath, 800, 600);

echo '';

图片上传成功!

echo '

} else {

echo '错误: 文件保存失败。';

} else {

// 处理上传错误

$uploadErrors = [

UPLOAD_ERR_INI_SIZE => '文件大小超过服务器限制。',

UPLOAD_ERR_FORM_SIZE => '文件大小超过表单限制。',

UPLOAD_ERR_PARTIAL => '文件只有部分被上传。',

UPLOAD_ERR_NO_FILE => '没有文件被上传。',

UPLOAD_ERR_NO_TMP_DIR => '缺少临时文件夹。',

UPLOAD_ERR_CANT_WRITE => '写入磁盘失败。',

UPLOAD_ERR_EXTENSION => 'PHP扩展停止了文件上传。'

$errorCode = $_FILES['image']['error'] ?? UPLOAD_ERR_NO_FILE;

echo '错误: ' . ($uploadErrors[$errorCode] ?? '未知上传错误。');

// 可选: 图片调整大小函数

function resizeImage($srcPath, $destPath, $maxWidth, $maxHeight) {

list($width, $height, $type) = getimagesize($srcPath);

$ratio = min($maxWidth/$width, $maxHeight/$height);

$newWidth = $width * $ratio;

$newHeight = $height * $ratio;

switch ($type) {

case IMAGETYPE_JPEG:

$src = imagecreatefromjpeg($srcPath);

break;

case IMAGETYPE_PNG:

$src = imagecreatefrompng($srcPath);

break;

case IMAGETYPE_GIF:

$src = imagecreatefromgif($srcPath);

break;

default:

return false;

$dst = imagecreatetruecolor($newWidth, $newHeight);

imagecopyresampled($dst, $src, 0, 0, 0, 0, $newWidth, $newHeight, $width, $height);

switch ($type) {

case IMAGETYPE_JPEG:

return imagejpeg($dst, $destPath);

case IMAGETYPE_PNG:

return imagepng($dst, $destPath);

case IMAGETYPE_GIF:

return imagegif($dst, $destPath);

return false;

5. 最佳实践

  1. 始终验证文件类型和大小
  2. 使用随机生成的文件名,不要使用用户提供的文件名
  3. 将上传的文件存储在web根目录之外(如果可能)
  4. 设置适当的文件权限
  5. 考虑使用.htaccess文件限制对上传目录的访问
  6. 对于生产环境,考虑使用云存储服务(如AWS S3、阿里云OSS等)

通过以上方法,您可以安全地在PHP网站中实现本地图片上传功能。

声明:内容由AI生成

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
事件升级!司晓迪晒开房记录,16个男顶流被锤!内娱彻底玩完

事件升级!司晓迪晒开房记录,16个男顶流被锤!内娱彻底玩完

大龄女一晓彤
2026-01-13 15:12:59
小学食堂阿姨将热水桶随意放门口,三年级女孩经过时被水桶绊倒严重烫伤

小学食堂阿姨将热水桶随意放门口,三年级女孩经过时被水桶绊倒严重烫伤

观威海
2026-01-14 09:06:03
黄健翔:中国U23踢泰国是苦战,要考虑丢球后如何调整

黄健翔:中国U23踢泰国是苦战,要考虑丢球后如何调整

懂球帝
2026-01-14 11:53:05
俄罗斯已看透特朗普:他在全球横冲直撞,却唯独不敢对中国乱来

俄罗斯已看透特朗普:他在全球横冲直撞,却唯独不敢对中国乱来

窥史
2026-01-13 23:46:11
婚外情最残忍真相:穷人连出轨都透着穷酸气

婚外情最残忍真相:穷人连出轨都透着穷酸气

衍月
2025-12-07 22:51:30
中方将奉陪到底!

中方将奉陪到底!

陆弃
2026-01-14 08:15:03
36年前陈宝国主演的盗墓恐怖片!尺度大到少儿不宜

36年前陈宝国主演的盗墓恐怖片!尺度大到少儿不宜

释凡电影
2025-08-14 09:33:19
贝林厄姆爆发:“简直是一堆狗屎”

贝林厄姆爆发:“简直是一堆狗屎”

绿茵情报局
2026-01-14 04:52:49
“不给6套房加1个亿,不搬”,钉子户张新国坚守14年,终败给现实

“不给6套房加1个亿,不搬”,钉子户张新国坚守14年,终败给现实

红梦史说
2025-07-11 11:23:39
科学家让一对情侣在核磁共振里实战,才发现人体惊人真相!

科学家让一对情侣在核磁共振里实战,才发现人体惊人真相!

徐德文科学频道
2026-01-06 19:51:55
性生活不伤肾,豆制品不伤肾,真正伤肾的事一再被你忽略!30条建议送给肾友们

性生活不伤肾,豆制品不伤肾,真正伤肾的事一再被你忽略!30条建议送给肾友们

掌上肾医
2026-01-12 19:16:03
军工企业郭某未能抵御境外间谍美色诱惑,发生不正当关系后被以曝光隐私要挟,协助策反同行2人,获刑十年

军工企业郭某未能抵御境外间谍美色诱惑,发生不正当关系后被以曝光隐私要挟,协助策反同行2人,获刑十年

都市快报橙柿互动
2026-01-14 08:12:01
玩具新潮催生“包挂经济”(看中国好物七十二变)

玩具新潮催生“包挂经济”(看中国好物七十二变)

人民网
2026-01-14 07:05:31
LV红毯这天,周冬雨没胸硬捂,金晨渔网内搭,被全裹的巩俐惊艳

LV红毯这天,周冬雨没胸硬捂,金晨渔网内搭,被全裹的巩俐惊艳

一娱三分地
2026-01-14 14:14:29
人真的好脆弱,网友:我最好的朋友去长白山滑雪脑出血去世了!

人真的好脆弱,网友:我最好的朋友去长白山滑雪脑出血去世了!

夜深爱杂谈
2026-01-13 21:36:54
你不大可能见过的照片

你不大可能见过的照片

霹雳炮
2025-10-04 22:58:14
“失踪”8年!孔令辉未参加国乒教练竞聘,张继科透露孔令辉人品

“失踪”8年!孔令辉未参加国乒教练竞聘,张继科透露孔令辉人品

观察者海风
2026-01-13 23:54:54
呆呆爆火才2天,无语的一幕发生!全网几百家都杀猪 文案几乎一样

呆呆爆火才2天,无语的一幕发生!全网几百家都杀猪 文案几乎一样

丁丁鲤史纪
2026-01-14 12:06:34
当不成总统了?美国最新投票结果公布,特朗普承认自己或将下台

当不成总统了?美国最新投票结果公布,特朗普承认自己或将下台

阿伧说事
2026-01-14 15:19:57
斯普利特:队医告诉我杨瀚森伤无大碍,所以才让他重返比赛

斯普利特:队医告诉我杨瀚森伤无大碍,所以才让他重返比赛

懂球帝
2026-01-14 15:37:51
2026-01-14 16:00:49
建邺区生态科技岛人工智能商会
建邺区生态科技岛人工智能商会
南京市建邺区生态科技岛人工智能行业商会
243文章数 0关注度
往期回顾 全部

科技要闻

美国批准英伟达H200卖给中国,但有条件

头条要闻

电车失控在市区以超100km/h时速连撞15车 阿维塔回应

头条要闻

电车失控在市区以超100km/h时速连撞15车 阿维塔回应

体育要闻

牛津学霸买下儿时主队,让它成为英超黑马

娱乐要闻

何晴去世30天,许亚军终于发声

财经要闻

姚振华举报:观致汽车资产被低价拍卖

汽车要闻

曝Model Y或降到20万以内!

态度原创

教育
时尚
房产
本地
军事航空

教育要闻

小升初压轴题,求圆的面积?

比变老更可怕的是不会穿!中年女人掌握4个技巧,优雅不费力

房产要闻

热销17亿后!天正·三亚湾壹号,被爆违建!

本地新闻

穿越鳌太线,怎么就成了户外人的致命诱惑?

军事要闻

美再发安全警告 敦促美公民立即离开伊朗

无障碍浏览 进入关怀版