Dar*_*rov 5 asp.net asp.net-mvc
在 XHTML/Strict 文档中对锚标记中的 URL 进行编码的正确方法是什么:
<a href="http://www.sit.com/page/<%= HttpUtility.UrlEncode("String that might contain unicode and dangerous characters like +, /, \\, <, >, \", ', =") %>">
Anchor text
</a>
Run Code Online (Sandbox Code Playgroud)
或者
<a href="http://www.site.com/page/<%= HttpUtility.HtmlEncode("String that might contain unicode and dangerous characters like +, /, \\, <, >, \", ', =") %>">
Anchor text
</a>
Run Code Online (Sandbox Code Playgroud)
或者
<a href="http://www.site.com/page/<%= CustomEncode("String that might contain unicode and dangerous characters like +, /, \\, <, >, \", ', =") %>">
Anchor text
</a>
Run Code Online (Sandbox Code Playgroud)
在哪里CustomEncode定义。
我已经用asp.net-mvc标记了这个问题,因为我提出了以下问题。假设我尝试过的模板生成的默认路由:
<%= Html.RouteLink("action text", new { id ="a/b" }) %>
<%= Html.RouteLink("action text", new { id = Html.Encode("a/b") }) %>
Run Code Online (Sandbox Code Playgroud)
两者都呈现为
<a href="/Home/Index/a/b">action text</a>
Run Code Online (Sandbox Code Playgroud)
尽管
<%= Html.RouteLink("action text", new { id = Url.Encode("a/b") }) %>
Run Code Online (Sandbox Code Playgroud)
呈现为
<a href="/Home/Index/a%252fb">action text</a>
Run Code Online (Sandbox Code Playgroud)
起初对我来说似乎是正确的,但是当我点击链接时,我收到错误 400 Bad Request。
我把它放在同一页面上来测试 id 参数是否正确传递:
<% if (ViewContext.RouteData.Values.ContainsKey("id")) { %>
<div><%= Html.Encode(ViewContext.RouteData.Values["id"]) %></div>
<% } %>
Run Code Online (Sandbox Code Playgroud)
答案也可能是为了 SEO 目的而简单地在 url 中避免这些字符。如果是这种情况,我会简单地避免使用它们,但我只是好奇 CMS 和博客如何处理这个问题。
例如,在 SO 问题标题上,例如a/b会a-b在锚点 href 中呈现,所以我想这里有一些自定义的事情,我正在寻找最佳实践。
| 归档时间: |
|
| 查看次数: |
3724 次 |
| 最近记录: |