JQuery文件上传及以Base64字符串形式呈现图片
一:上传之
首先,你必然得有一个 file input,如下:
<td>
<img id="imgGif" style="display: none" />
<input type="file" id="imgGifFile" name="imgGifFile" value="选择图片" class="easyui-validatebox"
data-options="
@if (ViewBag.IsEdit != true)
{
@:required: true,missingMessage:'请选择课程图片!',
}
" />
</td>
其次,让我们 upload,如下:
$.ajaxFileUpload({
url: '@ViewBag.Domain/Course/CreateUpdate',
type: 'post',
data: otherObj,
secureuri: false,
fileElementId: 'imgGifFile',
dataType: 'json',
success: function (data) {
$("#courseBank").datagrid("reload");
if ($("#Id").val() != "") {
$.messager.alert("提示", "课程修改成功!");
} else {
$.messager.alert("提示", "课程添加成功!");
}
},
error: function () {
window.OnLoadFunc.isSaved();
$.messager.alert("提示", "服务器无响应,请稍后重试!");
}
});
其中,fileElementId 就是我们的 file input 的 Id 值,除此之外,如果我们要同时提交表单数据,则可以构建一个如上的 otherObj,是一个 json 对象。类似如下,
var result = {
Id: $("#Id").val(),
CategoryId: $("#categoryTree").tree("getSelected").id,
Name: $("#name").val};
那么,服务端代码如下:
public void CreateUpdate(Course course)
{
HttpPostedFileBase imgGifFile = Request.Files["imgGifFile"];
course.ImgGif = ImageHelper.GetImgByte(imgGifFile);
if (!string.IsNullOrEmpty(course.Id))
{
_courseDal.Update(course);
}
else
{
course.Id = Guid.NewGuid().ToString().Replace("-", string.Empty);
course.Creator = user.Id;
_courseDal.Insert(course);
}
}
服务器端,首先会自动根据 JSON 内容,构造 Course 对象,但是,文件需要通过 Request.Files["imgGifFile"]; 来进行获取的,获取完毕你就可以转成二进制存放到数据库。注意到ImageHelper,为一个帮助类,后面会专门贴出代码。
二:从数据库读出来并转为base64字符串,并在网页上呈现出来
先看前台代码:
$('#imgGif').attr("width", "100px");
$('#imgGif').attr("height", "100px");
$('#imgGif').attr("src", "@ViewBag.ImgGifSrc");
$('#imgGif').show();
$('#imgGif').after("<br/>");
无非就是ImgGifSrc,它是字符串如下:
ViewBag.ImgGifSrc = ImageHelper.Base64ImgToSrc(ViewBag.EditCourse.ImgGif);
现给出ImageHelper:
using System;
using System.Collections.Generic;
using System.Drawing.Imaging;
using System.Globalization;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Web;namespace YHBJ.Utility.Web
{
public class ImageHelper
{
public static byte[] GetImgByte(HttpPostedFileBase imgFileBase)
{
if (imgFileBase != null && !string.IsNullOrEmpty(imgFileBase.FileName))
{
var len = imgFileBase.ContentLength;
byte[] bytes = null;
using (var obj = new BinaryReader(imgFileBase.InputStream))
{
bytes = obj.ReadBytes(len);
}if (bytes.Length > 2)
{
string fileclass = string.Empty;
try
{
fileclass = bytes[0].ToString(CultureInfo.InvariantCulture);
fileclass += bytes[1].ToString(CultureInfo.InvariantCulture);
}
catch
{
}String[] fileType = { "7173", //gif
"255216", //jpg
"6677" //bmp
};var flag = fileType.Any(t => fileclass == t);
if (flag)
{
return bytes;
}
}
}return null;
}public static string Base64ImgToSrc(byte[] imgBytes)
{
if (imgBytes == null)
{
return string.Empty;
}using (var stream = new MemoryStream(imgBytes))
{
using (var image = System.Drawing.Image.FromStream(stream))
{
return string.Format(
"data:image/{0};base64,{1}",
GetImageExtension(image),
Convert.ToBase64String(imgBytes));
}
}
}private static string GetImageExtension(System.Drawing.Image image)
{
var imgFormatList = typeof(ImageFormat).GetProperties(BindingFlags.Static | BindingFlags.Public);foreach (var item in imgFormatList)
{
var imgFormat = (ImageFormat)item.GetValue(null, null);
if (imgFormat.Guid.Equals(image.RawFormat.Guid))
{
return item.Name.ToLower();
}
}return "gif";
}
}
}
要注意的是,base64格式的图片,有上限限制,默认多少来着,Anyway,bing之。
另,check图片格式:
if ($("#imgGifFile").val() != "") {
var strRegex = "(.gif|.GIF)$"; //用于验证图片扩展名的正则表达式
var re = new RegExp(strRegex);
if (!re.test($("#imgGifFile").val())) {
$.messager.alert("提示", "必须是gif图片!");
return false;
}
}
JQuery文件上传及以Base64字符串形式呈现图片的更多相关文章
- 强大的支持多文件上传的jQuery文件上传插件Uploadify
支持多文件上传的jQuery文件上传插件Uploadify,目前此插件有两种版本即Flash版本和HTML5版本,对于HTML5版本会比较好的支持手机浏览器,避免苹果手机Safari浏览器不支持Fla ...
- jQuery文件上传插件Uploadify(转)
一款基于flash的文件上传,有进度条和支持大文件上传,且可以多文件上传队列. 这款在flash的基础上增加了html5的支持,所以在移动端也可以使用. 由于官方提供的版本是flash免费,html5 ...
- 文件上传三:base64编码上传
介绍三种上传方式: 文件上传一:伪刷新上传 文件上传二:FormData上传 文件上传三:base64编码上传 Flash的方式也玩过,现在不推荐用了. 优点: 1.浏览器可以马上展示图像,不需要先上 ...
- jQuery文件上传插件jQuery Upload File 有上传进度条
jQuery文件上传插件jQuery Upload File 有上传进度条 jQuery文件上传插件jQuery Upload File,插件使用简单,支持单文件和多文件上传,支持文件拖拽上传,有进度 ...
- 20款最好的jQuery文件上传插件
当它是关于开发网络应用程序和网页的时候,文件上传功能的重要性是不容忽视的.一个文件上传功能可以让你上传所有类型的文件在网站上,包括视频,图像,文件和更多.创建一个文件上传功能,对你的网站是不是很难,有 ...
- jQuery 文件上传插件:uploadify、swfupload
jQuery 文件上传插件: uploadify.swfupload
- JQuery文件上传插件JQuery.upload.js的用法简介
JQuery文件上传插件,这个插件很小,用法很简单,效果却很棒.注意:JQuery版本要求1.8及以上,大家执行如果没效果,则检查JQuery版本,如果是1.8及以上,则该插件源码中的.size()需 ...
- 可拖拽和带预览图的jQuery文件上传插件ssi-uploader
插件描述:ssi-uploader是一款带预览图并且可以拖拽文件的jQuery ajax文件上传插件.该文件上传插件支持AJAX,支持多文件上传,可控制上的文件格式和文件大小,提供各种回调函数,使用非 ...
- jquery文件上传控件 Uploadify
(转自 http://www.cnblogs.com/mofish/archive/2012/11/30/2796698.html) 基于jquery的文件上传控件,支持ajax无刷新上传,多个文件同 ...
随机推荐
- IDEA创建Spring Boot项目
首先安装Spring Boot CLI 先确定自己安装的JDK是1.8版本或者以上,然后下载Srping Boot CLI,Spring Boot CLI下载地址,下载下来是一个压缩包,解压,得到一个 ...
- 教你如何清除 MyEclipse/Eclipse 中 Web Browser 和 Switch Workspace 的历史记录
有些许强迫症的开发人员可能会因为 MyEclipse/Eclipse 中 Web Browser 和 Switch Workspace 冗余的历史记录而感到苦恼,下面的方法就可以有效的帮助解决你的痛点 ...
- ubuntu 安装 eslint
1. 安装 npm install -g eslint 安装结束后记住 /usr/local/bin/eslint -> /usr/local/lib/node_modules/eslint/b ...
- Python 学习之list和Tuple类型
1.创建list L = ['Adam', 95.5, 'Lisa', 85, 'Bart', 59] print(L) print(L[1],L[3],L[5])#索引 不能越界 正向访问 #95. ...
- 六、django rest_framework源码之解析器剖析
1 绪论 网络传输数据只能传输字符串格式的,如果是列表.字典等数据类型,需要转换之后才能使用但是我们之前的rest_framework例子都没有转换就直接可以使用了,这是因为rest_framewor ...
- Bzoj4548 小奇的糖果(链表+树状数组)
题面 Bzoj 题解 很显然,我们只需要考虑单独取线段上方的情况,对于下方的把坐标取反再做一遍即可(因为我们只关心最终的答案) 建立树状数组维护一个横坐标区间内有多少个点,维护双向链表实现查询一个点左 ...
- 用Python开始机器学习(3:数据拟合与广义线性回归)
机器学习中的预测问题通常分为2类:回归与分类. 简单的说回归就是预测数值,而分类是给数据打上标签归类. 本文讲述如何用Python进行基本的数据拟合,以及如何对拟合结果的误差进行分析. 本例中使用一个 ...
- BZOJ2673 [Wf2011]Chips Challenge 费用流 zkw费用流 网络流
https://darkbzoj.cf/problem/2673 有一个芯片,芯片上有N*N(1≤N≤40)个插槽,可以在里面装零件. 有些插槽不能装零件,有些插槽必须装零件,剩下的插槽随意. 要求装 ...
- hdu 5305 Friends(2015多校第二场第6题)记忆化搜索
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5305 题意:给你n个人,m条关系,关系可以是online也可以是offline,让你求在保证所有人on ...
- hdu 2216 bfs
题目大意:两个东西朝相同方向移动Sample Input4 4XXXX.Z...XS.XXXX4 4XXXX.Z...X.SXXXX4 4XXXX.ZX..XS.XXXXSample Output11 ...