1. 程式人生 > >URL傳參問題,區分escape、encodeURI和encodeURIComponent

URL傳參問題,區分escape、encodeURI和encodeURIComponent

1、escape和它們不是同一類

簡單來說,escape是對字串(string)進行編碼(而另外兩種是對URL),作用是讓它們在所有電腦上可讀。
編碼之後的效果是%XX或者%uXXXX這種形式。
其中 ASCII字母、數字、@*/+ ,這幾個字元不會被編碼,其餘的都會。
最關鍵的是,當你需要對URL編碼時,請忘記這個方法,這個方法是針對字串使用的,不適用於URL。
事實上,這個方法我還沒有在實際工作中用到過,所以就不多講了。

2、最常用的encodeURI和encodeURIComponent

對URL編碼是常見的事,所以這兩個方法應該是實際中要特別注意的。它們都是編碼URL,唯一區別就是編碼的字元範圍,其中
encodeURI方法不會對下列字元編碼  ASCII字母、數字、

[email protected]#$&*()=:/,;?+'
encodeURIComponent方法不會對下列字元編碼 ASCII字母、數字、~!*()'
所以encodeURIComponent比encodeURI編碼的範圍更大。
實際例子來說,encodeURIComponent會把 http://  編碼成  http%3A%2F%2F 而encodeURI卻不會。

1、如果只是編碼字串,不和URL有半毛錢關係,那麼用escape。
 
2、如果你需要編碼整個URL,然後需要使用這個URL,那麼用encodeURI。
比如
encodeURI("http://www.cnblogs.com/season-huang/some other thing");
編碼後會變為
"http://www.cnblogs.com/season-huang/some%20other%20thing";
其中,空格被編碼成了%20。但是如果你用了encodeURIComponent,那麼結果變為
"http%3A%2F%2Fwww.cnblogs.com%2Fseason-huang%2Fsome%20other%20thing"
看到了區別嗎,連 "/" 都被編碼了,整個URL已經沒法用了。


3、當你需要編碼URL中的引數的時候,那麼encodeURIComponent是最好方法。
var param = "http://www.cnblogs.com/season-huang/"; //param為引數
param = encodeURIComponent(param);
var url = "http://www.cnblogs.com?next=" + param;
console.log(url) //"http://www.cnblogs.com?next=http%3A%2F%2Fwww.cnblogs.com%2Fseason-huang%2F"
看到了把,引數中的 "/" 可以編碼,如果用encodeURI肯定要出問題,因為後面的/是需要編碼的。

相關推薦

URL問題區分escapeencodeURIencodeURIComponent

1、escape和它們不是同一類 簡單來說,escape是對字串(string)進行編碼(而另外兩種是對URL),作用是讓它們在所有電腦上可讀。 編碼之後的效果是%XX或者%uXXXX這種形式。 其中 ASCII字母、數字、@*/+ ,這幾個字元不會被編碼,其餘的都會。 最

簡明區分escapeencodeURIencodeURIComponent

aso 字符串 () 問題 最好 %x 空格 con %u 一、前言 講這3個方法區別的文章太多了,但是大部分寫的都很繞。本文試圖從實踐角度去講這3個方法。 二、escape和它們不是同一類 簡單來說,escape是對字符串(string)進行編碼(而另外兩種是對URL

區分escapeencodeURIencodeURIComponent

一、前言 講這3個方法區別的文章太多了,但是大部分寫的都很繞。本文試圖從實踐角度去講這3個方法。   二、escape和它們不是同一類 簡單來說,escape是對字串(string)進行編碼(而另外兩種是對URL),作用是讓它們在所有電腦上可讀。 編碼之後的效果是%XX或者

簡單明瞭區分escapeencodeURIencodeURIComponent

一、前言 講這3個方法區別的文章太多了,但是大部分寫的都很繞。本文試圖從實踐角度去講這3個方法。 二、escape和它們不是同一類 簡單來說,escape是對字串(string)進行編碼(而另外兩種是對URL),作用是讓它們在所有電腦上可讀。 編碼之後的效果是%X

JS中為什麼會存在escapeencodeURIencodeURIComponent方法

1.為什麼需要以上三個方法?    當我們瀏覽網頁的時候看,會在瀏覽器的位址列輸入相應的URL地址,然而對於URL中的可以出現的字元是有要求的。       對於URL中的可以出現的字元要求可詳見RFC 1738,具體為以下內容: Thus, only alphan

前端編碼之escapeencodeURIencodeURIComponent

一、前言講這3個方法區別的文章太多了,但是大部分寫的都很繞。本文試圖從實踐角度去講這3個方法。二、escape和它們不是同一類簡單來說,escape是對字串(string)進行編碼(而另外兩種是對URL),作用是讓它們在所有電腦上可讀。編碼之後的效果是%XX或者%uXXXX這

IEFireFoxChrome瀏覽器中關於URL中文亂碼解決相容性問題!

前臺用url傳值中文,後臺用request.getParameter接收引數。在Firefox,Chrome等瀏覽器中沒有問題。但用IE瀏覽器就又會出現引數中文亂碼現象。         IE、 Firefox、Chrome瀏覽器對URL的處理各不相同,瀏覽器在傳輸URl時

jqjs獲取一個頁面中的ajax資料到另一個頁面顯示(通過url方式)

做專案遇到了頁面之間傳輸資料的問題,特別是第一個頁面的資料是使用ajax顯示的,當點選ajax中append的li的時候,開啟另一個頁面,將第一個頁面的資料顯示在另一個頁面上,具體情況如下: 一、這是第一個頁面中的js程式碼: //顯示所有該使用者的歌單 function showMusicMe

通過URL然後第二個頁面需要獲取

banner chan rom base its [0 val success escape /** * 方法說明:通過url參數鍵值名稱獲取參數的值 * @method getQueryString * @param name

(四)flask框架使用教程系列——URL反轉URL

一、URL傳引數 1. 引數的作用       可以在相同的URL ,但是指定不同的引數,後來載入不同的資料。 2. 在flask中如何使用引數 引數需要放在兩個尖括號中; 檢視函式中需要放和url中的

【Django2x 學習筆記 03】建立path路由url(建立新路由URLpathinfo模式多個GET模式多個返回json)

注意:Django2.1.3 下環境,Python3.7,基於最新的語言和框架的特性。 #1 已新建一個Django專案工程——mysite(假設:F = /django/mysite/ 目錄) django-admin startproject mysite #2&nbs

原生Ajax使用筆記---getpost方法url

AJAX是Asynchronous Javascript And XML(非同步JavaScript和XML)的縮寫,用於建立快速動態網頁的技術。AJAX的核心物件是XMLHttpRequest ,在每個瀏覽器中都有。 原生Ajax的使用步驟: 建立一個核心物件XMLHttpReque

4.4Django - URLURL給檢視(二)

上篇介紹了通過URL傳參給檢視,下面繼續說一下URL傳參給檢視的另外一種方式(查詢字串的形式),即GET 請求方法 。 在douAPI專案APP為douBook的views.py中: from django.shortcuts import render # Create you

4.4Django - URLURL給檢視(一)

1、為什麼要在URL中傳遞引數? 引數,意味著在url中不固定,如果是寫死固定的話,就不需要了 。 下面兩幅圖,顯示的是前面部分相同的豆瓣的文章連結,只有後面的id不一樣 。 在APP為douBook下的views.py中: from django.http import

a標籤跳頁以及擷取URL引數 js 中編碼(encode)解碼(decode)的三種方法

<a href="dd.index?aa=1&&bb=2"></a> //擷取URL引數 // console.log(window.location.search); function GetQueryString(name) { var reg = new Re

二維碼url中漢字導致查詢不到結果結果為編碼所引起

1、正常經過應該是掃描頁面中的二維碼,開啟url,系統根據url中引數查詢出結果,沒有漢字,一切正常; 2、之後引數中加入漢字,找不到結果了; 2、網站頁面經過混淆,無從查詢原因,然後找到生成二維碼的檔案qrcode.asp; 3、發現檔案中url經過了encodeURIComponent(url)(u

第一章:認識HTTP區分URI URL URN

1、認識Http HTTP是一種網路傳輸協議即超文字傳輸協議(還有其他檔案傳輸協議FTP、郵件傳輸協議SMTP等),就是大家講好規矩,都按這個規矩來,有序規範,並保證資料傳輸的穩定性與

Python函式的4種值的方式必選 func(param)預設func(param=value)可變func(*param)關鍵字func(**param)列舉說明

#coding:utf-8 #author:libingxian """ Python的4種傳值的方式,必選傳參 func(param)、預設傳參func(param=value)、可選傳參func(*param)、關鍵字傳參func(**param)列舉說明

通過url時要注意不能有空格否則會發生意想不到的問題

在練習servlet,需要寫一個使用超連結轉到下一個頁面並且攜帶一個引數過去。 我選擇使用url把引數傳遞過去,但會報404錯誤,連下一個頁面都找不到了,通過嘗試發現是問號與前面有空格的問題,把空格去

URL傳遞過程中幾種編碼escape()encodeURI()encodeURIComponent()

在地址URL傳輸過程中常常需要對中文,特殊符號等進行編碼,常用到的編碼方式有escape()、encodeURI()、encodeURIComponent() 一文中有詳細的闡述,本人只在這裡記錄一下個人的使用心得  首先escape()使用限制較多,轉碼也不完全,使用