救命啊!快点,帮忙啊!,急救!

堕落陨石 2007-11-27 01:43:58
我现在在做一个门户网站
网站上有个需求,在新闻展示页面,有个下载按钮
提供用户下载本条新闻的内容
但是服务器上是没有打包好的文件的
只是数据库有这个新闻内容的字段
现在我要让用户点击 "下载 "按钮后,提供下载(把sql表中字段(newsContent)的内容写入word 然后打包 提供用户下载)
下载完后,不要在服务器的硬盘上留下这个文件
请问XX老师,帮下了,感激不尽,在线等!!!!
现在是2007-11-27 13:15分
开始计时间,等啊........
...全文
143 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
堕落陨石 2007-11-27
  • 打赏
  • 举报
回复
OK,确定代码无误了,就帖出来,一起修改指正!
simenpeng 2007-11-27
  • 打赏
  • 举报
回复
帮你完整版的贴出来吧
省的我不懂得时候也发问
嘎嘎
LZ
记得把整理后的帖出来
堕落陨石 2007-11-27
  • 打赏
  • 举报
回复
打包的功能我这自己能实现了,结合谢谢上面的几位大哥,结合你们的代码和意见,今天我就可以搞定这个需求了,谢了,下班后给分!谢谢!
blueiv 2007-11-27
  • 打赏
  • 举报
回复
response.buffer= true; 
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();

类似上面的方法可以实现,不过没有打包的功能、
堕落陨石 2007-11-27
  • 打赏
  • 举报
回复
实际上就是个打包传输的过程,这个一连串的动态过程,有谁做过的,提供下例子,谢了,等着高手来结帖!!!!!!
blueiv 2007-11-27
  • 打赏
  • 举报
回复
可以直接用html流输出,不过可以读取字段放到一个dategrid(可以隐藏在页面里)
然后直接导出一个Word文件供用户下载,不过再动态打包就不知道该怎么做了
堕落陨石 2007-11-27
  • 打赏
  • 举报
回复
最好提供个动态打包下载(也就是下载玩了,什么都不会有了,服务器也不会有那个文件(实际上又不晓得这样的想法是否合理)),那就一起OK了
堕落陨石 2007-11-27
  • 打赏
  • 举报
回复
上面大哥说的实际上就是我想要的,可是实现起来对小弟有点困难啊,要是你能给点例子就好了!实现中......
zbjg 2007-11-27
  • 打赏
  • 举报
回复
提供代码不实现,给你个建议:
1. 不建议用Word组件,并发情况下可能有问题,且会出现Word版本问题。你可以先做一个Word文件存成“HTML”格式,作为模板。
2. 读数据库中的新闻,用前面的WORD模板在内存中创建字符串,用新闻替换模板中的如“{$new_content$}”。
3. 将字符串以WORD流的格式作为新页面返回给用户。(如果不好做,就搞个缓冲的临时文件夹,给用户个下载URL)
堕落陨石 2007-11-27
  • 打赏
  • 举报
回复
要是谁看清了需求,给个解决方案的提示也行,谢谢大家了!
堕落陨石 2007-11-27
  • 打赏
  • 举报
回复
大哥,已经不错了,做了一半,还差一半,也就是打包下载了!
suyiming 2007-11-27
  • 打赏
  • 举报
回复
添加引用->COM->Microsoft Word 11.0 Object Library
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;
}

62,074

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧