POST请求工具函数
来源:互联网 发布:matlab编程第四版 pdf 编辑:程序博客网 时间:2024/06/03 18:53
首先铺垫一下,这里写的是原生的javascript的Ajax请求,我们平时提交表单数据到服务器又两种提交格式
一种是标准的标准的表单编码,使用等号把编码后的名字和值分开,并使用“&”符号分开名/值对;
就像这样
find="pizza"&zipcode=02134&radius="1KM"
第二种方式以对象的方式提交数据,那么上面的数据就可以写成下面这样
{find:"pizza",zipcode:02134,radius:"1KM"}
那么我们这里就写一个工具函数来实现非表单数据的表单编码并以POST方式提交数据,我们是以第一种标准的表单数据格式
/*编码对象的属性为标准的表格提交数据格式*/function encodeFormData(data){ if(!data) return ""; var pairs = []; for(var name in data){ if(!data.hasOwnProperty(name)) continue;//跳过继承属性 if(typeof data[name] === "function") continue;//跳过方法 var value = data[name].toString();//把值转为字符串 name = encodeURIComponent(name.replace("%20","+"));//编码名字 value = encodeURIComponent(value.replace("%20","+"));//编码值 pairs.push(name+"="+value);//记住名=值对 } return pairs.join("&");//返会使用“&”链接的名/值对}
使用上面的encodeFormData( )函数,我们就可以写一个POST提及的工具函数了
function postData(url,data,callback){ var request = new XMLHttpRequest(); request.open("POST",url); request.onreadystatechange = function(){ if(request.readyState=4 && request.status=200) callback(request); } request.setRequestHeader("Content-type", "application/x-www-form-urlencoded");//表单提交必须这样设置请求头 request.send(encodeFormData(data));}
一个简单的工具函数就这样了,如果请求的url有加密,则把open那里改为
request.open("POST",url,true,username,password);//第三个参数——true表示异步请求,false表示同步请求,同步请求则省略状态//监听,并且会产生阻塞//第四个参数是url的用户名//第五个参数是url的密码
1 0
- POST请求工具函数
- 网络请求get/post工具类:NetUtil
- java发送GET/POST请求工具类
- Http请求get、post工具类
- 模拟post,get请求的工具
- Http 的post请求的工具类
- Http请求get、post工具类
- HttpUtil工具类发送post请求
- get/post请求网络服务的工具类
- android HttpClient get请求与post请求工具类
- HttpClientUtil工具类,发送get请求和post请求
- java工具类-------get请求和post请求
- POST请求模拟工具、JSON请求工具、http接口测试、post接口测试
- Java工具类——发送GET/POST请求工具
- Java工具类——发送GET/POST请求工具
- PHP:stream_context_create函数模拟POST/GET请求
- Android代码工具集——网络Post请求
- android中利用Post提交请求工具类
- 复制粘贴——社交分享监测工具Tynt
- 分析linux进程调度与进程切换
- Synch4j使用指南
- 学点编码知识又不会死:Unicode的流言终结者和编码大揭秘
- iOS 移除所有子视图
- POST请求工具函数
- JIRA忘记admin密码的恢复方法
- oracle执行计划分析
- 使用框架实现上拉下刷功能
- 从头认识多线程-1.6 迫使线程停止的方法-异常法
- Google Analytics内容分组功能与网站页面分类
- d3.js——面积图表的制作
- 机器学习:EM算法
- web测试清单