Server.MapPath查询路径那几件事
主要总结Server.MapPath 这个方法的使用以及使用的场景,不是什么时候都适合使用;
1、实现功能:
Server.MapPath能够获取指定URL相对服务器的物理路径,在IIS服务端,能够根据文件名来获取该文件的物理路径;
2、存在命令空间:
System.Web.HttpContext.Current.Server.MapPath 以及System.web.MVC.Control.Server.Mapth;
3、使用情况:
既然是System.Web.HttpContent 也及时表明该方法只能放在Http.web中使用,非该环境系统会扔出一个错误;非web环境是什么意思那,举个例子,我们使用线程来处理某个业务逻辑的时候,这个时候你使用该方法,那必然报错,以为你已经脱离了web环境。所以视情况而定;获取虚拟目录的物理地址,该方法很有效果;
随便补充一句,多线程编程的时候,一定要分清楚那些事线程能够获取的资源,那些事依赖其他环境获取的变量,比如IIS中多线程获取缓存数据,离开了HttpWeb这环境来获取IIS的缓存,必然是失败的,所以要分清楚多线程编程时候,使用的资源对象。线程安全对象集合:ConcurrentQueue、ConcurrentBag等
4、需要注意事项:
system.Web.HttpContext.Current.Server.MapPath("myPic") //也就是获取当前平级目录地址; system.Web.HttpContext.Current.Server.MapPath("../myPic") //也就是获取当前上级目录地址;
使用的时候需要慎重;
SaveAs 方法将使用 FileUpload 控件上载的文件的内容保存到 Web 服务器上的指定路径
获取前端的页面上的文件
HttpFileCollection files = HttpContext.Current.Request.Files;
//原来以为这里的FILES只是file文件上传才能取得,后来经测试发现这里的files只要是页面上有的file文件(图片等等),都会当做request.files传过去
private void SaveFile(string xxbh, string flowLsh, string basePath = "~/Upload/Attachment/") { var _result = "0"; DAL.DALBase dal = new DAL.DALBase(); var name = string.Empty; var saveName = Guid.NewGuid().ToString().Replace("-", ""); basePath = (basePath.IndexOf("~") > -1) ? System.Web.HttpContext.Current.Server.MapPath(basePath) : basePath; HttpFileCollection files = System.Web.HttpContext.Current.Request.Files; basePath += xxbh + "/"; if (!Directory.Exists(basePath)) { Directory.CreateDirectory(basePath); } dal.DB.BeginTransaction(); try { var _suffix = files[0].FileName.Substring(files[0].FileName.LastIndexOf(".")); var _temp = System.Web.HttpContext.Current.Request["name"]; if (!string.IsNullOrEmpty(_temp)) { name = _temp; } else { Random rand = new Random(24 * (int)DateTime.Now.Ticks); name = rand.Next() + "." + _suffix; } var full = basePath + saveName; files[0].SaveAs(full); //保存数据库 string sqlString = "insert into t_xxbb_attachment\n" + " (lsh, filename, filesuffix, filesize, ref_xxbh, scbz, sjc,ref_jgbh,ref_yhbh,ref_flow_lsh)\n" + "values\n" + " ('" + saveName + "', '" + name + "', '" + _suffix + "', " + files[0].ContentLength + ", '" + xxbh + "', 0, sysdate," + UI.ssjgbh + "," + UI.yhbh + ",'" + flowLsh + "')"; dal.DB.ExecuteNonQuery(sqlString); dal.DB.CommitTransaction(); _result = "1"; } catch (Exception ex) { dal.DB.RollbackTransaction(); LogHelper.writelog("AttachmentUpload->SaveFile", ex); } System.Web.HttpContext.Current.Response.Write(_result); }