主要总结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);
}