av激情亚洲男人的天堂国语,日韩欧美精品一中文字幕,无码av一区二区三区无码,国产又色又爽又刺激的a片,国产又色又爽又刺激的a片

淺析get和post在HTTP編程中的使用方式

本文將要介紹如何在HTTP編程中,get和post兩個關鍵字的混合用法,希望通過本文,能對關鍵字的最大長度以及功能有所了解。

問題來源于get和post的特點和限制。對于get請求,我們可以很方便的使用window.opener的方式與父頁面進行通訊,但是根據http協議的規(guī)定,url最大長度是2083個字節(jié),可以用于GET傳遞數據的長度是2048個字節(jié)。對于post請求,雖然沒有最大長度的限制,卻不能方便的使用window.opener與父頁面進行通訊。

關于如何使用javascript自動將一段get請求轉變成一個post請求,網上有很多的方法,其主要思想就是動態(tài)構造一個iframe,并將get請求中的url參數值賦給input控件,最后設置form的action地址并調用submit方法。

園子里有人已經給出一個解決方法,http://www.cnblogs.com/ppchen/archive/2008/03/18/1109607.html
這里轉載如下:

 
 
 
  1. Code  
  2. var PostNewWin = function(url){  
  3. var urlurlArr = url.split("?");  
  4. var postUrl = urlArr[0];  
  5. var postData = urlArr[1];  
  6. var iframe = document.getElementById("postData_iframe");  
  7. if(!iframe){  
  8. iframe = document.createElement("iframe");  
  9. iframe.id = "postData_iframe";  
  10. iframe.scr= "about:blank";  
  11. iframe.frameborder = "0";  
  12. iframe.style.width = "0px";  
  13. iframe.style.height = "0px";  
  14.  
  15. var form = document.createElement("form");  
  16. form.id = "postData_form";  
  17. form.method = "post";  
  18. form.target = "_blank";  
  19.  
  20. document.body.appendChild(iframe);  
  21. iframe.contentWindow.document.write("" + form.outerHTML + "");  
  22. }  
  23. iframe.contentWindow.document.getElementById("postData_form").innerHTML = "/>";  
  24. iframe.contentWindow.document.getElementById("postData_form").action = postUrl;  
  25. iframe.contentWindow.document.getElementById("postData_form").submit();  
  26. }; 

例如原來有一個函數,使用get請求打開新頁面

 
 
 
  1. function openNewWindow()  
  2. {  
  3. var url = http://www.website.com/page1.aspx?p1=v1&p2=v2;  
  4. var win =window.open(url);   

因為ur的長度問題,現在改為使用post方式提交,如下所示:

 
 
 
  1. function openNewWindow()  
  2. {  
  3. var url = http://www.website.com/page1.aspx?p1=v1&p2=v2;  
  4. //var win =window.open(url);   
  5. PostNewWin(url);  

這里有一個問題就是,使用這種方式后,就無法使用window.opener與父頁面進行交互了,因為通過這個函數,已經將get請求變成一個post請求了。為了可以使用post的方式提較大數據,同時也可以使用window.open(url)方式的window.opener與父頁面通訊,在這里做一點小的改版,首先使用window.open(url)時候,增加一個參數,指定打開窗口的名稱,,如下所示:

 
 
 
  1. function openNewWindow()  
  2. {  
  3. var url = http://www.website.com/page1.aspx?p1=v1&p2=v2;  
  4. var winName  = "";  
  5. var win =window.open("about:blank",winName );   
  6. PostNewWin(url,winName);  
  7. }  
  8. 同時修改PostNewWin函數,將這個新窗口的句柄傳遞給這個函數,將post請求的target設置為這個參數,如下所示:  
  9. var PostNewWin = function(url,winName){  
  10. .........  
  11. form.target = winName;   
  12. .......  
  13. }; 

這樣就可以同時使用post和get兩種方式的優(yōu)點了。


新聞標題:淺析get和post在HTTP編程中的使用方式
URL地址:http://uogjgqi.cn/article/dhgdeph.html
掃二維碼與項目經理溝通

我們在微信上24小時期待你的聲音

解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯網交流