一、逻辑实现:将数据库中的二进制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. Linux基础介绍【第九篇】

    服务器添加3块磁盘的体系结构 [root@oldboylinux test]# free -m              total used free shared buffers cached M ...

  2. zookeeper(单机/集群)安装与配置

    一.安装与单机配置 1.下载: wget http://archive.apache.org/dist/zookeeper/stable/zookeeper-3.4.6.tar.gz 如果网站下载不了 ...

  3. FastClick 填坑及源码解析

    最近产品妹子提出了一个体验issue —— 用 iOS 在手Q阅读书友交流区发表书评时,光标点击总是不好定位到正确的位置: 如上图,具体表现是较快点击时,光标总会跳到 textarea 内容的尾部.只 ...

  4. 【腾讯Bugly干货分享】React Native项目实战总结

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/577e16a7640ad7b4682c64a7 “8小时内拼工作,8小时外拼成长 ...

  5. 疯狂的JSONP

    何为跨域?何为JSONP?JSONP技术能实现什么?是否有必要使用JSONP技术? 跨域 就是由于JavaScript同源策略的限制,使得a.com域名下的js无法操作b.com或c.a.com域名下 ...

  6. (原创) alljoyn物联网实验之手机局域网控制设备

    AllJoyn开源物联网协议框架,官方描述是一个能够使连接设备之间进行互操作的通用软件框架和系统服务核心集,也是一个跨制造商来创建动态近端网络的软件应用.高通已经将该项目捐赠给了一个名为“AllSee ...

  7. 精通Perl(第2版)

    精通Perl(第2版)(通往Perl大师之路必读经典书籍,体现了一种编程思维,能够帮你解决很多实际的问题) [美]brian d foy(布瑞恩·D·福瓦)著   王兴宇 刘宸宇 译 ISBN 978 ...

  8. linux安装mvn后提示权限不够

    Maven - 环境配置 Maven 是一个基于 Java 的工具,所以要做的第一件事情就是安装 JDK. 系统要求 项目 要求 JDK Maven 3.3 要求 JDK 1.7 或以上Maven 3 ...

  9. tornado template

    若果使用Tornado进行web开发可能会用到模板功能,页面继承,嵌套... 多页应用模板的处理多半依赖后端(SPA就可以动态加载局部视图),就算是RESTfull的API设计,也不妨碍同时提供部分模 ...

  10. js和jquery实现简单的选项卡

    选项卡切换在做网页的时候经常会用到,以往都是用JQ来实现,代码简单易懂,今天用原生的js实现了一下,二者还是有很大不同的,可以对比一下代码来研究一下. <!DOCTYPE html> &l ...