получение базового URL корня сайта (абсолютный / относительный URL) - PullRequest
7 голосов
/ 29 марта 2010

Я хочу полностью понять, как использовать относительный и абсолютный адрес URL в статических и динамических файлах.

~  : 
/  :
.. : in a relative URL indicates the parent directory
 . : refers to the current directory
 / : always replaces the entire pathname of the base URL
// : always replaces everything from the hostname onwards

Этот пример прост, когда вы работаете без виртуального каталога. Но я работаю над виртуальным каталогом.

Relative URI          Absolute URI
about.html            http://WebReference.com/html/about.html
tutorial1/            http://WebReference.com/html/tutorial1/
tutorial1/2.html      http://WebReference.com/html/tutorial1/2.html
/                     http://WebReference.com/
//www.internet.com/   http://www.internet.com/
/experts/             http://WebReference.com/experts/
../                   http://WebReference.com/
../experts/           http://WebReference.com/experts/
../../../             http://WebReference.com/
./                    http://WebReference.com/html/
./about.html          http://WebReference.com/html/about.html

Я хочу смоделировать сайт ниже, как мой проект, который работает в виртуальном каталоге.

Это мои папки aspx и ascx

http://hostAddress:port/virtualDirectory/MainSite/ASPX/default.aspx
http://hostAddress:port/virtualDirectory/MainSite/ASCX/UserCtrl/login.ascx

http://hostAddress:port/virtualDirectory/AdminSite/ASPX/ASCX/default.aspx

Это мои файлы JS (которые будут использоваться как с файлами aspx, так и с файлами ascx):

http://hostAddress:port/virtualDirectory/MainSite/JavascriptFolder/jsFile.js
http://hostAddress:port/virtualDirectory/AdminSite/JavascriptFolder/jsFile.js

это мой статический адрес веб-страницы (я хочу показать несколько картинок и запустить некоторые функции js):

http://hostAddress:port/virtualDirectory/HTMLFiles/page.html

это моя папка с изображениями

http://hostAddress:port/virtualDirectory/Images/PNG/arrow.png
http://hostAddress:port/virtualDirectory/Images/GIF/arrow.png

если я хочу написать и ссылку на файл изображения в моем ASPX-файле, я должен написать

aspxImgCtrl.ImageUrl = Server.MapPath("~")+"/Images/GIF/arrow.png";

Но если я хочу записать путь в жестком коде или из файла javascript, какой это должен быть адрес URL?

1 Ответ

7 голосов
/ 06 мая 2010

Оператор ~ распознается asp.net только для серверных элементов управления и в коде сервера.Нельзя использовать оператор ~ для клиентских элементов.

Абсолютные и относительные ссылки на пути в серверном элементе управления имеют следующие недостатки:

• Абсолютные пути не переносимы между приложениями.Если вы переместите приложение, на которое указывает абсолютный путь, ссылки разорвутся.

• Относительные пути в стиле клиентских элементов могут быть затруднены при перемещении ресурсов или страниц в разные папки.

Чтобы преодолеть эти недостатки, ASP.NET включает в себя корневой оператор веб-приложения (~), который можно использовать при указании пути в элементах управления сервером.ASP.NET преобразует оператор ~ в корень текущего приложения.Вы можете использовать оператор ~ в сочетании с папками, чтобы указать путь, основанный на текущем корне.

Как и в примере, который вы разместили

aspxImgCtrl.ImageUrl = Server.MapPath("~")+"/Images/GIF/arrow.png";

, приведенный выше код отобразит серверфизический путь (например, - c: \ inetpub \ wwwroot \ mysite \ images \ gif \ arrow.png ", который имеет меньшее значение на стороне клиента,

, вы должны использовать его для правильного относительного пути клиента:

aspxImgCtrl.ImageUrl = "~/Images/GIF/arrow.png"; 

Чтобы ссылаться на ресурсы из javascript, вы можете рассмотреть структуру папок одного уровня для объединения путей доступа, например:

  • Pages
  • JS
  • Pix
  • и т. Д. *

Для получения более подробной информации посетите пути к веб-сайтам asp.net

...