PHP post & get请求

  1 <?php
  2 /**
  3  * HTTP 请求类
  4  */
  5 class HttpHelper {
  6
  7     const METHOD_GET = ‘GET‘;
  8     const METHOD_POST = ‘POST‘;
  9
 10     private static $_connectTimeout = 60;
 11     private static $_timeout = 60;
 12
 13     /**
 14      * Http post请求
 15      * @param type $url  http url address
 16      * @param type $data post params name => value
 17      */
 18     public static function post($url, $data = array()){
 19
 20         $queryString = self::buildHttpQueryString($data,  self::METHOD_POST);
 21
 22         $response = self::makeHttpRequest($url, self::METHOD_POST,$queryString);
 23         return $response;
 24     }
 25
 26     /**
 27      * http get 请求
 28      * @param type $url  http url address
 29      * @param type $data get params name => value
 30      */
 31     public static function get($url,$data = array()) {
 32         if(!empty($data)){
 33             $url .= "?" . self::buildHttpQueryString($data,  self::METHOD_GET);
 34         }
 35         $response = self::makeHttpRequest($url,  self::METHOD_GET);
 36         return $response;
 37     }
 38
 39     /**
 40      * 构造并发送一个http请求
 41      * @param type $url
 42      * @param type $method
 43      * @param type $postFields
 44      * @return type
 45      */
 46     public static function makeHttpRequest($url,$method,$postFields = null) {
 47         $ch = curl_init();
 48         curl_setopt($ch, CURLOPT_URL, $url);
 49         curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
 50         if(self::METHOD_POST == $method){
 51             curl_setopt($ch, CURLOPT_POST, 1);
 52             if(!empty($postFields)){
 53                 curl_setopt($ch, CURLOPT_POSTFIELDS, $postFields);
 54             }
 55         }
 56         curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, self::$_connectTimeout);
 57         curl_setopt($ch, CURLOPT_TIMEOUT, self::$_timeout);
 58         curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
 59         curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
 60
 61         $result = curl_exec($ch);
 62         curl_close($ch);
 63         return $result;
 64     }
 65
 66     /**
 67      * 构造http请求的查询字符串
 68      * @param array $params
 69      * @param type $method
 70      * @return string
 71      */
 72     public static function buildHttpQueryString(array $params, $method = self::METHOD_GET) {
 73         if(empty($params)){
 74             return ‘‘;
 75         }
 76         if(self::METHOD_GET == $method){
 77             $keys = array_keys($params);
 78             $values = self::urlEncode(array_values($params));
 79             $params = array_combine($keys, $values);
 80         }
 81
 82         $fields = array();
 83
 84         foreach ($params as $key => $value) {
 85             $fields[] = $key . ‘=‘ . $value;
 86         }
 87         return implode(‘&‘,$fields);
 88     }
 89
 90     /**
 91      * url encode 函数
 92      * @param type $item  数组或者字符串类型
 93      * @return type
 94      */
 95     public static function urlEncode($item) {
 96         if(is_array($item)){
 97             return array_map(array(‘HttpHelper‘,‘urlEncode‘), $item);
 98         }
 99         return rawurlencode($item);
100     }
101
102     /**
103      * url decode 函数
104      * @param type $item 数组或者字符串类型
105      * @return type
106      */
107     public static function urlDecode($item){
108         if(is_array($item)){
109             return array_map(array(‘HttpHelper‘,‘urlDecode‘), $item);
110         }
111         return rawurldecode($item);
112     }
113 }

使用方法:

echo HttpHelper::get(‘http://www.baidu.com‘, array(‘t‘ => 1));
时间: 2024-12-22 11:24:11

PHP post & get请求的相关文章

http请求与响应全过程

HTTP 无状态性 HTTP 协议是无状态的(stateless).也就是说,同一个客户端第二次访问同一个服务器上的页面时,服务器无法知道这个客户端曾经访问过,服务器也无法分辨不同的客户端.HTTP 的无状态特性简化了服务器的设计,使服务器更容易支持大量并发的HTTP 请求. HTTP 持久连接       HTTP1.0 使用的是非持久连接,主要缺点是客户端必须为每一个待请求的对象建立并维护一个新的连接,即每请求一个文档就要有两倍RTT 的开销.因为同一个页面可能存在多个对象,所以非持久连接可

HTTP 400 错误 - 请求无效 (Bad request)

在ajax请求后台数据时有时会报 HTTP 400 错误 - 请求无效 (Bad request);出现这个请求无效报错说明请求没有进入到后台服务里: 原因:1)前端提交数据的字段名称或者是字段类型和后台的实体类不一致,导致无法封装: 2)前端提交的到后台的数据应该是json字符串类型,而前端没有将对象转化为字符串类型: 解决方案: 1)对照字段名称,类型保证一致性 2)使用stringify将前端传递的对象转化为字符串    data: JSON.stringify(param)  ;

WAF——针对Web应用发起的攻击,包括但不限于以下攻击类型:SQL注入、XSS跨站、Webshell上传、命令注入、非法HTTP协议请求、非授权文件访问等

核心概念 WAF Web应用防火墙(Web Application Firewall),简称WAF. Web攻击 针对Web应用发起的攻击,包括但不限于以下攻击类型:SQL注入.XSS跨站.Webshell上传.命令注入.非法HTTP协议请求.非授权文件访问等.

POST请求 参数 使用body

主要是记录一下,post请求,参数请放到body里: 虽然放到params里,也可以,但是并不合理,因为url的长度是有限制的

http网络请求 基础

http://tuijian.hao123.com:80/index.html scheme(协议前缀): host(主机):port(端口):path(资源路径) 核心类: URL:网络统计资源定位符 ,标识是网络中唯一资源 HttpURLConnection 网络资源连接类,可以打开网络连接,读取网路资源,上传网路资源等 功能方法:getinputStream()来获取网路资源字节读取流 getContentLength()来获取网路资源字节数 getPesponseCode() 来获取网路

HTTP请求报文详解

HTTP Request Header 请求头 Header 解释 示例 Accept 指定客户端能够接收的内容类型 Accept: text/plain, text/html Accept-Charset 浏览器可以接受的字符编码集. Accept-Charset: iso-8859-5 Accept-Encoding 指定浏览器可以支持的web服务器返回内容压缩编码类型. Accept-Encoding: compress, gzip Accept-Language 浏览器可接受的语言 Ac

学习笔记12JS异步请求

*一般用JS来监听按钮事件,都应该先监听页面OnLoad事件. *Js写在哪里,就会在页面解析到哪里执行. 异步请求:所谓异步请求,就是使用JS来监听按钮点击事件,并且发送请求,等到回复后,再使用JS来进行页面跳转,或动态改变页面.使用场合:当请求是ashx是,都可以使用异步方法,页面就无需刷到ashx的一个空白页面或者不用于展示的页面了. *使用jquery发送异步请求:$("#按钮ID").Click(fuction(){ $.get( "页面URL.ashx"

接口测试,添加请求头的时候,大小写一定要正确

今天同事碰到了一个问题,就是他用robot framework+requests写接口测试用例的时候,post一个json数据的时候,发送出去的数据一直是data=<empty>,明明有数据啊,通过log打印也是没问题. 最终发现是添加头的时候,将Content-Type写成了content-type. 我刚开始也没看出来问题在哪里,费了好长时间才搞定.说一下如何排查出的这个问题吧,以往写Content-Type的时候,还真没注意到大小写的问题,jmeter应该不区分的.于是今天一直没想到是这

Spring MVC HTTP请求数据绑定

package com.springmvc.controller; import com.springmvc.model.UserInfo; import org.springframework.core.io.ClassPathResource; import org.springframework.core.io.Resource; import org.springframework.stereotype.Controller; import org.springframework.uti

node.js搭建代理服务器请求数据

1.引入node.js中的模块 1 var http = require("http"); 2 var url = require("url"); 3 var qs = require("querystring"); 2.创建服务器 //用node中的http创建服务器 并传入两个形参 http.createServer(function(req , res) { //设置请求头 允许所有域名访问 解决跨域 res.setHeader("