I have been facing this problem every now and then. I have tried many ways but have not got any success. How can I figure out where I am going wrong? This is my PHP script:
    <?php 
    if (isset($_SERVER['HTTP_ORIGIN'])) {
            header("Access-Control-Allow-Origin: {$_SERVER['HTTP_ORIGIN']}");
            header('Access-Control-Allow-Credentials: true');
            header('Access-Control-Max-Age: 86400');    // cache for 1 day
        }
        if ($_SERVER['REQUEST_METHOD'] == 'OPTIONS') {
            if (isset($_SERVER['HTTP_ACCESS_CONTROL_REQUEST_METHOD']))
                header("Access-Control-Allow-Methods: GET, POST, OPTIONS");         
            if (isset($_SERVER['HTTP_ACCESS_CONTROL_REQUEST_HEADERS']))
                header("Access-Control-Allow-Headers: {$_SERVER['HTTP_ACCESS_CONTROL_REQUEST_HEADERS']}");
            exit(0);
        }
    $mysql_host = "localhost";
    $mysql_database = "locationtracker";
    $mysql_user = "root";
    $mysql_password = "";
    // Create connection
    $conn = new mysqli($mysql_host, $mysql_user, $mysql_password,$mysql_database);
    if ($conn->connect_error) {
        //die("Connection failed: " . $conn->connect_error);
    } 
    $postdata = file_get_contents("php://input");
        if (isset($postdata)) {
            $request = json_decode($postdata);
             $user= $request->username;
                    }
        $sql = "SELECT u_id FROM user_info WHERE login_id = '$user'";
          $result = mysqli_query($conn,$sql);
          $row = mysqli_fetch_array($result,MYSQLI_ASSOC);
          $active = $row['active'];
          $count = mysqli_num_rows($result);
          if($count >0) {
         $response= "Your Login success";
          }else {
        $response= "Your Login Email or Password is invalid";         
          }
     echo json_encode( $response);
    ?>
Note: This script will be used for ionic login authentication part.
 
     
    