ASP.NET 网页文件夹

本章介绍文件夹和文件夹路径。


在本章中,您将学到:

  • 逻辑和物理文件夹结构
  • 虚拟和物理名称
  • web URL 和路径

逻辑文件夹结构

下面是 ASP.NET 网页的典型文件夹结构:

Folders
  • "Account" 文件夹包含登录和安全文件
  • "App_Data" 文件包含数据库和数据文件
  • "Images" 文件夹包含图片
  • "Scripts" 文件夹包含浏览器脚本
  • "Shared" 文件夹包含通用文件(比如布局和样式文件)

物理文件结构

上面这个网站的 "Images" 文件夹的物理结构在计算机上类似这样:

C:\Johnny\Documents\MyWebSites\Demo\Images


虚拟和物理名称

根据上面的例子:

web 图片的虚拟名称类似这样:"Images/pic31.jpg"。

But the physical name is "C:\Johnny\Documents\MyWebSites\Demo\Images\pic31.jpg"



URL 和路径

URL 用于从 web 访问文件: https://www.w3schools.cn/html/html5_intro.asp

URL 在服务器上对应的文件是: C:\MyWebSites\w3schools\html\html5_intro.asp

虚拟路径是代表物理路径的简写形式。如果您使用虚拟路径,就能够在不更新路径的情况下将网页移动到不同的域名(或服务器)。

URL https://www.w3schools.cn/html/html5_intro.asp
Server name w3schools
Virtual path /html/html5_intro.asp
Physical path C:\MyWebSites\w3schools\html\html5_intro.asp

磁盘驱动器上的根目录写作: C:\,但是网站上的根目录是 /(斜杠)。

web 文件夹的虚拟路径(几乎)永远不会与物理文件夹相同。

在您的代码中,根据代码内容的不同,可能会同时引用物理路径和虚拟路径。

ASP.NET 提供三种处理文件夹路径的工具:~ 操作符、Server.MapPath 方法以及 Href 方法。


~ 操作符

如需在编程代码中规定虚拟根目录,请使用 ~ 操作符。

如果您使用 ~ 操作符,而不是路径,就能够在不改变任何代码的情况下,将网站移动到不同的文件夹或位置:

var myImagesFolder = "~/images";
var myStyleSheet = "~/styles/StyleSheet.css";

Server.MapPath 方法

Server.MapPath 方法将虚拟路径 (/default.cshtml) 转换为服务器能够理解的物理路径 (C:\Johnny\MyWebSited\Demo\default.cshtml)。

当需要打开位于服务器上的数据文件时,您就会用到该方法(数据文件只能通过完整的物理路径来访问):

var pathName = "~/dataFile.txt";
var fileName = Server.MapPath(pathName);

You will learn more about reading from (and writing to) data files on the server in the next chapter of this tutorial.


Href 方法

Href 方法把代码中的路径转换为浏览器能够理解的路径(浏览器无法理解 ~ 操作符)。

您使用 Href 方法来创建指向资源(比如图片和 CSS 文件)的路径。

您会经常在 HTML <a>、<img> 以及 <link> 元素中用到该方法:

@{var myStyleSheet = "~/Shared/Site.css";}

<!-- This creates a link to the CSS file. -->
<link rel="stylesheet" type="text/css" href="@Href(myStyleSheet)" />

<!-- Same as : -->
<link rel="stylesheet" type="text/css" href="/Shared/Site.css" />

Href 方法属于 WebPage 对象的方法。