- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
附加查询字符串时始终跳过尾部斜杠是否安全?
也就是说,我可以使用
http://example.com?querystring
而不是:
http://example.com/?querystring
?我使用过的所有网络主机都支持此方法,但是可以安全地假设所有服务器环境都支持此方法吗?标准吗?
最佳答案
作为现代规范的问题,是的,允许跳过斜杠,这与 accepted answer 的内容相反。这里声明。
尽管接受的答案正确引用了 RFC 1738(20 多年前发布!),但它错误地声称 RFC 2396(1998 年发布)需要斜杠,并且忽略了这些规范都又被 RFC 3986 废弃,于 2005 年发布(距离编写已接受的答案还有几年),最近由 WhatWG URL Standard 发布。 ,两者都允许省略斜杠。
让我们按照从最早到最新的顺序依次考虑这些规范:
<小时/>隐式要求 specifying that it may be omitted if the URL contains neither a path nor a query string 包含斜杠(此处称为 searchpart
)。下面的粗体是我的:
<小时/>An HTTP URL takes the form:
http://<host>:<port>/<path>?<searchpart>
where
<host>
and<port>
are as described in Section 3.1. If :<port>
is omitted, the port defaults to 80. No user name or password isallowed.<path>
is an HTTP selector, and<searchpart>
is a querystring. The<path>
is optional, as is the<searchpart>
and itspreceding "?". If neither<path>
nor<searchpart>
is present, the "/"may also be omitted.
这里省略斜杠是可以接受的。这个 RFC 合法化了一些奇怪的 URL 语法,这些语法在方案之后没有双斜杠,但是如果我们忽略这些语法(它们是规范的 BNF 中带有 opaque_part
的语法)并坚持使用包含主机,然后我们发现一个absoluteURI
定义如下...
absoluteURI = scheme ":" ( hier_part | opaque_part )
然后是 hier_part
看起来像这样:
hier_part = ( net_path | abs_path ) [ "?" query ]
然后是 net_path
看起来像这样:
net_path = "//" authority [ abs_path ]
其中abs_path
依次定义为以斜线开头。请注意 abs_path
在上面的语法中是可选 - 这意味着 scheme://authority?query
形式的 URL是完全合法的。
附录 G.2. Modifications from both RFC 1738 and RFC 1808 暗示了此更改的动机:
The question-mark "?" character was removed from the set of allowedcharacters for the userinfo in the authority component, since testingshowed that many applications treat it as reserved for separating thequery component from the rest of the URI.
换句话说 - 现实世界中的代码假设 URL 中任何位置的第一个问号都标记了查询字符串的开头,因此规范被务实地更新以与现实保持一致。
<小时/>同样,可以省略斜杠。该规范通过规定每个包含权限(主机)的 URI 中都需要一个“路径”来表达这一点,并且该路径必须以斜线开头或由以下内容组成没有字符:
The generic URI syntax consists of a hierarchical sequence ofcomponents referred to as the scheme, authority, path, query, andfragment.
URI = scheme ":" hier-part [ "?" query ] [ "#" fragment ]
hier-part = "//" authority path-abempty
/ path-absolute
/ path-rootless
/ path-emptyThe scheme and path components are required, though the path may beempty (no characters). When authority is present, the path musteither be empty or begin with a slash ("/") character.
为了完整起见,请注意path-abempty
后来这样定义:
path-abempty = *( "/" segment )
这确实允许它不包含任何字符。
<小时/>同样,省略斜杠是可以接受的,尽管这次我们没有 BNF 可看,而是需要阅读大量散文。
Section 4.3告诉我们:
An absolute-URL string must be one of the following
- a URL-scheme string that is an ASCII case-insensitive match for a special scheme and not an ASCII case-insensitive match for "
file
", followed by ":
" and a scheme-relative-special-URL string- a URL-scheme string that is not an ASCII case-insensitive match for a special scheme, followed by ":" and a relative-URL string
- a URL-scheme string that is an ASCII case-insensitive match for "file", followed by ":" and a scheme-relative-file-URL string
any optionally followed by "?" and a URL-query string.
由于 HTTP 和 HTTPS 是 special schemes ,任何 HTTP 或 HTTPS URL 必须满足这三个选项中的第一个 - 即 http:
或https:
随后是 scheme-relative-special-URL string ,其中:
must be "
//
", followed by a valid host string, optionally followed by ":
" and a URL-port string, optionally followed by a path-absolute-URL string.
一个path-absolute-URL string被定义为以斜杠开头,但在上面的绝对 URL 字符串的定义中是明确可选的;因此,允许从主机直接转到“?
”和查询字符串,以及像 http://example.com?query
这样的 URL。是合法的。
当然,这些都不能保证每个 Web 服务器或 HTTP 库都会接受此类 URL,也不能保证它们在语义上等同于包含斜杠的 URL。但就规范而言,跳过斜杠是完全合法的。
关于url - 可以在查询字符串之前跳过斜杠吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1617058/
假设我拥有域 mydomain.com,并且我在服务器上有一个 Web 应用程序,网址为 http://99.99.99.99:1234/MyApplication/startpage.somethi
我正在尝试通过以下方式更新已解析的 URL: u, _ := url.Parse(s) if u.Scheme == "" { u.Scheme = "https" } if u.Path =
如何将 www.somesite.com/api(.*) 映射到 www.somesite.com/$1:9000? (我需要将/api 映射到运行 @ 端口 9000 的 Play 框架应用程序)
我有一个资源结构,如航类 > 座位 > 预订,所以预订属于某个航类的某个座位: http://example.com/jdf_3prGPS4/1/jMBDy46PbNc
我想知道以下网址是否有效。 路径中的点,在主机之后: http://www.example.com/v.b.w..com 主机中的点,作为子域的一部分: http://v.b.w..co.manufa
我有两个域 - crmpicco.co.uk 和 ayrshireminis.com - 如果我浏览到: www.crmpicco.co.uk/mini/new我希望能够重定向到 www.ayrshi
我正在尝试使用 URL 重写和应用程序请求路由来重写到外部 URL。我设置了以下规则: 在规则中,“patternToMatch”是我试
我已经安装了带有 SharePoint 和 Url Rewrite 模块的 IIS 7.0。 是以下句子还是我配置错误才能看到这个结果? Url Redirect 可以将 url 重定向到任何内部(在
我想知道,为了获得良好的 SEO,您必须在 URL 中使用自然语言。您知道字符中单词或短语的最大大小吗?例如: www.me.com/this-is-a-really-long-url.htm 我问这
有人知道在 SEO 友好 URL 中使用逗号有什么问题吗?我正在使用一些在其 SEO 友好 URL 中使用大量逗号的软件;但我 100% 肯定我见过一些程序/平台无法正确识别 URL 并在第一个逗号后
我有一个网站,我正在为所有链接使用干净的 URL。我想知道对于简短的基本 URL 与较长的描述性 URL 有何看法。 例如,如果我的网站是关于 Georgia Bulldog 足球新闻的,那么哪个网站
我正在编写一个类似于 tinyurl 的 URL 缩短器,我想知道如何跟踪已经使用我的服务缩短的 URL?例如,tinyurl 为相同的长 URL 生成相同的小 URL,而不管是谁创建的。如
我是 magento 的新手。我正在开发一个模块。为此,我有一些要显示链接的 css 和 js 文件。我目前有类似 的链接 getSkinUrl('module_tryouts/css/jquery.
我想基于 HTTP_URL 重写 URL 以重定向到不同的端口,同时保留其余的 URL 和查询字符串(如果指定)。例如, http://host/john/page.aspx 应该重定向到 http:
我遇到了以下问题: 我的 Grails (2.2.0) 应用程序具有以下 URL 映射: "/api/clientQuote/$labcode/$cliCode/$quoCode"(controlle
我有一个很长的 URL,它不适合 URL 字段。它一直在修剪。该怎么办?有没有办法增加 SharePoint 2010 中的 URL 字段字符限制? 或者解决方法来容纳长 URL。例如,以下 URL
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题? Update the question所以它是on-topic对于堆栈溢出。 9年前关闭。 Improve this que
我们从客户以前的开发人员那里继承了相当多的 Google Apps 脚本项目。 Apps 脚本通过嵌入式小部件部署在 Google 网站 (sites.google.com) 的各个页面上。每当我们需
我正在编写一些文档,但遇到了一些词汇问题: http://www.example.com/en/public/img/logo.gif 被称为“绝对”网址,对吗? ../../public/img/l
我们从客户以前的开发人员那里继承了相当多的 Google Apps 脚本项目。 Apps 脚本通过嵌入式小部件部署在 Google 网站 (sites.google.com) 的各个页面上。每当我们需
我是一名优秀的程序员,十分优秀!