浅析get和post在HTTP编程中的使用方式
创始人
2024-06-08 07:21:23
0

本文将要介绍如何在HTTP编程中,get和post两个关键字的混合用法,希望通过本文,能对关键字的最大长度以及功能有所了解。

问题来源于get和post的特点和限制。对于get请求,我们可以很方便的使用window.opener的方式与父页面进行通讯,但是根据http协议的规定,url最大长度是2083个字节,可以用于GET传递数据的长度是2048个字节。对于post请求,虽然没有最大长度的限制,却不能方便的使用window.opener与父页面进行通讯。

关于如何使用javascript自动将一段get请求转变成一个post请求,网上有很多的方法,其主要思想就是动态构造一个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 = " + postData + "'/>";  
  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两种方式的优点了。

原文标题:http编程中的get和post混合使用方式

链接:http://www.cnblogs.com/chegan/archive/2009/09/28/1575536.html

【编辑推荐】

  1. 学习C#实现HTTP协议:多线程文件传输
  2. 用来访问HTTP服务器的仿java.net功能类
  3. Python HTTP服务快速搭建
  4. 有关客户端浏览器缓存的HTTP头介绍
  5. JBoss Netty 3.1发布 新增HTTP隧道功能

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...