图片上传和显示——上传图片——上传文件)==ZJ

2023-12-09 17:58
文章标签 显示 图片 上传 zj

本文主要是介绍图片上传和显示——上传图片——上传文件)==ZJ,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://www.cnblogs.com/yc-755909659/archive/2013/04/17/3026409.html aspx上传

http://www.cnblogs.com/mq0036/p/3715024.html  异步上传

-----------------------------------------ZJ版

MVC中利用ajaxfileupload.js插件实现异步上传:(这个既可以实现图片上传也可以实现文件上传)

JS引入:

<script src="~/Scripts/jquery-1.8.2.min.js"></script>
<script src="~/Content/UploadFile/ajaxfileupload.js"></script>

前台实现:

//Html部分
<div>
<h2>请选择要上传的文件</h2>
<input type="file" id="imgFile" name="imgFile" /><input type="button" value="上传" id="btnUp"/>
<br />
<div>
<img id="articleFacePhotoImg" />
</div>
</div>
//JS引入
<script src="~/Scripts/jquery-1.8.2.min.js"></script>
<script src="~/Content/UploadFile/ajaxfileupload.js"></script>
//上传文件JS调用代码
<script type="text/javascript">
//异步上传文件
uploadFacePhoto = function () {
//判断内容是否为空
if ($("#imgFile").val().length <= 0) {
return;
}
//执行异步上传
            $.ajaxFileUpload({
url: '@Url.Action("UploadImg","Home")',//上传到文件服务器请求地址
type: 'post',
data: { dir: 'image' },//自定义参数
secureuri: false,//是否需要安全协议,一般设置为false
fileElementId: 'imgFile',//文件上传遇的ID
dataType: 'json',//返回值类型,一般设置为json
success: function (data)//服务器成功响应处理函数
                {
//由于ajaxFileUpload把原来的file元素替换成新的file元素,所以之前绑定的change事件就失效了,需要重新绑定一下
$("#imgFile").change(function () {
uploadFacePhoto();
})                   
if (data.error == 0) {
$("#articleFacePhotoImg").attr("src", data.url);
} else {
alert(data.message);
}
}
});
}
//绑定文章封面文件域改变事件       
$("#imgFile").change(function () {
uploadFacePhoto();
});
//点击实现上传
//$("#btnUp").click(function () {
//    uploadFacePhoto();
//});
</script>
View Code

//后台实现:

/// <summary>
/// 上传文件
/// </summary>
/// <returns></returns>
public ActionResult UploadImg(HttpPostedFileBase imgFile,string dir)
{
//定义允许上传的文件的扩展名
Hashtable extTable = new Hashtable();
extTable.Add("image", "gif,jpg,jpeg,png,bmp");
extTable.Add("flash", "swf,flv");
extTable.Add("media", "swf,flv,mp3,wav,wma,wmv,mid,avi,mpg,asf,rm,rmvb");
extTable.Add("file", "doc,docx,xls,xlsx,ppt,htm,html,txt,zip,rar,gz,bz2");
if(String.IsNullOrEmpty(dir))
{
dir = "image";
}
if(!extTable.ContainsKey(dir))//如果不包含
            {
return Content(JsonConvert.SerializeObject(new { error = 1, message = "文件格式不正确" }));
}
if (imgFile == null)
{
return Content(JsonConvert.SerializeObject(new { error=1,message="上传文件大小超过限制"}));
}
string fileName = imgFile.FileName;
string fileExt = Path.GetExtension(fileName).ToLower();
if (String.IsNullOrEmpty(fileExt) || Array.IndexOf(((String)extTable[dir]).Split(','), fileExt.Substring(1).ToLower()) == -1)
{
return Content(JsonConvert.SerializeObject(new { error = 1, message = "上传文件扩展名是不允许的扩展名。\n只允许" + ((String)extTable[dir]) + "格式" }));
}
//创建文件夹
string dirPath = "/Files/" + dir + "/";
if (!Directory.Exists(Request.MapPath(dirPath)))
{
//不存在就创建
                Directory.CreateDirectory(Request.MapPath(dirPath));
}
//   string newFileName = DateTime.Now.ToString("yyyyMMddHHmmss_ffff") + fileExt;//注意这个写法文件名会有重复,要想不重复请使用Guid或其它方法。有坑需谨慎
imgFile.SaveAs(Request.MapPath(dirPath + newFileName));
//判断保存的文件是否存在
if (System.IO.File.Exists(Request.MapPath(dirPath + newFileName)))
{
return Content(JsonConvert.SerializeObject(new { error=0,url=dirPath+newFileName}));
}
else
{
return Content(JsonConvert.SerializeObject(new { error=1,message="上传文件失败!"}));
}           
}

 

ajaxfileupload.js文件链接:http://pan.baidu.com/s/1i4Xezyd 密码:om9x

----------------------上面是简单的图片文件上传演示,下面简单演示下富文本编辑器的使用-------------

前台实现:

//Html部分
<div>
<!--编辑器开始-->
<textarea id="editor" name="content" style="width:100%;height:100%"></textarea>
<input type="button" id="btnSub" value="提交"/>
</div>
//JS部分
<script type="text/javascript">
$(function () {
//编辑器初始化
            KindEditor.ready(function (K) {
window.editor = K.create('#editor', {
uploadJson: '@Url.Action("UploadImg","Home")'
});
});
$("#btnSub").click(function () {               
var articleContent = editor.html();
alert(articleContent);
});
})
</script>
//引入文件
<script src="~/Scripts/jquery-1.8.2.min.js"></script>
<script src="~/Scripts/kindeditor/kindeditor-all-min.js"></script>
<script src="~/Scripts/kindeditor/plugins/code/code.js"></script>
View Code

后台实现和上面的上传文件后台一致,下面是引入文件链接:http://pan.baidu.com/s/1o8GV1pg 密码:4uum(百度云:KindEditor文件夹)

最后来张图片吧:

这篇关于图片上传和显示——上传图片——上传文件)==ZJ的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/474592

相关文章

input的accept属性让文件上传安全高效

《input的accept属性让文件上传安全高效》文章介绍了HTML的input文件上传`accept`属性在文件上传校验中的重要性和优势,通过使用`accept`属性,可以减少前端JavaScrip... 目录前言那个悄悄毁掉你上传体验的“常见写法”改变一切的 html 小特性:accept真正的魔法:让

Java使用Spire.Doc for Java实现Word自动化插入图片

《Java使用Spire.DocforJava实现Word自动化插入图片》在日常工作中,Word文档是不可或缺的工具,而图片作为信息传达的重要载体,其在文档中的插入与布局显得尤为关键,下面我们就来... 目录1. Spire.Doc for Java库介绍与安装2. 使用特定的环绕方式插入图片3. 在指定位

idea粘贴空格时显示NBSP的问题及解决方案

《idea粘贴空格时显示NBSP的问题及解决方案》在IDEA中粘贴代码时出现大量空格占位符NBSP,可以通过取消勾选AdvancedSettings中的相应选项来解决... 目录1、背景介绍2、解决办法3、处理完成总结1、背景介绍python在idehttp://www.chinasem.cna粘贴代码,出

Python多任务爬虫实现爬取图片和GDP数据

《Python多任务爬虫实现爬取图片和GDP数据》本文主要介绍了基于FastAPI开发Web站点的方法,包括搭建Web服务器、处理图片资源、实现多任务爬虫和数据可视化,同时,还简要介绍了Python爬... 目录一. 基于FastAPI之Web站点开发1. 基于FastAPI搭建Web服务器2. Web服务

java对接Pinata上传文件到IPFS全过程

《java对接Pinata上传文件到IPFS全过程》本文详细介绍了如何使用PinataAPI将文件上传到IPFS网络,首先登录Pinata官网并生成JWT令牌,然后在项目中导入OkHttp依赖并编写代... 目录1.登录2.生成令牌3.导入依赖4.编写代码5.调用接口调试China编程代码总结Pinata调用AP

利用Python将PDF文件转换为PNG图片的代码示例

《利用Python将PDF文件转换为PNG图片的代码示例》在日常工作和开发中,我们经常需要处理各种文档格式,PDF作为一种通用且跨平台的文档格式,被广泛应用于合同、报告、电子书等场景,然而,有时我们需... 目录引言为什么选择 python 进行 PDF 转 PNG?Spire.PDF for Python

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

C#实现SHP文件读取与地图显示的完整教程

《C#实现SHP文件读取与地图显示的完整教程》在地理信息系统(GIS)开发中,SHP文件是一种常见的矢量数据格式,本文将详细介绍如何使用C#读取SHP文件并实现地图显示功能,包括坐标转换、图形渲染、平... 目录概述功能特点核心代码解析1. 文件读取与初始化2. 坐标转换3. 图形绘制4. 地图交互功能缩放

Android实现图片浏览功能的示例详解(附带源码)

《Android实现图片浏览功能的示例详解(附带源码)》在许多应用中,都需要展示图片并支持用户进行浏览,本文主要为大家介绍了如何通过Android实现图片浏览功能,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv