这个导出网站功能指通过前台javascript触发进入ashx函数中,实现将服务器中某个文件夹(包含其子文件夹和文件)通通复制到服务器中另一处位置,当然该文件夹本身就是一个网站。所以导出网站最重要的两个功能,除了javascript的触发,就是C#ashx文件复制文件夹的操作。
下面这段代码就是通过javascript的Request函数调用copy.ashx函数文件,实现将需要复制的文件夹的子路径和复制到所在位置的子路径的两个参数传进去后台函数getWebList函数就是后台的一个函数,这个函数可以不用管他。getBack函数就需要写上,可以通过这个函数获取结果。当然Webside_load这个函数也是需要onclick触发过来的,这里就不全部列出来了。
以下是C#实现导出网站功能引用片段:
//Webside_load导出网站 function Webside_load(sID, iWebTemplateID) {//alert(0); //alert(sID); alert(iWebTemplateID); //被赋值的目录:就是模板ID下的文件夹以及文件 sTartDir = "http://www.cnblogs.com/uploadfile/webTemplate/" + iWebTemplateID; //目标目录:就是作品ID下 sEndDir = "http://www.cnblogs.com/uploadfile/showweb/" + sID + "/"; //alert(sourceDir); alert(targetDir); var variable = ["sTartDir", "sEndDir"]; var value = [sTartDir, sEndDir]; //alert(value); Request("getWebList", variable, value, getBack, WebUrl + "http://www.cnblogs.com/copy.ashx", svrNamespace); } function getBack() { var xmlhttp = xmlHttpRequest; var Result = xmlhttp.responseText; alert(Result); }
通过上面的javascript,可以获取来自后台函数的数据,而获取后台函数的数据就需要下面关于遍历加copy的函数文件了。
以下是引用片段:
<%@ WebHandler Language="C#" Class="copy" %> using System; using System.Web; using System.IO; public class copy : IHttpHandler { //采用递归的方式遍历,文件夹和子文件中的所有文件。 public void ProcessRequest(HttpContext context) { HttpRequest Request = context.Request; HttpResponse Response = context.Response; HttpServerUtility Server = context.Server; //指定输出头和编码 context.Response.ContentType = "text/html"; Response.Charset = "utf-8"; HttpFileCollection fs = HttpContext.Current.Request.Files; string sTartDir = Request.Form["sTartDir"]; string sEndDir = Request.Form["sEndDir"]; sTartDir = System.Web.HttpContext.Current.Server.MapPath(sTartDir); sEndDir = System.Web.HttpContext.Current.Server.MapPath(sEndDir); //Test //string sTartDir = System.Web.HttpContext.Current.Server.MapPath("../uploadfile/webTemplate/2"); //string sEndDir = System.Web.HttpContext.Current.Server.MapPath("../uploadfile/showweb/2012082700000001/"); MyDirectory_Copy(sTartDir, sEndDir); Response.Write("成功导出!"); } static void MyDirectory_Copy(string sTartDir, string sEndDir) { //判断两个目录是否都是存在的 if (!Directory.Exists(sTartDir)) return; if (!Directory.Exists(sEndDir)) return; //获取文件夹名字 string sTarteFolderName = sTartDir.Replace(Directory.GetParent(sTartDir).ToString(), "").Replace(Path.DirectorySeparatorChar.ToString(), ""); //判断是否该文件夹赋值成功 if (sTartDir == sEndDir + sTarteFolderName) return; //要复制到的路径 string endPath = sEndDir + Path.DirectorySeparatorChar.ToString() + sTarteFolderName; if (Directory.Exists(endPath)) { Directory.Delete(endPath, true); } Directory.CreateDirectory(endPath); //复制文件 string[] files = Directory.GetFiles(sTartDir); for (int i = 0; i < files.Length; i++) { File.Copy(files[i], endPath + Path.DirectorySeparatorChar.ToString() + Path.GetFileName(files[i])); } //复制目录 string[] dires = Directory.GetDirectories(sTartDir); for (int j = 0; j < dires.Length; j++) { MyDirectory_Copy(dires[j], endPath); } } public bool IsReusable { get { return false; } } }
从前台获得sTartDir源文件目录和 sTartDir目标目录,得到他们的绝对路径。再执行DirectoryCopy函数,获得源文件的文件夹名字,将目标文件的绝对路径加上文件夹名赋给新的目标文件目录通过递归循环判断,执行复制过程。
这种方法类似于之前所提到的C#遍历文件夹,不过这里是内部遍历复制,和在系统中遍历也不是完全一样。
以上就是C#导出网站功能的全部内容介绍,希望对大家的学习有所帮助。