我现在在做一个门户网站 
网站上有个需求,在新闻展示页面,有个下载按钮 
提供用户下载本条新闻的内容 
但是服务器上是没有打包好的文件的 
只是数据库有这个新闻内容的字段 
现在我要让用户点击 "下载 "按钮后,提供下载(把sql表中字段(newsContent)的内容写入word     然后打包   提供用户下载) 
下载完后,不要在服务器的硬盘上留下这个文件 
请问XX老师,帮下了,感激不尽,在线等!!!! 
现在是2007-11-27  13:15分 
开始计时间,等啊........

解决方案 »

  1.   

    添加引用->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;
            } 
      

  2.   

    提供代码不实现,给你个建议:
    1. 不建议用Word组件,并发情况下可能有问题,且会出现Word版本问题。你可以先做一个Word文件存成“HTML”格式,作为模板。
    2. 读数据库中的新闻,用前面的WORD模板在内存中创建字符串,用新闻替换模板中的如“{$new_content$}”。
    3. 将字符串以WORD流的格式作为新页面返回给用户。(如果不好做,就搞个缓冲的临时文件夹,给用户个下载URL)
      

  3.   

    可以直接用html流输出,不过可以读取字段放到一个dategrid(可以隐藏在页面里)
    然后直接导出一个Word文件供用户下载,不过再动态打包就不知道该怎么做了
      

  4.   

    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();
    类似上面的方法可以实现,不过没有打包的功能、