php post请求后端拿不到值_PHP解决Vue发起POST请求,接收不到数据

刚开始使用vue对接后端接口时,PHP后端一直接受不到前端传的参数。找了很久,发现vue请求接口传参的形式是流的方式,因此后端要在接受数据的方面做一些改变。这里我用的是PHP原生方法file_get_contents。

file_get_contents("php://input")的使用方法

php://input 是个可以访问请求的原始数据的只读流。 POST 请求的情况下,最好使用 php://input 来代替 ,因为它不依赖于特定的 php.ini 指令。

而且,enctype="multipart/form-data" 的时候 php://input 是无效的。

下面是使用中的一些要点:1.php://input 可以读取http entity body中指定长度的值,由Content-Length指定长度,不管是POST方式或者GET方法提交过来的数据。但是,一般GET方法提交数据 时,http request entity body部分都为空。 2.php://input 与$HTTP_RAW_POST_DATA读取的数据是一样的,都只读取Content-Type不为multipart/form-data的数据。3.Coentent-Type仅在取值为application/x-www-data-urlencoded和multipart/form-data两种情况下,PHP才会将http请求数据包中相应的数据填入全局变量$_POST

4.PHP不能识别的Content-Type类型的时候,会将http请求包中相应的数据填入变量$HTTP_RAW_POST_DATA

5. 只有Coentent-Type为multipart/form-data的时候,PHP不会将http请求数据包中的相应数据填入php://input,否则其它情况都会。填入的长度,由Coentent-Length指定。 6.只有Content-Type为application/x-www-data-urlencoded时,php://input数据才跟$_POST数据相一致。 7.php://input数据总是跟$HTTP_RAW_POST_DATA相同,但是php://input比$HTTP_RAW_POST_DATA更凑效,且不需要特殊设置php.ini 8.PHP会将PATH字段的query_path部分,填入全局变量$_GET。通常情况下,GET方法提交的http请求,body为空。

代码实例

1.接收XML数据(php用file_get_contents("php://input")或者$HTTP_RAW_POST_DATA可以接收xml数据)xmldata';//要发送的xml

$url = 'http://localhost/test/getXML.php';//接收XML地址

$header = 'Content-type: text/xml';//定义content-type为xml

$ch = curl_init(); //初始化curl

curl_setopt($ch, CURLOPT_URL, $url);//设置链接

curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);//设置是否返回信息

curl_setopt($ch, CURLOPT_HTTPHEADER, $header);//设置HTTP头

curl_setopt($ch, CURLOPT_POST, 1);//设置为POST方式

curl_setopt($ch, CURLOPT_POSTFIELDS, $xml);//POST数据

$response = curl_exec($ch);//接收返回信息

if(curl_errno($ch)){//出错则显示错误信息

print curl_error($ch);

}

curl_close($ch); //关闭curl链接

echo $response;//显示返回信息?>

2.上传文件

3.接收文件

3.获取HTTP请求原文/**

* 获取HTTP请求原文

* @return string

*/

function get_http_raw() {

$raw = '';     // (1) 请求行

$raw .= $_SERVER['REQUEST_METHOD'].' '.$_SERVER['REQUEST_URI'].' '.$_SERVER['SERVER_PROTOCOL']."\r\n";     // (2) 请求Headers

foreach($_SERVER as $key => $value) {        if(substr($key, 0, 5) === 'HTTP_') {

$key = substr($key, 5);

$key = str_replace('_', '-', $key);

$raw .= $key.': '.$value."\r\n";

}

}     // (3) 空行

$raw .= "\r\n";     // (4) 请求Body

$raw .= file_get_contents('php://input');     return $raw;

}

作者:赵客缦胡缨v吴钩霜雪明

链接:https://www.jianshu.com/p/74b140d89373

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你在 Vue 3 中使用 axios 或者 fetch API 发送 POST 请求传递多个参数,但是在后端无法获取这些参数,可能是因为请求头未设置正确导致的。 在使用 axios 或者 fetch API 发送 POST 请求时,需要设置请求头的 Content-Type 为 application/x-www-form-urlencoded。这样服务器才能正确解析请求体中的参数。 以下是设置请求头的示例代码: ```javascript import axios from 'axios'; const data = { param1: 'value1', param2: 'value2', param3: 'value3' }; axios.post('/api/endpoint', data, { headers: { 'Content-Type': 'application/x-www-form-urlencoded' } }) .then(response => { console.log(response); }) .catch(error => { console.log(error); }); ``` 在上面的示例中,我们通过在 axios.post() 方法的第三个参数中设置 headers 来设置请求头,其中 Content-Type 设置为 application/x-www-form-urlencoded。 如果你使用的是 fetch API,可以使用 Request 对象来设置请求头。以下是使用 fetch API 发送 POST 请求并设置请求头的示例代码: ```javascript const data = new URLSearchParams(); data.append('param1', 'value1'); data.append('param2', 'value2'); data.append('param3', 'value3'); fetch('/api/endpoint', { method: 'POST', body: data, headers: { 'Content-Type': 'application/x-www-form-urlencoded' } }) .then(response => { console.log(response); }) .catch(error => { console.log(error); }); ``` 在上面的示例中,我们使用了 URLSearchParams 对象来构造请求体,并通过设置 headers 属性来设置请求头。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值