Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
182 views
in Technique[技术] by (71.8m points)

php - JavaScript function call interprets encoded Single Quote %27 as literal

Requirements:

  • I have to fetch a URL that contains a single quote.
  • I am required to call a function via; e.g. <a href="javascript:my_function('my_quote%27s.txt');">...</a>.

After a lot of hassle of trying to properly encode a single quote (%27) both Waterfox and Chrome both keep throwing errors. Chrome allowed me to see that the error was triggered because the browsers are taking it upon themselves to decode strings (when I have not programed them to) turning %27 in to the literal single quote character so it errors out before the function is even called (e.g. my_function('my_quotes's.txt') with the quote being internally decoded and causing the obvious triple quote issue).

I could use PHP's htmlentities($file_name, ENT_QUOTES) though I'd have to string replace &#039; which seems pointlessly convoluted.

  • I am required to support the single quote and make the call via javascript:.
  • I'd like to avoid literal interpretation of encoded strings when calling functions.
  • I'd like to minimize the fuss and just use an encoding that JavaScript won't complain about.
  • No frameworks or libraries.

How do I properly encode a single quote in a manner that JavaScript won't take it upon itself to somehow internally decode it and throw errors?

See Question&Answers more detail:os

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

I am required to make the call via javascript:

Shudder. Please fix this. It's known as a bad practice since over ten years! And it's exactly what's causing the URI decoding - the javascript: schema is followed by an percent-encoded value to interpret.

So if you start with the js code

my_function('my&quote's.txt');

it would become one of

javascript:my_function%28%27my%26quote%27s.txt%27%29%3B
javascript:my_function(%27my%26quote%27s.txt%27)%3B
javascript:my_function('my%26quote's.txt')%3B

(the apostrophe ' and the parenthesis actually don't need to be encoded).

But 'my_quote's.txt' is not the valid javascript that you want to start with. What you're actually looking for is 'my_quote's.txt' or "my_quote's.txt'. To use these in a javascript:-scheme URI, it becomes

javascript:my_function('my_quote's.txt')%3B
javascript:my_function("my_quote's.txt")%3B

So if you generate this href string from a dynamic filename value, you must

  1. String-escape the filename in the JS string literal
  2. URL-encode the complete code in the javascript url
  3. html-entity-escape the complete href attribute value

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

1.4m articles

1.4m replys

5 comments

56.9k users

...