• 在Asp.Net MVC中实现上传图片并显示


    实现思路大概分为两步:

    1. 通过上传接口,将图片上传到服务器,返回文件路径给客户端;

    2. 点击保存上传,将文件路径保存到数据库,如果是多张图片,路径用逗号分隔。

    核心上传代码:

            /// <summary>
            /// 图片上传
            /// </summary>
            /// <returns></returns>
            [HttpPost]
            [Route("PostFile")]
            public HttpResponseMessage PostFile()
            {
                //TODO:Save file...
                if (!Request.Content.IsMimeMultipartContent("form-data"))
                    throw new HttpResponseException(HttpStatusCode.UnsupportedMediaType);
                HttpResponseMessage response = null;
    
                HttpContext context = HttpContext.Current;
                try
                {
                    HttpPostedFile file = HttpContext.Current.Request.Files["form-data"];
    
                    if (!string.IsNullOrEmpty(context.Request["type"]))
                    {
                        string type = context.Request["type"].ToString();
                        if (type == "image")
                        {
                            if (!string.IsNullOrEmpty(context.Request["size"]))
                            {
                                string sizes = context.Request["size"].ToString();
    
                                response = Request.CreateResponse(HttpStatusCode.Accepted, SaveBySize(file, sizes.Split(',')));
                            }
                            else
                            {
                                context.Response.Write("{ret:-1,msg:"参数错误"}");
                            }
                        }
                        else
                        {
                            response = Request.CreateResponse(HttpStatusCode.Accepted, Save(file));
                        }
                    }
                    else
                    {
                        response = Request.CreateResponse(HttpStatusCode.Accepted, Save(file));
                    }
    
                }
                catch (HttpResponseException ex)
                {
                    //throw new HttpResponseException(HttpStatusCode.BadRequest);
                    response = Request.CreateErrorResponse(HttpStatusCode.ExpectationFailed, ex.ToString());
                }
                return response;
            }
    

    实现效果

    点击选择图片

    点击确定上传

    图片预览

    有需要的朋友可以扫描下方二维码加入QQ群,我会把源码分享在QQ群里

  • 相关阅读:
    2015.7.23 开始记录一些学习情况
    poj 3299 java
    在线编辑~
    MATLAB加载数据来绘图《原创翻译Loading Data into MATLAB for Plotting》
    【转载】matlab的reshape函数的作用
    (转载)CUDA 6.0 安装及配置( WIN7 64位 / 英伟达G卡 / VS2010 )
    简单文本处理
    【转】CUDA与二维动态数组
    《转载》 cpp文件调用CUDA .cu文件实现显卡加速相关编程
    cuda_opencv之向量相加
  • 原文地址:https://www.cnblogs.com/ydcnblog/p/9316812.html
Copyright © 2020-2023  润新知