我现在在做一个门户网站
网站上有个需求,在新闻展示页面,有个下载按钮
提供用户下载本条新闻的内容
但是服务器上是没有打包好的文件的
只是数据库有这个新闻内容的字段
现在我要让用户点击 "下载 "按钮后,提供下载(把sql表中字段(newsContent)的内容写入word 然后打包 提供用户下载)
下载完后,不要在服务器的硬盘上留下这个文件
请问XX老师,帮下了,感激不尽,在线等!!!!
现在是2007-11-27 13:15分
开始计时间,等啊........
网站上有个需求,在新闻展示页面,有个下载按钮
提供用户下载本条新闻的内容
但是服务器上是没有打包好的文件的
只是数据库有这个新闻内容的字段
现在我要让用户点击 "下载 "按钮后,提供下载(把sql表中字段(newsContent)的内容写入word 然后打包 提供用户下载)
下载完后,不要在服务器的硬盘上留下这个文件
请问XX老师,帮下了,感激不尽,在线等!!!!
现在是2007-11-27 13:15分
开始计时间,等啊........
解决方案 »
- ASP.NET中如何更改默认页面
- 大家有没有遇见这样的问题啊,asp和.net 1.1 和.net 2.2在同一个服务器上
- 问一编码问题:js的函数encodeURIComponent编码的数据怎么在ASP.net中解码?
- 关于 Web Service 问题
- 蛙蛙请教:启用页面跟踪后,跟踪信息和页面重叠在一起了,怎么办?
- 请达人们看一下我的简单问题~~
- 如何在代码中将Listbox,CheckBoxList,RadioButtonList中的选项设定为选取
- 征求基于web的文件服务器方案,高分相赠。
- asp.net 游客与会员的判断
- to icyer 提问:为什么动态加载的控件无法使用?
- 怎样在本页的CS后台文件里调用本页所调用的用户控件的变量值!
- ascx 中选择dropdownlist时显示的永远是index 0
using Word;
下面的例子中包括C#对Word文档的创建、插入表格、设置样式等操作:(例子中代码有些涉及数据信息部分被省略,重要是介绍一些C#操作word文档的方法) public string CreateWordFile( string CheckedInfo)
... {
string message = "" ;
try
... {
Object Nothing = System.Reflection.Missing.Value;
Directory.CreateDirectory( " C:/CNSI " ); // 创建文件所在目录
string name = " CNSI_ " + DateTime.Now.ToShortString() + " .doc " ;
object filename = " C://CNSI// " + name; // 文件保存路径
// 创建Word文档
Word.Application WordApp = new Word.ApplicationClass();
Word.Document WordDoc = WordApp.Documents.Add( ref Nothing, ref Nothing, ref Nothing, ref Nothing); // 添加页眉
WordApp.ActiveWindow.View.Type = WdViewType.wdOutlineView;
WordApp.ActiveWindow.View.SeekView = WdSeekView.wdSeekPrimaryHeader;
WordApp.ActiveWindow.ActivePane.Selection.InsertAfter( " [页眉内容] " );
WordApp.Selection.ParagraphFormat.Alignment = Word.WdParagraphAlignment.wdAlignParagraphRight; // 设置右对齐
WordApp.ActiveWindow.View.SeekView = WdSeekView.wdSeekMainDocument; // 跳出页眉设置
WordApp.Selection.ParagraphFormat.LineSpacing = 15f; // 设置文档的行间距 // 移动焦点并换行
object count = 14 ;
object WdLine = Word.WdUnits.wdLine; // 换一行;
WordApp.Selection.MoveDown( ref WdLine, ref count, ref Nothing); // 移动焦点
WordApp.Selection.TypeParagraph(); // 插入段落 // 文档中创建表格
Word.Table newTable = WordDoc.Tables.Add(WordApp.Selection.Range, 12 , 3 , ref Nothing, ref Nothing);
// 设置表格样式
newTable.Borders.OutsideLineStyle = Word.WdLineStyle.wdLineStyleThickThinLargeGap;
newTable.Borders.InsideLineStyle = Word.WdLineStyle.wdLineStyleSingle;
newTable.Columns[ 1 ].Width = 100f;
newTable.Columns[ 2 ].Width = 220f;
newTable.Columns[ 3 ].Width = 105f; // 填充表格内容
newTable.Cell( 1 , 1 ).Range.Text = " 产品详细信息表 " ;
newTable.Cell( 1 , 1 ).Range.Bold = 2 ; // 设置单元格中字体为粗体
// 合并单元格
newTable.Cell( 1 , 1 ).Merge(newTable.Cell( 1 , 3 ));
WordApp.Selection.Cells.VerticalAlignment = Word.WdCellVerticalAlignment.wdCellAlignVerticalCenter; // 垂直居中
WordApp.Selection.ParagraphFormat.Alignment = Word.WdParagraphAlignment.wdAlignParagraphCenter; // 水平居中
// 填充表格内容
newTable.Cell( 2 , 1 ).Range.Text = " 产品基本信息 " ;
newTable.Cell( 2 , 1 ).Range.Font.Color = Word.WdColor.wdColorDarkBlue; // 设置单元格内字体颜色
// 合并单元格
newTable.Cell( 2 , 1 ).Merge(newTable.Cell( 2 , 3 ));
WordApp.Selection.Cells.VerticalAlignment = Word.WdCellVerticalAlignment.wdCellAlignVerticalCenter; // 填充表格内容
newTable.Cell( 3 , 1 ).Range.Text = " 品牌名称: " ;
newTable.Cell( 3 , 2 ).Range.Text = BrandName;
// 纵向合并单元格
newTable.Cell( 3 , 3 ).Select(); // 选中一行
object moveUnit = Word.WdUnits.wdLine;
object moveCount = 5 ;
object moveExtend = Word.WdMovementType.wdExtend;
WordApp.Selection.MoveDown( ref moveUnit, ref moveCount, ref moveExtend);
WordApp.Selection.Cells.Merge();
// 插入图片
string FileName = Picture; // 图片所在路径
object LinkToFile = false ;
object SaveWithDocument = true ;
object Anchor = WordDoc.Application.Selection.Range;
WordDoc.Application.ActiveDocument.InlineShapes.AddPicture(FileName, ref LinkToFile, ref SaveWithDocument, ref Anchor);
WordDoc.Application.ActiveDocument.InlineShapes[ 1 ].Width = 100f; // 图片宽度
WordDoc.Application.ActiveDocument.InlineShapes[ 1 ].Height = 100f; // 图片高度
// 将图片设置为四周环绕型
Word.Shape s = WordDoc.Application.ActiveDocument.InlineShapes[ 1 ].ConvertToShape();
s.WrapFormat.Type = Word.WdWrapType.wdWrapSquare;
newTable.Cell( 12 , 1 ).Range.Text = " 产品特殊属性 " ;
newTable.Cell( 12 , 1 ).Merge(newTable.Cell( 12 , 3 ));
// 在表格中增加行
WordDoc.Content.Tables[ 1 ].Rows.Add( ref Nothing);
WordDoc.Paragraphs.Last.Range.Text = " 文档创建时间: " + DateTime.Now.ToString(); // “落款”
WordDoc.Paragraphs.Last.Alignment = Word.WdParagraphAlignment.wdAlignParagraphRight; // 文件保存
WordDoc.SaveAs( ref filename, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing);
WordDoc.Close( ref Nothing, ref Nothing, ref Nothing);
WordApp.Quit( ref Nothing, ref Nothing, ref Nothing);
message = name + " 文档生成成功,以保存到C:CNSI下 " ;
}
catch
... {
message = " 文件导出异常! " ;
}
return message;
}
1. 不建议用Word组件,并发情况下可能有问题,且会出现Word版本问题。你可以先做一个Word文件存成“HTML”格式,作为模板。
2. 读数据库中的新闻,用前面的WORD模板在内存中创建字符串,用新闻替换模板中的如“{$new_content$}”。
3. 将字符串以WORD流的格式作为新页面返回给用户。(如果不好做,就搞个缓冲的临时文件夹,给用户个下载URL)
然后直接导出一个Word文件供用户下载,不过再动态打包就不知道该怎么做了
response.charset="gb2312";
response.appendheader("content-disposition","attachment;filename="+datetime.today.tostring("yyyymmdd_hhmmss")+".doc");
response.contentencoding=system.text.encoding.getencoding("gb2312");
response.contenttype = "application/ms-word";
repeater1.enableviewstate = false;
system.io.stringwriter ostringwriter = new system.io.stringwriter();
system.web.ui.htmltextwriter ohtmltextwriter = new system.web.ui.htmltextwriter(ostringwriter);
repeater1.rendercontrol(ohtmltextwriter);
response.write(ostringwriter.tostring());
response.end();
类似上面的方法可以实现,不过没有打包的功能、