Can . (period) be part of the path part of an URL?

27,777

Solution 1

I don't see where RFC1738 disallows periods (.) in URLs. Here are some excerpts from there:

hpath          = hsegment *[ "/" hsegment ]
hsegment       = *[ uchar | ";" | ":" | "@" | "&" | "=" ]
uchar          = unreserved | escape
unreserved     = alpha | digit | safe | extra
safe           = "$" | "-" | "_" | "." | "+"

So the answer to your question is: Yes, http://www.example.com/module.php/lib/lib.php is a valid URL.

Solution 2

As others have noted, periods are allowed in URLs, but be careful. If a single or double period is used in part of a URL's path, the browser will treat it as a change in the path, and you may not get the behavior you want.

For example:

  • www.example.com/foo/./ redirects to www.example.com/foo/
  • www.example.com/foo/../ redirects to www.example.com/

Whereas the following will not redirect:

  • www.example.com/foo/bar.biz/
  • www.example.com/foo/..biz/
  • www.example.com/foo/biz../

Solution 3

Periods are allowed. See section "2.3 Unreserved Characters" in this document: https://www.rfc-editor.org/rfc/rfc3986

"Characters that are allowed in a URI but do not have a reserved purpose are called unreserved. These include uppercase and lowercase letters, decimal digits, hyphen, period, underscore, and tilde".

Solution 4

Nothing wrong with a period in a url. If you look at the makeup in the grammar in the link you provided a period is mentioned via the 'safe' group, which is included via uchar a

Ignore my answer, Adams is better

Share:
27,777
Moffe
Author by

Moffe

Software developer primarily working with PHP and the technologies associated with web development.

Updated on July 09, 2022

Comments