04.18.2024

02.07.2010

An Open Letter to Web Developers on Percent-Encoding

Filed under: news @ 02:43

Dear web developers,

Please understand the difference between the encoding called for in application/x-www-form-urlencoded encoded data [1] and the encoding called for in URIs (and how that encoding applies to URIs in the http/https scheme).

In particular, note the difference in how spaces are treated. The former encodes them as +, the later as %20.

Understand also how your web server processes different pieces of URLs. Pay particular attention to your web server’s treatment of plus signs. PHP, for example, interprets “$_GET” data (the data drawn from the query component of the URI) as though it were application/x-www-form-urlencoded and converts those plus signs to spaces [2].

Now that you know that the different encoding methods encode spaces differently and that the different decoding methods decode pluses differently, make sure you’re being consistent.

Because when I type into your website my email address with its plus sign in it, I expect things to work.

Love,
mdawaffe

[1] More details in HTML5‘s definition of the application/x-www-form-urlencoded encoding algorithm.

[2] See the difference between urlencode()/urldecode() and rawurlencode()/rawurldecode(). parse_str() uses urldecode().

Decoding the query component of the URI according to application/x-www-form-urlencoded is the logical thing to do, since the web server can’t tell the difference between a GET request generated by a form and one that isn’t (since user agents are not supposed to set a “Content-Type: application/x-www-form-urlencoded” header when submitting a form over http/https via the GET method), but I can’t tell if converting pluses in the query part of the URI into spaces is required; I can’t find anything in the definition of the http URI scheme that says that plus signs are “delimiters” in the query component of the URI. So I believe it to be an implementation-specific choice and therefore up for grabs depending on how you power your web server (PHP, ruby, .NET, etc.).

2 Comments

  1.  
    Joseph Scott 02.08.2010 @ 08:34

    I don’t like spaces in URLs, either encoding doesn’t really make any sense from a user perspective.

  2.  
    527yw 04.16.2012 @ 01:10

    Fashion illustratration is the most important part of the fashion designers

    abilities.Knowledge of an anatomy of the human body, is very imp -to make a sketch appropriate and proportionate to the

    design.The Front and back details are required for the tailor to sew the garment as per the illustratration?and?

    measurments. SEWING SPECIFICATIONS—GENERALLY STUDENTS ALLOW THE TAILORS OR MASTERS TO SEW THE GARMENT

    ACCORDING TO THEIR EXPERIENCES AND DO NOT BOTHER TO REFINE SEWING- THIS AGAIN NEEDS PRACTICAL EXPERIENCE. THE ART

    OF LEARNING SEWING TECHNIQUE IS VERY IMPORTANT FOR A DESIGNER TO BECOME A SUCCESSFUL FASHION ENTRAPRENURE. I HAVE HAD SOME

    OF THE DESIGNERS SENDING ME SKETCHES OR PRESENTATION TEMPLATES AND EXPECT ME TO DO THE REST OF THE JOB ACCORDING TO THE

    STYLE REQUIRED AND SEW THE GARMENT TO PERFECTION USING THE FINEST TAILORING TECHNIQUE. THIS WILL WORK ONLY IF THE DESIGNER

    IS VERY SURE OF THE CAPABILITIES OF THE PRODUCTION TEAM (SEWING TEAM)-SKILLS FOR TAILORING IS NOT ACQUIRED OVERNIGHT –IT

    NEEDS A LOT OF EXPERIENCE AND EFFICIENCY OF THE TAILOR, ONLY AND ONLY THEN WILL YOUR DESIGN BECOME A CREDIBLE GARMENT

    FABRIC- CHOOSE FABRIC /SEASON OR CLIENT PREFERENCE MEASUREMENTS- GENERALLY CENTER SIZE IS APPLIED TO

    PRO TO SAMPLES FOR BULK PRODUCTION. IF YOU ARE A BOUTIQUE OWNER AND CUSTOM MAKING –CLOTHES –YOU NEED TO TAKE THE

    CORRECT MEASUREMENTS-TO FORM A PERFECT FIT-SHOULDER POINT TO ARM HOLE TO CHEST TO WAIST TO HIP AND FULL LENGTH

    MAKE A NEAT MEASUREMENT CHART

© mdawaffe (Michael D Adams) - Powered by WordPress - Full Credits