ASP.NET Core图片上传

.NET Framework 或 .NET Core 中实现图片上传功能的代码示例通常涉及前端HTML表单与后端C#控制器之间的交互,以及文件流处理和可能的存储逻辑。以下是一个基本的ASP.NET MVC或ASP.NET Core MVC控制器中的Action方法示例,用于接收并保存上传的图片到服务器的指定文件夹:

using System;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Hosting;

public class ImageController : Controller
{
    private readonly IWebHostEnvironment _webHostEnvironment; // 依赖注入Web宿主环境服务

    public ImageController(IWebHostEnvironment webHostEnvironment)
    {
        _webHostEnvironment = webHostEnvironment;
    }

    [HttpPost]
    public IActionResult UploadImage(IFormFile file)
    {
        if (file == null || file.Length == 0)
        {
            return Json(new { success = false, message = "请选择一个图片文件进行上传。" });
        }

        // 检查文件扩展名是否为允许的类型
        string[] allowedExtensions = { ".jpg", ".jpeg", ".png", ".gif" }; // 更多类型可添加
        string extension = Path.GetExtension(file.FileName).ToLowerInvariant();
        if (!allowedExtensions.Contains(extension))
        {
            return Json(new { success = false, message = "不支持的图片格式,请上传.jpg、.jpeg、.png或.gif格式的图片。" });
        }

        // 设置图片保存目录
        string folderPath = Path.Combine(_webHostEnvironment.WebRootPath, "bookimg");
        Directory.CreateDirectory(folderPath); // 如果文件夹不存在,则创建

        // 生成唯一文件名(防止重名)
        string uniqueFileName = Guid.NewGuid().ToString() + extension;
        string filePath = Path.Combine(folderPath, uniqueFileName);

        // 保存图片到服务器
        using (var stream = new FileStream(filePath, FileMode.Create))
        {
            file.CopyTo(stream);
        }

        // 图片上传成功,返回相关信息
        return Json(new { success = true, imageUrl = $"/bookimg/{uniqueFileName}" });
    }
}

 在前端,你需要有一个HTML表单或者使用Ajax提交来发送POST请求,并包含enctype="multipart/form-data"属性以便能够上传文件:

<form id="uploadForm" enctype="multipart/form-data">
    <input type="file" name="file" accept=".jpg, .jpeg, .png, .gif" />
    <button type="submit">上传图片</button>
</form>

<script>
    $("#uploadForm").submit(function(event) {
        event.preventDefault(); // 阻止默认表单提交行为
        var formData = new FormData(this); // 创建FormData对象包含表单数据
        $.ajax({
            url: '/Image/UploadImage',
            type: 'POST',
            data: formData,
            contentType: false, // 必须设置为false,jQuery才会正确发送FormData
            processData: false, // 不允许jQuery对数据进行序列化处理
            success: function(response) {
                if (response.success) {
                    alert('图片上传成功');
                    // 更新图片显示路径等操作...
                } else {
                    alert(response.message);
                }
            },
            error: function(xhr, status, error) {
                alert('上传失败:' + xhr.responseText);
            }
        });
    });
</script>
逐个模块给出以下说明: 一个用户只能在同一时间登陆一次,需要经过电脑ip验证,用户名和密码验证,全部通过才可以进入首页。 用户登录:首先进入首页,显示该用户今天上传图片。 1.查看图片:显示该用 户上传的所有图片,显示内容:图像描述,图像大小,是否验证,上传时间,查看,删除 2.上传图片:用户可以上传图片,在上传时有预览的功能,如果数据库中已存在上传过的照片,则提醒用户已上传,否则进入等待验证页面,等待后台验证,若验证成功则显示上传的图像,如果失败则提醒用户是否继续等待验证 3.修改口令:用户可以修改自己的密码 4.退出系统:用户退出当前系统,注销 5.团队简介和客户服务主要是显示团队介绍和联系方式 管理员登陆:进入首页,显示今天上传的所有图片,显示内容:编号,id,图像描述,图像大小,是否验证,上传用户,ip,上传时间,查看,删除 1.查看用户:显示用户名,密码,增加时间,上传几张图片,删除 2.增加用户:包括用户名,密码 3.查找用户:根据输入的用户名进行模糊查询,显示内容:用户名,密码,添加时间,上传几张图片,删除 4.查看所有图片:显示编号,id,图像描述,图像大小,是否验证,上传用户,ip,上传时间,查看,操作,其中id,图像描述,图像大小,是否验证,上传用户,ip,上传时间字段具有排序功能 5.查找图片:可以根据用户名和上传日期进行查询 6.查看节点:显示IP地址,删除 7.增加节点:输入客户端的ip地址进行添加 8.退出系统:进行注销 9.团队简介和客户服务:主要是显示团队介绍和联系方式
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值