当前位置: 首页 > 面试题库 >

AngularJS HTTP发布到PHP,并且未定义

南宫俊逸
2023-03-14
问题内容

我有一个带有标签的表格 ng-submit="login()

该函数在javascript中被称为罚款。

function LoginForm($scope, $http)
{
    $http.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded; charset=UTF-8';

    $scope.email    = "fsdg@sdf.com";
    $scope.password = "1234";

    $scope.login = function()
    {
        data = {
            'email' : $scope.email,
            'password' : $scope.password
        };

        $http.post('resources/curl.php', data)
        .success(function(data, status, headers, config)
        {
            console.log(status + ' - ' + data);
        })
        .error(function(data, status, headers, config)
        {
            console.log('error');
        });
    }
}

我从PHP文件中获得了200 OK响应,但是返回的数据就是这样,email并且password未定义。这就是我拥有的所有php

<?php
$email = $_POST['email'];
$pass  = $_POST['password'];
echo $email;
?>

知道为什么我会得到未定义的POST值吗?

编辑

我想指出,因为这似乎是一个受欢迎的问题(但它是旧的),.success.error已被弃用,你应该使用.then如@詹姆斯氏族在commments指出


问题答案:

angularjs .post()默认将Content-
type标头设置为application/json。您要覆盖此内容以传递表单编码的数据,但是您没有更改data值以传递适当的查询字符串,因此PHP并未$_POST按预期填充。

我的建议是只使用默认的angularjs设置application/json作为标头,读取PHP中的原始输入,然后反序列化JSON。

可以这样在PHP中实现:

$postdata = file_get_contents("php://input");
$request = json_decode($postdata);
$email = $request->email;
$pass = $request->password;

或者,如果您严重依赖$_POST功能,则可以形成类似的查询字符串email=someemail@email.com&password=somepassword并将其作为数据发送。确保此查询字符串是URL编码的。如果是手动构建的(而不是使用类似的东西jQuery.serialize()),则Javascript
encodeURIComponent()可以为您解决问题。



 类似资料:
  • 问题内容: 我有一个带有标签的表格 该函数在javascript中被很好地调用。 我从PHP文件中获得了200 OK响应,但是返回的数据就是这样,并且未定义。这就是我拥有的所有php 知道为什么我会得到未定义的值吗? 编辑 我想指出,因为这似乎是一个受欢迎的问题(但它是旧的),并已被弃用,你应该使用如@詹姆斯氏族在commments指出 问题答案: angularjs 默认将Content- ty

  • 问题内容: 好吧,我已经建立了我的json字符串,但是我不确定下一步该怎么做? 在我的php文件中,我试图将dataString写入文本文件,这样我可以看到它通过ok,但是文本文件中什么都没有!我在客户端或PHP方面做错了什么,我的php代码: 问题答案: 您为什么不尝试像这样构造数据 然后在您的AJAX通话中 现在,您的PHP脚本可以将数据作为多维数组处理

  • 问题内容: 我正在使用angularjs和Typescript创建一些应用程序,但是我无法解决此错误, 这是我的* .ts代码 这是我的GULP任务 这是我的错误:未捕获的ReferenceError:导出未定义 问题是:如何在打字稿中使用类似es6的导入?我缺少什么? 问题答案: 我使用angular 1.6和webpack,当我将模块更改为 “ umd”* 时,它可以在我这边使用 * UMD:

  • 我有一个Azure WebJobs,我正在从Visual Studio 2017发布到标准S1应用服务,WebJobs应该由CRON触发,但总是发布为连续,我不知道我做错了什么(另外两个WebJobs发布罚款) 我在根目录下有一个settings.job文件和我的日程安排 我的程序课 以及正在调用的函数

  • 发布到DynamoDB,以便用户登录。 致命错误:未捕获的异常'Aws\DynamoDb\Exception\DynamoDbException',带有消息'在“https://dynamodb.us-east-1.amazonaws.com”上执行“GetItem”时出错;AWS HTTP错误:客户端错误:导致响应:{"__type":"com.amazon.coral.validate#Val