在VS2013 MVC项目中上传图片

之前做网站项目时,凡遇到保存图片的,我都将图片上传后存储在服务器的本地文件夹中,在一个Controller的Action中,类似操作如下所示:

public ActionResult UpLoad(HttpPostedFileBasearImg)
{ 
           //保存图片
           if (arImg != null)
           {
                string uploadName =arImg.FileName;//获取待上传图片的完整路径,包括文件名
                string suffix =uploadName.Substring(uploadName.LastIndexOf("."));//获得上传的图片的后缀名
                string newName =DateTime.Now.ToString("yyyyMMddHHmmss") + suffix;
                try
                {
                   arImg.SaveAs(Server.MapPath("~/Images/Article/") + newName); 
                }
                catch (System.Exception ex)
                {
                   System.Diagnostics.Trace.WriteLine(ex.Message);
                }
           }
           return View(“Images”);
}

现在,我想将图片存储到MySql数据库中,并想尝试使用MVC中Ajax功能,所以写了如下图所示的测试程序。其中红色框中的内容是部分视图,因为我想使用Ajax上传图片,然后动态更新红色框部分。

首先,新建一个MVC Internet项目,在HomeController中添加Images方法,用于返回上图所示的图片列表。代码如下:

publicActionResult Images()
{
return View();
}

添加Images视图页面,如下:

为了便于部分更新,在HomeController中添加Action返回_ImageList分部视图,如下:

publicPartialViewResult _ImageList()
{
IList<Int32> imgList =GetImageList();
returnPartialView(imgList);
}

这个子Action获取所有的图片的ID列表,并传入视图中。GetImageList()是一个私有方法,功能是从数据库中读取所有图片的ID。代码如下:

privateIList<int> GetImageList()
    {
            IList<Int32> imgList = newList<Int32>();
            MySqlConnection sqlCon = null;
            try
            {
                sqlCon = newMySqlConnection("server=127.0.0.1;uid=root;pwd=test;database=test;CharSet=utf8");
                sqlCon.Open();
 
                MySqlCommand sqlCmd = newMySqlCommand("SELECT ID FROMImages",sqlCon);
                MySqlDataReader dr =sqlCmd.ExecuteReader();
 
               while (dr.Read())
                {
                   imgList.Add(dr.GetInt32(0));
                }
 
                dr.Close();
            }
            catch (Exception ex)
            {
                System.Diagnostics.Trace.WriteLine("Image error:" +ex.Message);
            }
            finally
            {
                if (sqlCon != null)
                {
                    sqlCon.Close();
                }
                sqlCon = null;
            }
 
            return imgList;
}

添加_ImageList分部视图如下,用于循环显示所有图片。

    接下来,需要实现UpLoad方法,用于保存客户端上传的图片。

[HttpPost]
        publicActionResult Upload(HttpPostedFileBase image)
        {
            if (image != null)
            {
                MySqlConnection sqlCon = null;
                try
                {
                    sqlCon = newMySqlConnection("server=127.0.0.1;uid=root;pwd=test;database=test;CharSet=utf8");
                    sqlCon.Open();
 
                    string sql = "INSERT INTOImages (Content, Type, Length) VALUES (@Content, @Type, @Length)";
 
                    byte[] data = newbyte[image.InputStream.Length];
                   image.InputStream.Read(data, 0, Convert.ToInt32(image.InputStream.Length));
 
                    MySqlCommand sqlCmd = newMySqlCommand(sql, sqlCon);
                    sqlCmd.Parameters.AddWithValue("Content", data);
                   sqlCmd.Parameters.AddWithValue("Type", image.ContentType);
                   sqlCmd.Parameters.AddWithValue("Length",image.ContentLength);
                    sqlCmd.ExecuteNonQuery();
                }
                catch (Exception ex)
                {
                    System.Diagnostics.Trace.WriteLine("Upload imageerror: " +ex.Message);
                }
                finally
                {
                    if (sqlCon != null)
                    {
                        sqlCon.Close();
                    }
                    sqlCon = null;
                }
            }
 
            return View("Images");
}

另外,还需要实现一个方法,根据ID获取相应的图片内容,如下:

publicFileResult Image(int id)
        {
            FileResult fileRet = null;
            MySqlConnection sqlCon = null;
            try
            {
                sqlCon = newMySqlConnection("server=127.0.0.1;uid=root;pwd=FarStone1!;database=test;CharSet=utf8");
                sqlCon.Open();
 
                MySqlCommand sqlCmd = newMySqlCommand("SELECTContent, Type, Length FROM Images WHERE ID=" + id.ToString(),sqlCon);
                MySqlDataReader dr =sqlCmd.ExecuteReader();
 
                if (dr.Read())
                {
                    int length =dr.GetInt32(2);
                    byte[] data = newbyte[length];
                    dr.GetBytes(0, 0, data, 0,length);
                    fileRet = newFileContentResult(data,dr.GetString(1));
                }
            }
            catch (Exception ex)
            {
                System.Diagnostics.Trace.WriteLine("Image error:" +ex.Message);
            }
            finally
            {
                if (sqlCon != null)
                {
                    sqlCon.Close();
                }
                sqlCon = null;
            }
 
            return fileRet;
    }

完成以上操作后,就可以编译运行MVC项目了,通过IE调试可以看到下图的效果,且可以上传文件。

但是,需要注意的是,我在上传时并没有用到Ajax相关的东西。第一步,需要修改上传代码,如下:

然后,需要修改HomeController中的UpLoad方法的,返回PartialView,如下:

IList<Int32> imgList =GetImageList();
return PartialView("_ImageList", imgList);

编译并运行程序,并没有出现理想中的部分更新,而是重新跳转到了新的页面,如下图所示:

也就是说Ajax的上传没有效果,通过查看资料发现,需要在项目中包含Ajax相关的Javascript文件,但是VS2013在项目的Script文件夹下并没有默认添加相关的Javascript文件,所以需要手动添加。这里通过右键项目名称,通过“管理NuGet程序包”并在联机项目中搜索“jQuery Unobtrusive Ajax”并安装相关的程序包,这时Script文件夹下将出现两个Ajax文件,如下图所示:

编辑App_Start文件夹中的BundleConfig文件,加入如下代码:

bundles.Add(newScriptBundle("~/bundles/ajax").Include(
                        "~/Scripts/jquery.unobtrusive-ajax.min.js"));

然后在_Layout.cshtml文件中加入如下代码引用Ajax相关的Javascript文件:

@
Scripts
.Render(
"~/bundles/ajax"
)

当然,也可以使用<script></script>直接引用相关的Javascript文件。

这时再次编译运行项目,并选择文件上传,发现界面始终停留在如下界面:

为了确认点击“Upload”按钮时确实发生了上传动作,在HomeController的UpLoad方法中设置了断点,并上传文件,如下所示:

发现无论上传什么文件,在Controller中接收到的image都是空的。为了确认是否与上传文件有关,修改_ImageList分部视图如下:

并在HomeController中新增UploadText方法,如下:

publicActionResult UploadText(string image)
        {
            return Content("<divid=‘result‘>" +image + "</div>");
    }

编译运行程序,可以看见在文本框中输入的任何字符串都可以动态更新在界面上,且是通过Ajax上传,并没有更新整个页面。

在网上查阅资料发现,MVC提供的Ajax.BeginForm无法上传文件,所以如果需要在MVC项目中上传图片,还是要使用Html.BeginForm。

在VS2013 MVC项目中上传图片

时间: 2024-10-12 18:59:35

在VS2013 MVC项目中上传图片的相关文章

MVC项目中如何判断用户是在用什么设备进行访问

使用UAParser在C#MVC项目中如何判断用户是在用什么设备进行访问(手机,平板还是普通的电脑) 现在我们开发的很多web应用都要支持手机等移动设备.为了让手机用户能有更加好的用户体验,我们经常为手机设备专门准备一套前端的页面.这样当用户使用普通电脑来访问的时候,我们的应用就向用户展示普通电脑的页面.当用户使用手机等移动设备来访问我们的系统的时候,我们就向用户展示手机设备的页面.但是这时候另一个问题出现了.如何判断用户在使用什么设备访问我们的应用?是使用手机还是普通电脑? 网上能查到的不同的

谈谈MVC项目中的缓存功能设计的相关问题

本文收集一些关于项目中为什么需要使用缓存功能,以及怎么使用等,在实际开发中对缓存的设计的考虑 为什么需要讨论缓存呢? 缓存是一个中大型系统所必须考虑的问题.为了避免每次请求都去访问后台的资源(例如数据库),我们一般会考虑将一些更新不是很频繁的,可以重用的数据,通过一定的方式临时地保存起来,后续的请求根据情况可以直接访问这些保存起来的数据.这种机制就是所谓的缓存机制. 根据缓存的位置不同,可以区分为: 1.客户端缓存(缓存在用户的客户端,例如浏览器) 2.服务器断货(缓存在服务器中,可以缓存在内存

在 ASP.NET MVC 项目中使用 WebForm、 HTML

原文地址:http://www.cnblogs.com/snowdream/archive/2009/04/17/winforms-in-mvc.html ASP.NET MVC和WebForm各有各的优点,我们可能需要同时使用ASP.NET MVC和WebForm.本文介绍了如何在ASP.NET MVC项目中使用WebForm.首先新建一个名为WebForms的文件夹用于存放WebForm,并添加一个Web窗体文件Demo.aspx作为演示. Demo.aspx就简单的输出一句话“It’s a

转 mvc项目中,解决引用jquery文件后智能提示失效的办法

mvc项目中,解决用Url.Content方法引用jquery文件后智能提示失效的办法 这个标题不知道要怎么写才好, 但是希望文章的内容对大家有帮助. 场景如下: 我们在用开发开发程序的时候,经常会引用jquery, 但是由于路由的关系,最终访问页面的地址相对js文件来说,是不固定的. 为了在view中能够引用到jquery文件,我们通常都是用如下的代码 <script src="@Url.Content("~/Scripts/jquery-1.4.4.min.js")

【转】在 ASP.NET MVC 项目中使用 WebForm

ASP.NET MVC和WebForm各有各的优点,我们可能需要同时使用ASP.NET MVC和WebForm.本文介绍了如何在ASP.NET MVC项目中使用WebForm. 首先新建一个名为WebForms的文件夹用于存放WebForm,并添加一个Web窗体文件Demo.aspx作为演示. Demo.aspx就简单的输出一句话"It's a WebForm." 关键步骤在于路由设置.如果你希望WebForms这个文件夹名作为URL的一部分,也就是普通WebForm应用程序的方式来访

ServiceStack 项目实例 005 使用第一个服务功能 (在MVC项目中)

建立好服务后,我们就可以在MVC项目中使用这个服务,在使用这个服务之前,需要先确定一下它所在端口,只需要在SS项目上点右键,将其设置为启动项目,然后运行一下SS项目,在浏览器地址栏,就可以看到这个服务的端口号,并且也能看到已经添加到其中的服务.(运行的效果可以在001节中的截图看到,001节中的端口为59068.) 在MVC的Controller目录下添加一个控制器NewsController.cs,在NewsController.cs中加入一个 Action, 用来显示添加新闻的页面 publ

添加Bootstrap 到MVC项目中(vs2010)

环境:Visual Studio 2010   ASP.NET MVC3 手动添加: 下载地址:http://twitter.github.com/bootstrap/ 一个js,两个css,两张图 js 文件:  •bootstrap.min.js CSS 文件:  •bootstrap.min.css  •bootstrap-responsive.min.css image 文件:  •glyphicons-halflings.png  •glyphicons-halflings-white

ASP.NET MVC项目中App_Code目录在程序应用

学习ASP.NET MVC,如果你是开发ASP.NET MVC项目的,也许你去为项目添加前ASP.NET项目的APP_Code目录,在这里创建与添加的Class类,也许你无法在MVC项目所引用. 那这样说,是不是一没有作用了呢?非也. 从下面一步一步来学习. 创建一个model,名称:Machine using System; using System.Collections.Generic; using System.Linq; using System.Web; namespace Insu

MVC项目中使用Ztree

最近新接触了MVC,慢慢的摸索学习中,在我的mvc练习项目中需要使用Ztree展示网站的栏目导航. 在网上查找了相关资料,以及看了Ztree的API文档,最终实现了该功能. 下面进行步骤说明: 第一步: 官网下载Ztree,将css和js文件夹复制粘贴进项目中. 第二步: 引用Ztree样式和js 第三步,建立ZNode模型 /// <summary> /// 树节点 /// </summary> public class ZNode { public string id { ge