博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Server.MapPath和Request.PhysicalApplicationPath的异同
阅读量:6799 次
发布时间:2019-06-26

本文共 1157 字,大约阅读时间需要 3 分钟。

很多人对它们都不陌生,在众多的WEB程序中,使用Server.MapPath和Request.PhysicalApplicationPath来操作目录/文件的几率参半,我曾经也经常混用,然而时间久了。发现Request.PhysicalApplicationPath有点“麻烦”?

其实在一般的应用程序中,感觉不到两者的区别,而在一些存在“虚拟目录”、存在多级子目录、需要虚拟目录相互文件操作的站点中,就可以知道它们的区别了。我的总结如下:
1、相对当前路径的文件操作:
可以使用Server.MapPath("test.txt")、Server.MapPath("a/test.txt")、Server.MapPath("../b/test.txt"),这个时候使用Request.PhysicalApplicationPath就很难定位到文件;
2、绝对路径的文件操作:
这个时候两者都可以,有点注意的是Server.MapPath中的绝对是“面向”站点而言的,不会因为“虚拟目录”本身的属性不同而变化,Request.PhysicalApplicationPath就并非如此。
打个比方:主站点指向D:\wwwroot\,虚拟目录指向E:\wwwroot\a\,取名为a。
那么如果我要操作虚拟目录下的E:\wwwroot\a\test.txt,可以使用Server.MapPath("/a/test.txt"),又或者直接使用Server.MapPath("~/test.txt");
那么用Request.PhysicalApplicationPath该怎么写?
很多人数是:Request.PhysicalApplicationPath + "test.txt",我说不一定,为什么?
因为要是该虚拟目录有单独的应用池,Request.PhysicalApplicationPath就是E:\wwwroot\a\,后面加上test.txt就是E:\wwwroot\a\test.txt;
但要是该虚拟目录没有单独的应用池,Request.PhysicalApplicationPath就是D:\wwwroot\,不管你后面怎么加,都定位不到我要找到文件了。呵呵……

3、跨虚拟目录的文件操作:

比如我现在要操作虚拟目录b下的test2.txt文件,使用Server.MapPath("/b/test2.txt")就没有问题(前提是我有操作权限,没有权限是另外一回事)。
而Request.PhysicalApplicationPath根本就无法找到其他的虚拟目录下的文件,不信谁试试,再告诉我方法?!!!
  

转载于:https://www.cnblogs.com/MrWby/p/4349962.html

你可能感兴趣的文章
hdu 1540 Tunnel Warfare(线段树区间统计)
查看>>
android 自定义按钮实现 home键 和返回键
查看>>
Android App测试要点
查看>>
深入理解C指针之三:指针和函数
查看>>
android(9)_数据存储和访问3_scard基本介绍
查看>>
eclipse自动部署问题
查看>>
Asp.Net验证码2
查看>>
Android APK反编译就这么简单 详解(附图)
查看>>
Python 随机数
查看>>
面向程序员的数据库访问性能优化法则
查看>>
创建, 发布自己的 Vue UI 组件库
查看>>
有关Android插件化思考
查看>>
redis 集群搭建以及redislive监测部署
查看>>
HTML5系列之meta
查看>>
react-router 4.x
查看>>
Wepy目录结构
查看>>
JS面试理论题
查看>>
Spring Boot 参考指南(Spring Integration)
查看>>
October CMS - 快速入门 7 显示列表和详情页
查看>>
Django之Ubuntu环境搭建
查看>>