MVC 中使用uploadify上传图片遇到的蛋疼问题
初次使用uploadify上传图片,遇到了一些比较纠结的问题,在这里和大家分享下,有不对的地方还望大神多多指教,希望对刚接触的朋友有所帮助,文采不好还望见谅。新建项目,引用 uploadify脚本啥的就不说了,直接进入主题:
在Index页面放了一个上传图片的按键和脚本代码如下:
@{
ViewBag.Title = "Index";
}
<br /><br /><br />
<input id="file_upload" type="file" value="上传图片" /> <script src="@Url.Content("~/Scripts/jquery-1.8..js")"></script>
<link href="~/Content/UploadJS/uploadify.css" rel="stylesheet" />
<script src="~/Content/UploadJS/jquery.uploadify.min.js"></script>
<script type="text/javascript">
$(function () {
$("#file_upload").uploadify({
swf: '@Url.Content("~/Content/UploadJS/uploadify.swf")',// 上传使用的 Flash
uploader: '/Home/Upload', // 服务器端处理地址
//显示参数
width: , // 按钮的宽度
height: , // 按钮的高度
buttonText: "上传图片", // 按钮上的文字
buttonCursor: "hand", // 按钮的鼠标图标
buttonClass: "up_button2",
fileObjName: 'Filedata', // 上传参数名称
//规则参数
fileSizeLimit: "5000KB",
fileTypeExts: "*.jpg;*.jpeg;*.png;*.gif",//允许上传的文件扩展名 和下面一起配合使用
fileTypeDesc: "请选择 jpg、jpeg、png、gif 文件",// 文件说明
fileSizeLimit: "5MB", //允许上传的文件大小
multi: false, // 是否支持同时上传多个文件
removeTimeout: ,
onUploadSuccess: function (file,data,respose) {
var obj = jQuery.parseJSON(data); //把返回的数据序列化为Obj对象
if (obj.ret) {
alert(obj.FilePath);
}
else {
alert("");
} }
})
})
</script>
Index 页面
下面是控制器代码:
public ActionResult Index()
{
return View();
}
[HttpPost]
public ActionResult Upload(HttpPostedFileBase Filedata) {
if (Filedata != null && Filedata.ContentLength > )
{
//文件上传后的保存根路径
string filePath = Server.MapPath("~/UploadImg/");
if (!Directory.Exists(filePath))
{
Directory.CreateDirectory(filePath);
}
string fileName = Path.GetFileName(Filedata.FileName);//获取文件原名
string fileExtension = Path.GetExtension(fileName);//获取文件扩展名
string saveFileName = Guid.NewGuid().ToString() + fileExtension;//要保存的文件名称
int fileSize = Filedata.ContentLength / ;
if (fileSize > || fileSize <= )
{
return Json(new { ret = false, message = "文件上传失败,请选择小于1M的图片" });
}
else
{
Filedata.SaveAs(filePath + saveFileName);
return Json(new { ret=true,FilePath="/UploadImg/"+saveFileName});
}
}
else
{
return Json(new { ret = false, message = "请选择要上传的文件" });
}
}
控制器
在这里Upload方法里要注意一点,就是它所要接收的参数名称必须是Filedata,不区分大小写;我们在Index页面里可以看到,脚本代码里设置了 fileObjName: 'Filedata'这个属性,所以控制里接收的名称必须一样,之前在Index页面没有设置这个属性,它的默认名称就是“FileData”,我在控制器是自己随便起的名称,这样控制器接收到的对象一直为NUll;
接下来我们看看Index页面Jquery引用的问题,如果引用正确页面效果应该是这样的:
从Index页面可以看到,我引用了下这三个脚本:
一般来说这样引用 没有什么问题啊,但是我的页面呈现的效果是这样的:
坑啊,Uploadify引用的样式啥的都没有,怎么回事?用谷歌浏览F12跟踪一下看到引用了两个Jquery文件,什么情况?页面明明就引用了一次啊,怎么会出来两次,但事实就是两个,如下图:
上图可以看出不仅有两个相同的Jquery文件,而且一个还在页面的最后面才引用,重复引用导致了上传按钮样式啥的加载有误,纠结好久终于找到原因,原来在我在建项目时,是默认加载模板页的;也就是Index页面默认加载了_Layout.cshtml这个模板面,来看看这个页面的代码:
从图上可以看出,其中有@Scripts.Render("~/bundles/jquery")这句代码,原来它才是罪魁祸首啊,这句会默认引用Jquery文件,而且会在最后面引用,我们把这一句注释掉,一切就OK了。
接下来再说一点与上传无关的题外话,我们可以看到_Layout.cshtml这个模板面还有一句代码“@RenderSection("scripts", required: false)”,果断不知道具体是干什么用的啊,所以我就把它改为required: true,接下来调试运行,竟然出错了,好吧,是Jquery引用的问题,接下来我又把Index的页面的引用改成这样:
好了,页面不报错了,但是这样引用的文件和@Scripts.Render("~/bundles/jquery")这句引用的Jquery文件一样都在页面的的最后面,这样我的上传按钮还是没有样式,不能实现异步上传。好了,说了这么多废话,最后就是想让初次遇到这类问题的朋友多多注意默认加载模板页和Jquery引用的问题。
有什么不对的地方还希望大家帮忙指出,大家一起分享,共同成长。