使用PHP得到所有的HTTP请求头_还有应答头

1)如何获取 客户端请求的头部

参考网站:

http://www.neatstudio.com/show-377-1.shtml

PHP中一般采用getallheaders来获取头部,但事实上,有些模式下是获取不到的(以前真没有注意过在fastcgi下这个函数不能用,当然我现在也没有测试。是老王说的)

他说:

在PHP里,想要得到所有的HTTP请求头,可以使用getallheaders方法,不过此方法并不是在任何环境下都存在,比如说,你使用fastcgi方式运行PHP的话,就没有这个方法,所以说我们还需要考虑别的方法,幸运的是$_SERVER里有我们想要的东西,它里面键名以HTTP_开头的就是HTTP请求头:

$headers = array(); 
foreach ($_SERVER as $key => $value) { 
    if ('HTTP_' == substr($key, 0, 5)) { 
        $headers[str_replace('_', '-', substr($key, 5))] = $value; 
    } 
}

代码很简单,需要说明的是RFC里明确指出了信息头的名字是不区分大小写的。

 

2)如果php脚本作为http客户端,用curl去请求远端 服务器,那么如何获取 http响应消息 的应答头!
代码如下:

<?php
$xml = <<<'EOF'
<?xml version="1.0" encoding="UTF-8" ?>
<body>
<keyword>3333</keyword>
<order>0</order>
<pagesize>10</pagesize>
<pagenum>1</pagenum>
<corporation_id>3398351028</corporation_id>
</body>
EOF;
$PublicAccountServerIP = "218.205.81.33";

$header[]="Host: $PublicAccountServerIP";
$header[]="Accept-Encoding: gzip";
$header[]="Content-Type: text/xml";
//自定义头部--start
$header[]="msgname: getpubliclist";
$header[]="version: 1.0.0";
$header[]="userid: +8618867101652_3398351028@li726-26";
$header[]="AuthType:httpdigest";
//自定义头部--end
$header[]="Content-Length: ".strlen($xml);

$url = "http://$PublicAccountServerIP/padata/eclient/msg";
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $xml);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
//curl_setopt($ch, CURLOPT_HEADER, 0);  #必须把应答头开启
curl_setopt($ch, CURLOPT_HEADER, 1); #头部有result: 000000 字段,表示应答请求信息,参考接口说明
$ret = curl_exec($ch);
$headSize = curl_getinfo($ch,CURLINFO_HEADER_SIZE); #获取头部数据大小,此项必须增加进来
curl_close($ch);

$strHead = substr($ret,0,$headSize-2); # \r\n多余
$strBody = substr($ret,$headSize);
echo $strHead;
echo "\r\n";
echo $strBody;
echo "\r\n";
echo getHttpField($strHead,'result');

//获取http请求头部的某个头域的值
function getHttpField($strHead,$strField){
if(!$strHead || !$strField){return null;}
$arr = explode("\r\n",$strHead);
foreach($arr AS $v){
$pos = strpos($v,':');
if($pos){
$field = substr($v,0,$pos);
$value = trim(substr($v,$pos+1));
if( $field == $strField){
return $value;
}
}
}
return null;
}


?>

重要说明:

转载于:https://www.cnblogs.com/voiphudong/p/4168693.html

### 解决前端跨域问题的方法 在开发过程中,当遇到浏览器因同源策略而阻止前后端通信的情况时,可以通过设置响应来允许跨域请求。具体来说,服务器需要返回特定的 HTTP 部字段 `Access-Control-Allow-Origin` 来告知客户端哪些来源可以访问资源。 以下是通过设置请求头解决跨域问题的具体方法: #### 方法一:在 Node.js 后端设置 CORS 请求头 如果使用的是 Node.js 作为后端服务,则可以在路由处理函数中手动设置响应以支持跨域请求[^1]: ```javascript app.get('/server', (req, res, next) => { res.setHeader('Access-Control-Allow-Origin', '*'); // 允许所有来源访问 res.json(data); // 返回给前端的数据 }); ``` 对于更复杂的场景(如需支持多种 HTTP 方法),还可以扩展部信息[^2]: ```javascript const http = require("http"); const server = http.createServer(); server.on("request", (req, res) => { res.setHeader("Access-Control-Allow-Origin", "*"); // 支持任意来源 res.setHeader("Access-Control-Allow-Methods", "DELETE,PUT,GET,POST,OPTIONS"); // 支持的HTTP方法 if (req.url === "/get" && req.method === "GET") { const data = { name: "hwc", age: 18 }; res.end(JSON.stringify(data)); } }); server.listen(3000); ``` #### 方法二:利用 Axios 配置代理 除了修改后端代码外,也可以借助 Vue 或其他框架中的配置实现跨域请求。例如,在 Vue 项目中可通过 `vue.config.js` 文件配置代理规则[^3]: ```javascript module.exports = { devServer: { proxy: { '/api': { target: 'https://www.axios-http.cn', changeOrigin: true, pathRewrite: { '^/api': '' }, }, }, }, }; ``` 在此基础上,可以直接调用 `/api/FingerUnion/list.php` 而无需关心实际的目标地址。 #### 方法三:Django 后端配合中间件 如果是基于 Django 构建的服务端应用,推荐安装并启用第三方库 django-cors-headers[^4]。完成安装之后按照官方文档将其加入到项目的 MIDDLEWARE 列表即可自动管理跨域相关内容。 --- ### 总结 无论是调整后端逻辑还是优化前端架构设计都可以有效应对跨域挑战。其中最常见也是最为直接的办法就是在每次应答之前附加必要的 Access-Control-* 系列首部项;而对于大型系统而言则建议采用反向代理或者专门构建网关层来进行统一治理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值