AngularJS表单数据未存储在MySQL数据库中


AngularJS form data not stored in MySQL db

在我的AngularJS应用程序中,点击提交按钮后,表单中输入的数据不会存储在MySQL数据库中。但是,成功提交表单数据后的警报表明它正在工作。

此外,在点击提交按钮后,我希望应用程序进入下一个视图(#/setup-step2),但它仍停留在步骤1。

html部分(#/setup-step1):

<form ng-submit="submitForm1()">
Job title: <input type="text" name="jobtitle" ng-model="formData1.jobtitle">
Vacancy ID: <input type="text" name="vacancyid" ng-model="formData1.vacancyid">
<button type="submit" class="animatedbutton"> Proceed </button>
</form>

controller.js:

var ctr = angular.module('myApp.controller', []);
ctr.controller
('Step1Controller', ['$scope', '$routeParams', '$http', function($scope, $routeParams, $http){
 $scope.formData1 = {};
                        $scope.submitForm1 = function() {
                        $http({
                            method: 'POST',
                            url: 'php/setup-step1.php',
                            data: $.param($scope.formData1),
                            headers: { 'Content-Type': 'application/x-www-form-urlencoded'}
                        })
                            .success(function(data){
                                console.log(data);
                                alert("It worked");
                            })
                            .error(function(data) {
                                console.log(data);
                                alert("It didn't work");
                            })
                    }
}]);

文件夹/php:中的setup-step1.php

<?php
include_once('db.php');
// Check connection
if(mysqli_connect_errno())
  {echo '<p>Connection to MySQL server failed: '.mysqli_connect_error().'</p>';}
else
  {echo '<p>Connection to MySQL server successful.</p>';}
$_POST = json_decode(file_get_contents("php://input"), true);
if (empty($_POST['jobtitle'])) 
   {$errors['jobtitle'] = 'Job title is required.';}
else {
// Escape user inputs for security
   $jobtitle = $_POST['jobtitle'];
   $vacancyid = $_POST['vacancyid'];
   $data = "INSERT INTO campaign (Job_title, Job_id) VALUES ('$jobtitle','$vacancyid')";mysql_query("INSERT INTO campaign (Job_title, Job_id) VALUES ('$jobtitle', '$vacancyid')");}
if ($connect->query($data) === TRUE) 
   {$conn->close();} 
else 
   {echo "Error: " . $sql . "<br>" . $conn->error;}
exit();
?>

首先,在对服务器执行任何请求之前,请确保启用了cors。当你使用angularjs时,这通常意味着你正在向服务器发出cors请求。如果您没有启用cors选项,您就不能从服务器调用任何方法,因为这是不允许的。

第二,只需将php代码保存在setup-step1.php中即可。您不需要任何html代码,因为它只会返回请求的结果。

第三,据我所知,您无法从服务器更改网页的位置,因为服务器域和网站域不同。您需要将用户重定向到angularjs中的另一个页面。您可以使用$location或$state在angularjs中找到重定向的方法。

我自己找到了答案。问题是php和mysql语法不正确。按照现在的工作方式更新了代码。