[Webinar] Streamline your web hosting managementRegister Today

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 290
  • Last Modified:

JavaScript: URL Encode All Non-whitelisted Characters Using _ instead of %

I want JavaScript functions that will work just like escape() and unescape() that use an underscore instead of a percent and encode all non-whitelisted charachters.

My function below does not work, as the example demonstrates:
http://jsfiddle.net/XVqeR/

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta charset="utf-8" />
<title>Demo</title>
</head>
<body>

<script type="text/javascript">
//<![CDATA[
// Thanks, leakim971
var x = 'A _test_ "1-2-3" 50%';
alert('The fist and last line should be the same:\n\n'+x+'\n'+escapeNonWhitelistedU(x)+'\n'+unescapeU(escapeNonWhitelistedU(x)));


function escapeNonWhitelistedU(str) {
    var escapechar = "%";
    var whitelist = "bcdefghijklmnopqrstuvwxyzBCDEFGHIJKLMNOPQRSTUVWXYZ0123456789_";
    return str.replace(/(.)/g,function($1) { return whitelist.indexOf($1)<0?escapechar+$1.charCodeAt(0).toString(16):$1; });
}

function unescapeU(str) {
 return unescape(str.replace(/_/g,"%"));
}

//]]>
</script>
</body>
</html>

Open in new window

0
hankknight
Asked:
hankknight
1 Solution
 
leakim971PluritechnicianCommented:
your escape character CAN'T be in your whitelist else how to differentiate both?

the same way escape convert % to %25

you should use a char not in your whitelist so you know when you found it it's the escape char
0

Featured Post

Free Tool: SSL Checker

Scans your site and returns information about your SSL implementation and certificate. Helpful for debugging and validating your SSL configuration.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now