前言

最近项目更新一个新需求,要求把图片储存在SQLserver中,而不是储存在本地磁盘。很好,又有新东西可以学了。

正文

一、建表

这里大概建几个字段演示一下

CREATE TABLE [dbo].[ImageFile](
[Id] [UNIQUEIDENTIFIER] NOT NULL,
[Name] [NVARCHAR](200) NULL,--文件名
[Type] [NVARCHAR](50) NULL,--文件类型
[Image] [IMAGE] NULL--文件
)

二、插入数据

一般写入数据在后端结合业务,这里只写一个控制台测试


/// <summary>
/// 插入图片
/// </summary>
/// <param name="filePath">图片文件夹路径</param>
public void ImportImage(string filePath)
{
string conn = "server=.;database=Test;Uid=sa;Pwd=1;";
using (SqlConnection myconn = new SqlConnection(conn))
{
myconn.Open();
using (SqlCommand mycomm = new SqlCommand())
{
foreach (FileInfo item in dir.GetFiles("*.jpg"))//循环读取文件夹内的jpg文件
{
var pic = getJpgSize(item.FullName);
string str = string.Format("insert into ImageFile (ImageFileId,Name,Type,Image) values('{0}','{1}','{2}',@file)", Guid.NewGuid().ToString(), Path.GetFileNameWithoutExtension(item.FullName), item.Extension.Substring(1));//插入数据
mycomm.CommandText = str;
mycomm.Connection = myconn;
FileStream fs = new FileStream(item.FullName, FileMode.Open);
BinaryReader br = new BinaryReader(fs);
Byte[] byData = br.ReadBytes((int)fs.Length);
fs.Close();
mycomm.Parameters.Add("@file", SqlDbType.Binary, byData.Length);
mycomm.Parameters["@file"].Value = byData;
mycomm.ExecuteNonQuery();
mycomm.Parameters.Clear();
}
}
}
}

三、读取文件

这一步根据不同的ORM框架来获取,可用 byte[] 对象承接图片

四、前端显示

1、这里默认是 png 格式,可根据实际情况写别的格式,jpg和png格式两个可以互换,只是记得png图片如果有透明区域转jpg后会变为白色,具体的大家可以试试

2、base64直接使用宽高默认为0,所以图片在 onload 时获取图片宽高

前端页面:

<img src="data:image/png;base64,这里写你的Base64代码" onload="imageLoad(this)" />

脚本:

// 获取图片真实高度
function imageLoad(_this) {
var imageSrc = $(_this).attr("src");
var img = new Image();
img.src = imageSrc;
// 如果图片被缓存,则直接返回缓存数据
if (img.complete) {
var width = img.width > img.height ? 550 : 310;
var height = img.height / img.width * width;
$(_this).css("width", width + "px")
$(_this).css("height", height + "px")
} else {
img.onload = function () {
var width = img.width > img.height ? 550 : 310;
var height = img.height / img.width * width;
$(_this).css("width", width + "px")
$(_this).css("height", height + "px")
}
}
}

五、图片放大

如果需要对图片进行放大,但是项目内的插件没有带这个功能,可以使用下面的方法

image增加单击事件:

<img onclick="imgEnlarge(this)" src="data:image/png;base64,这里写你的Base64代码" onload="imageLoad(this)" />

前端页面增加一个div:

<div id="imgEnlargeDiv" style="display: none; text-align: center;position: fixed;z-index: 1000;top: 0;left: 0;width: 100%;height: 100%;background-color: rgba(255,255,255,.9);">
<img id="bigimg" style="height: 90%;width: auto;border: 0px;margin: auto;position: absolute;top: 0;bottom: 0;left: 0;right: 0;" src="" />
</div>

脚本:

$(function () {
$("#imgEnlargeDiv").click(function () {//再次点击淡出消失弹出层
$(this).fadeOut("fast");
});
}); function imgShow(outerdiv, bigimg, _this) {
var src = _this.attr("src");//获取当前点击的pimg元素中的src属性
$(bigimg).attr("src", src);//设置#bigimg元素的src属性
$(outerdiv).fadeIn("fast"); //图片放大的div快速淡入显示层
} function imgEnlarge(_this) {
imgShow("#imgEnlargeDiv", "#bigimg", $(_this));
$("img[type ='showImg']").mouseover(function () {
$(this).css("cursor", "pointer");//鼠标移动到图片,鼠标箭头变为手势
});
$("img[type ='showImg']").click(function () {
var _this = $(this);//将当前的pimg元素作为_this传入函数
imgShow("#imgEnlargeDiv", "#bigimg", _this);
});
}

最后

这些东西很多都是利用网上有的,只是个人感觉都比较零散,所以整理出来给大家参考,也是给我自己做一份笔记。

同时感谢那些乐于分享的人!

SQLserver用Image格式储存图片的更多相关文章

  1. iPhone照片格式heic图片怎么打开

    苹果自iOS11系统之后默认的是heic图片格式,在电脑和安卓中都无法直接查看,需要将其转换图片格式,那苹果heic图片怎么转换成jpg格式?下面我们一起来看看吧! 使用工具:电脑.图片 操作方法: ...

  2. ElementUI的Upload上传,配合七牛云储存图片

    七牛云服务器的储存区域 存储区域 地域简称 上传域名 华东 z0 服务器端上传:http(s)://up.qiniup.com 华东 z0 客户端上传: http(s)://upload.qiniup ...

  3. java利用16进制来辨别png格式的图片

    很多人知道利用.png的字符串结尾可以判断前端传入的图片是否为png格式,但是这只是潜意识的判断!那么如何利用png读写的特殊内容来深意识地判断图片格式呢?最近在做东西的时候遇到了点问题,在加载图片的 ...

  4. 利用ArcMap对tiff或jpg格式地图图片的配准步骤

    原文:利用ArcMap对tiff或jpg格式地图图片的配准步骤 在实际应用中,经常会遇到提供一张高精度的地图图片文件,如何对将该图片进行配准(使图片具有经纬度坐标). 当然我们得有一些大概的参考图层, ...

  5. gif格式的图片不能存在与包含js目录的路径中?

    如题:gif格式的图片不能存在与包含js目录的路径中?是我的设置问题?还是真不能存在于js目录中. 今天纠结了一下午,某个项目中的效果就是出不来,找了差不多两个半小时... 在D盘新建一个js和jss ...

  6. 利用jpedal进行pdf转换成jpeg,jpg,png,tiff,tif等格式的图片

    项目中运用到pdf文件转换成image图片,开始时使用pdfbox开源库进行图片转换,但是转换出来的文件中含有部分乱码的情况.下面是pdfBox 的pdf转换图片的代码示例. try{ String ...

  7. jpg、png格式的图片转换成webp后颜色失真的问题

    今天简单的试用了一下 cweb.exe 将 jpg, png 格式的图片转换成 webp 格式. 我今天下载的是当前最新版:1.0.0 cwebp 3.jpg  -q 85 -o 3.webp 发现图 ...

  8. png格式的图片在IE6 下透明解决方案

    FF和IE7已经直接支持透明的png图了,下面这个主要是解决IE6下透明PNG图片有灰底的 style="FILTER: progid:DXImageTransform.Microsoft. ...

  9. python模块之imghdr(识别不同格式的图片文件)

    # -*- coding: utf-8 -*- #python 27 #xiaodeng #python模块之imghdr(识别不同格式的图片文件) import imghdr '''>> ...

随机推荐

  1. CDN是什么鬼

    CDN,内容分发网络,是大多数互联网业务里必不可少的部分,但大多数互联网从业人员不是特别清楚CDN究竟是什么,以及它可以为我们做哪些事情. 我们还是从之前介绍的<不同的人看到的直播为什么不一样? ...

  2. Proxmox如何进入单人维护模式(重置root密码)

    官网连接:https://pve.proxmox.com/wiki/Root_Password_Reset Root Password Reset     Contents [hide] 1Reset ...

  3. Java Design Patterns(2)

    1.Factory Design pattern 工厂设计模式的优点 (1)工厂设计模式提供了接口而不是实现的代码方法. (2)工厂模式从客户端代码中删除实际实现类的实例化.工厂模式使我们的代码更健壮 ...

  4. python 常用模块介绍

    1.定义 模块:用来从逻辑上组织python代码(变量.函数.类,逻辑),本质就是.py结尾的python文件(文件名:test.py,对应的模块名:test). 包:用来从逻辑上组织模块的,本质就是 ...

  5. Java 笔试面试(6)异常处理

    Java 笔试面试(6)异常处理 1. finally的代码何时执行? 问题描述:try{}里有一个return语句,那么在这个try后面的finally{}中的代码是否为执行?如果会,是在retur ...

  6. 乱世兄弟(豹老头 X 天捣臼)

    论CP之冷冷冷 只为白凡扫剧- 片源: 乱世兄弟 BGM:兄弟 人物角色: 豹老头 - 白凡 天捣臼 大专栏  乱世兄弟(豹老头 X 天捣臼)- 姚鲁 B站:豹老头 X 天捣臼-MV<乱世兄弟& ...

  7. Typora+PicGo+Gitee笔记方案

    前言:需要学习的知识太多,从一开始就在寻找一款能让我完全满意的编辑器,然而一直都没有令我满意的.在前两天Typora新版本更新后,总算是拥有了一套我认为很完美的笔记方案:使用Typora编写markd ...

  8. python 临时文件

    1. TemporaryFile 临时文件 TemporaryFile 不在硬盘上的生成真正文件,而是写在内存中 from tempfile import TemporaryFile # , Name ...

  9. 47-Python进阶小结

    目录 Python进阶小结 一.异常TODO 二.深浅拷贝 2.1拷贝 2.2 浅拷贝 2.3 深拷贝 三.数据类型内置方法 3.1 数字类型内置方法 3.1.1 整型 3.1.2 浮点型 3.2 字 ...

  10. LeetCode--链表2-双指针问题

    LeetCode--链表2-双指针问题 思考问题: 判断一个链表是否有环 列举几种情况: graph LR A-->B B-->C C-->D D-->E E-->C g ...