一、逻辑实现:将数据库中的二进制TIFF图片读出并分页显示在页面上。

1.显示界面

 public FrameDimension MyGuid;
public static int MyPos = ;
public static int totalPage = ;
public static MemoryStream stream;
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
string username = Request.QueryString["username"];
string sql = string.Format("select top(1) image from Image_Table where image_code=( select new_sjbh from new_ksy_dzpz where new_ksy_dzpzid='{0}' ) ", username);
DataTable dt = SqlHelper.GetTable(sql);
if (dt.Rows.Count > )
{
Image1.ImageUrl = "ShowImage.aspx?username=" + username + "&pagecount=0";
stream = new MemoryStream((byte[])dt.Rows[]["image"]);
// Bitmap bt = new Bitmap(Server.MapPath(Image1.ImageUrl));
Bitmap bt = new Bitmap(stream);
Guid gud = (Guid)bt.FrameDimensionsList.GetValue();
FrameDimension fds = new FrameDimension(gud);
totalPage = bt.GetFrameCount(fds);//获取页数
this.LabelPageCount.Text = totalPage.ToString();
this.LabelCurrentPage.Text = "";
if (totalPage == )
{
this.LinkButtonPreviousPage.Enabled = false;//上一页只读
this.LinkButtonFirstPage.Enabled = false;//首页只读
this.LinkButtonNextPage.Enabled = false;//下一页只读
this.LinkButtonLastPage.Enabled = false;//尾页只读
this.btnGo.Enabled = false; }
}
this.LinkButtonPreviousPage.Enabled = false;//上一页只读
this.LinkButtonFirstPage.Enabled = false;//首页只读
} }
//下载
protected void Button1_Click(object sender, EventArgs e)
{
string username = Request.QueryString["username"];
string sql = string.Format("select top(1) image,name from Image_Table where image_code=( select new_sjbh from new_ksy_dzpz where new_ksy_dzpzid='{0}' ) ", username);
DataTable dt = SqlHelper.GetTable(sql);
if (dt.Rows.Count > )
{
byte[] bytes = (byte[])dt.Rows[]["image"];
//下载单个凭证
Response.Buffer = true;
Page.Response.Clear();//清除缓冲区所有内容
Page.Response.ContentType = "application/octet-stream";
Page.Response.AddHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(dt.Rows[]["name"].ToString()) + ".tiff");
Response.BinaryWrite(bytes);
Response.Flush();
Response.End();
}
} //下一页
protected void LinkButtonNextPage_Click(object sender, EventArgs e)
{
int page = Convert.ToInt32(this.LabelCurrentPage.Text);
this.LabelCurrentPage.Text = Convert.ToString(page + );
fenyeshow(page);
} //上一页
protected void LinkButtonPreviousPage_Click(object sender, EventArgs e)
{
int page = Convert.ToInt32(this.LabelCurrentPage.Text) - ;
this.LabelCurrentPage.Text = Convert.ToString(page + );
fenyeshow(page);
}
//首页
protected void LinkButtonFirstPage_Click(object sender, EventArgs e)
{
int page = ;
this.LabelCurrentPage.Text = "";
fenyeshow(page);
}
//尾页
protected void LinkButtonLastPage_Click(object sender, EventArgs e)
{
int page = Convert.ToInt32(this.LabelPageCount.Text) - ;
this.LabelCurrentPage.Text = this.LabelPageCount.Text;
fenyeshow(page);
}
//Go
protected void btnGo_Click(object sender, EventArgs e)
{
int page = ;
if (this.txtNewPageIndex.Text != "")
{
int pagecount = Convert.ToInt32(this.LabelPageCount.Text);
int txt = Convert.ToInt32(this.txtNewPageIndex.Text);
if (txt <= pagecount && txt > )
{
page = Convert.ToInt32(this.txtNewPageIndex.Text) - ;
this.LabelCurrentPage.Text = this.txtNewPageIndex.Text;
}
}
if (page == )
{
this.LabelCurrentPage.Text = "";
}
fenyeshow(page);
}
//显示页面
public void fenyeshow(int pagecount)
{
string username = Request.QueryString["username"];
Image1.ImageUrl = "ShowImage.aspx?username=" + username + "&pagecount=" + pagecount.ToString();
if (this.LabelCurrentPage.Text == "")
{
this.LinkButtonPreviousPage.Enabled = false;//上一页只读
this.LinkButtonFirstPage.Enabled = false;//首页只读
this.LinkButtonNextPage.Enabled = true;
this.LinkButtonLastPage.Enabled = true;
}
if (this.LabelCurrentPage.Text == this.LabelPageCount.Text)
{
this.LinkButtonNextPage.Enabled = false;//下一页只读
this.LinkButtonLastPage.Enabled = false;//尾页只读
this.LinkButtonPreviousPage.Enabled = true;
this.LinkButtonFirstPage.Enabled = true;
}
}

Default.aspx

2.输出界面

 public static MemoryStream stream;
protected void Page_Load(object sender, EventArgs e)
{
string username = Request.QueryString["username"];
int pagecount =int.Parse(Request.QueryString["pagecount"]); string sql = string.Format("select top(1) image from Image_Table where image_code=( select new_sjbh from new_ksy_dzpz where new_ksy_dzpzid='{0}' ) ", username);
DataTable dt = SqlHelper.GetTable(sql);
if (dt.Rows.Count>)
{
stream = new MemoryStream((byte[])dt.Rows[]["image"]);
}
if (pagecount >= )
{
getImage(pagecount.ToString());
} } void getImage(string pp)//根据路径输出Jpeg格式图片流
{
Bitmap bt = new Bitmap(stream);
Guid gud = (Guid)bt.FrameDimensionsList.GetValue();
FrameDimension fds = new FrameDimension(gud); if (pp != "")
{ int qq = Convert.ToInt16(pp);
bt.SelectActiveFrame(fds, qq);
} MemoryStream ss = new MemoryStream();
bt.Save(Server.MapPath("1.jpg"));
bt.Save(ss, ImageFormat.Jpeg);
byte[] bb = ss.GetBuffer();
ss.Read(bb, , (int)ss.Length);
//this.ID_img.ImageUrl =Convert.ToString(bb);
Response.BinaryWrite(bb);
ss.Close();
bt.Dispose();
Response.End();
}

ShowImage.aspx

Tips:会在根目录下生成1.jpg文件,若迁移代码 需删掉1.jpg文件!

多页的TIFF图片在aspx页面分页显示的更多相关文章

  1. js 将很长的内容进行页面分页显示

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. Winform 图片预览列表+分页显示

    针对图片列表展示信息,一开始没有做过相关类似的功能,大多都是以表格行显示为主,所以刚开始实现这个功能的时候是懵逼的.无从下口.在网上搜索一时半会也没找到合适的解决方案.大致就是类似于下图这样,每条数据 ...

  3. JSP页面分页显示数据

    效果如上图所示!最多显示10条:完整jsp和后台代码如下: <%@ page contentType="text/html;charset=UTF-8" %> < ...

  4. aspx页面图片用作html中img的url

    背景:如果无法直接访问保存图片的服务器,我们可以先制作一个aspx页面用来接受服务器发送过来的图片,然后html页面请求aspx页面.对图片服务器起一定的缓冲保护作用,预防对黑客攻击造成危害. 注意: ...

  5. HTML控件ID和NAME属性的区别,以及如何在asp.net页面的.CS文件中获得.ASPX页面中HTML控件的值

    在html中:name指的是用户名称,ID指的是用户注册是系统自动分配给用户的一个序列号. name是用来提交数据的,提供给表单用,可以重复: id则针对文档操作时候用,不能重复.如:document ...

  6. Aspx页面模拟WebService功能

    在后台引入 using System.Web.Services 命名空间 然后在编写web服务方法: [WebMethod] public static string GetData(string t ...

  7. WebForm.aspx 页面通过 AJAX 访问WebForm.aspx.cs类中的方法,获取数据

    WebForm.aspx 页面通过 AJAX 访问WebForm.aspx.cs类中的方法,获取数据 WebForm1.aspx 页面 (原生AJAX请求,写法一) <%@ Page Langu ...

  8. Jquery Ajax调用aspx页面方法

    Jquery Ajax调用aspx页面方法 在asp.net webform开发中,用jQuery ajax传值一般有几种玩法 1)普通玩法:通过一般处理程序ashx进行处理: 2)高级玩法:通过as ...

  9. aspx页面中用Input 标签实现上传图片功能

    实现上传图片功能需单独的建立一个aspx页面, 其中前台页面需要注意两点: a)实现上传功能的input的type="file" b)设置请求报文头为 enctype=" ...

随机推荐

  1. 在配有英特尔® Iris™ 显卡的系统上通过优化对 Just Cause 3 进行增强

    高端 PC 继续通过高性能显卡驱动桌面游戏. 一流的"梦想机器"基于第六代智能 英特尔® 酷睿™ 处理器i7-6700K等 CPU,通常与高端独立显卡配合使用以运行要求最严苛的游戏 ...

  2. [css]实现垂直居中水平居中的几种方式

    转自博客 http://blog.csdn.net/freshlover/article/details/11579669 居中方式: 一.容器内(Within Container) 内容块的父容器设 ...

  3. Vim新手入门资料和一些Vim实用小技巧

    一些网络上质量较高的Vim资料 从我07年接触Vim以来,已经过去了8个年头,期间看过很多的Vim文章,我自己觉得非常不错,而且创作时间也比较近的文章有如下这些. Vim入门 目前为阿里巴巴高级技术专 ...

  4. 惊心动魄的一上午,感谢eclipse 的文件恢复功能

    昨晚倒腾了半天android 的程序,夜里三点多了,不争气的笔记本由于太热,突然熄火.话说就在昨天还在想着一定要把东西放到svn上,防止文档找不到或者笔记本丢失带来的严重后果.呵呵,就是这么想着,今天 ...

  5. ABP框架 - 领域服务

    文档目录 本节内容: 简介 例子 创建一个接口 实现服务 使用应用服务 相关论述 为什么不只用应用服务? 如何强制你使用领域服务? 简介 领域服务(或服务)用来执行领域操作和业务规则.Eric Eva ...

  6. Entity Framework 6 Recipes 2nd Edition(9-2)译->用WCF更新单独分离的实体

    9-2. 用WCF更新单独分离的实体 问题 你想通过WCF为一个数据存储发布查询,插入,删除和修改,并且使这些操作尽可能地简单 此外,你想通过Code First方式实现EF6的数据访问管理 解决方案 ...

  7. 自用的基于Emit的C#下DataTable转实体类方法

    之前一直在做WebForm的开发,数据绑定时直接DataTable绑定Gridview很方便,但是最近开始往MVC转,数据列表的传递和页面展示基本上是以List为主,像下面这样,遍历实体类的各个字段去 ...

  8. windows下获取IP地址的两种方法

    windows下获取IP地址的两种方法: 一种可以获取IPv4和IPv6,但是需要WSAStartup: 一种只能取到IPv4,但是不需要WSAStartup: 如下: 方法一:(可以获取IPv4和I ...

  9. 浅谈系列之 javascript原型与对象

    在我学习与使用javascript三个月中,我一直对javascript的继承关系以及prototype理解不清,导致很多时候为什么这么用说不出个所以然来.截止到本周为止,通过之前的学习以及自己的再学 ...

  10. (转)DOM appendHTML实现及insertAdjacentHTML

    appenChild() 原文转自 JS中有很多基本DOM方法,例如createElement, parentNode等,其中,appendChild方法是相当地常用与熟知,可谓是DOM节点方法中的& ...