• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >ASP.NET > ASP.NET实现图片以二进制的形式存入数据库

ASP.NET实现图片以二进制的形式存入数据库

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了上传图片 asp.net,asp.net,asp net培训,asp和asp.net的区别,零基础学asp.net等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

本文以实例形式讲述了ASP.NET实现图片以二进制的形式存入数据库的方法。过去我们都是直接在数据库中存入图片文件名的,还没有试过存储整张图片到数据库中,经过一番资料查询与测试,整理出了如下的功能代码:

1.建立保存图片的表的SQL语句:

USE [niunantest] 
GO 
/****** 对象: Table [dbo].[picdata]  脚本日期: 03/30/2010 14:51:58 ******/ 
SET ANSI_NULLS ON 
GO 
SET QUOTED_IDENTIFIER ON 
GO 
CREATE TABLE [dbo].[picdata]( 
  [id] [int] IDENTITY(1,1) NOT NULL, 
  [content] [image] NULL, 
  [createdate] [datetime] NOT NULL CONSTRAINT [DF_picdata_createdate] DEFAULT (getdate()), 
 CONSTRAINT [PK_picdata] PRIMARY KEY CLUSTERED  
( 
  [id] ASC 
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] 
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] 

</div>

2.下面是保存图片到数据库中的代码片段:

int len = fu.PostedFile.ContentLength; // 图片大小 
byte[] pic = new byte[len]; // 创建一个字节数组,大小为图片的大小,数据库中就存储这个东西 
fu.PostedFile.InputStream.Read(pic, 0, len); // 把上传控件中的文件用二进制读取存到pic字节数组中 
//  插入图片到数据库中    
SqlConnection connection = new 
SqlConnection(@"server=.\sqlexpress;database=niunantest;uid=sa;pwd=123456"); 
try 
{ 
  connection.Open(); 
  SqlCommand cmd = new SqlCommand("insert  into  picdata  " 
  + "([content])  values  (@pic)", connection); 
  cmd.Parameters.Add("@pic", pic); 
  cmd.ExecuteNonQuery(); 
  Label1.Text = "图片插入数据库成功!"; 
 
  Image1.ImageUrl = "getpic.ashx?t=" + DateTime.Now.Ticks; // 显示刚刚插入数据库的图片 
} 
finally 
{ 
  connection.Close(); 
}  
 

</div>

3.下面是从数据库中取出图片的代码片段:

MemoryStream stream = new MemoryStream(); 
SqlConnection connection = new 
SqlConnection(@"server=.\sqlexpress;database=niunantest;uid=sa;pwd=123456"); 
try 
{ 
  connection.Open(); 
  SqlCommand command = new 
  SqlCommand("select top 1 [content]  from  picdata order by id desc", connection); 
  byte[] image = (byte[])command.ExecuteScalar(); 
  stream.Write(image, 0, image.Length); 
  Bitmap bitmap = new Bitmap(stream); 
  context.Response.ContentType = "image/jpeg"; 
  bitmap.Save(context.Response.OutputStream, System.Drawing.Imaging.ImageFormat.Jpeg); 
} 
finally 
{ 
  connection.Close(); 
  stream.Close(); 
}

</div>

程序的原理其实也就是通过流把图片搞成字节数组再存到数据库中,然后再从数据库中读取字节数组出来,再通过字节数组创建流,再通过流把图像输出出来,发现你存到数据库中的是gif图像的话再取出来是可以把他转为jpg的图像的,因为在取出图像的时候我们设置他的ContentType是image/jpeg了。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • ASP.NET实现上传Excel功能
  • asp.net图片文件的上传与删除方法
  • ASP.NET图片处理三类经典问题
  • Asp.Net上传图片同时生成高清晰缩略图
  • ASP.NET中图片显示方法实例
  • ASP.NET实现图片以二进制的形式存入数据库
  • asp.net文件上传示例分享
  • ASP.net判断上传文件类型的三种有效方法
  • asp.net图片上传实例
  • ASP.net WebAPI 上传图片实例

相关文章

  • 2017-05-11asp.net 支付宝及时到帐接口使用详解
  • 2017-05-11asp.net 序列化and反序列化演示
  • 2017-05-11蛇年多屏图片切换(可添加图片链接以及编辑标题)
  • 2017-05-11在ASP.NET 2.0中操作数据之十:使用 GridView和DetailView实现的主/从报表
  • 2017-05-11SQL Server 2005安装过程中出现错误的解决办法
  • 2017-05-11排除JQuery通过HttpGet调用WebService返回Json时“parserror”错误
  • 2018-08-20MVC数据验证详解
  • 2017-05-11.net自定义事件示例分享
  • 2017-05-11asp.net和ajax实现智能搜索功能代码
  • 2017-05-11.net jquery绘制自定义表单源码分享

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C# Quoted-Printable编码、解码
    • ASP.NET从客户端中检测到有潜在危险的request.form值的3种解决方法
    • Asp.net mvc 数据调用示例代码
    • asp.net 导出到CSV文件乱码的问题
    • ASP.NET Core 2.0 WebApi全局配置及日志实例
    • Asp.Net 无刷新文件上传并显示进度条的实现方法及思路
    • document.getElementsByName和document.getElementById 在IE与FF中不同实现
    • DataSet 添加数据集、行、列、主键和外键等操作示例
    • Asp.Net各种超时问题总结
    • asp.net求3位不同数字的组合数

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有