Different behaviours of treating \ (backslash) in the url by FireFox and Chrome

假装没事ソ 提交于 2019-12-19 05:22:25

问题


BACKGROUND

According to my experience when my ubuntu workstation is configured on domain with active directory, the user name created for me was according to the following pattern.

domain_name\user_name

Using the userdir extensions of apache on linux will require to use user name in the URL in order to access public_html in the home directory.

http://localhost/~domain_name\user_name

PROBLEM A:

Chrome converts all the backslash '\' characters in the URL to forward slash '/' and the resultant url becomes as under that is totally different and always results Not Found.

http://localhost/~domain_name/user_name

Firefox on the other hand does not convert back slash to forward slash so http request to intended target is served by web server.

Common solution is to encode back slash in %5C.

PROBLEM B:

If we use a similar path (containing \ in path) in CSS @import construct, the import process of css file as HTTP Get Request is failed by reporting 404 error and the URL reported in the 404 error miss the presence of \ altogether. It means \ is removed from the URL before to invoke GET request against it.

This behavior is common in Firefox and Chrome. But they have uncommon solutions

Firefox needs escaped back slash to work in css import process.

@import url("http://localhost/~domain_name\\user_name/path/to/css");

Chrome as usual needs an encoded back slash solution.

@import url("http://localhost/~domain_name%5Cuser_name/path/to/css");

  • What is the unified solutions to deal with \ in URL?
  • Is there a way to avoid a \ to appear in user name?

回答1:


The unified solution to deal with backslash in a URL is to use %5C. RFC 2396 did not allow that character in URLs at all (so any behavior regarding that character was just error-recovery behavior). RFC 3986 does allow it, but is not widely implemented, not least because it's not exactly compatible with existing URL processors.

Chrome, in particular, does the same thing as IE: assumes you meant a forward slash any time you type a backslash, as you discovered, because that's what Windows file paths do.




回答2:


Try using the Slashy add-on in the firefox to help you with it.Here's a link to it.

Slashy




回答3:


This backslash auto conversion issue has fixed in Chrome version >= 53.0.2785.116.

Now the backslashes are treated properly as %5C.



来源:https://stackoverflow.com/questions/10438008/different-behaviours-of-treating-backslash-in-the-url-by-firefox-and-chrome

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!