Ajax 400 错误请求

安东尼·罗克·约翰逊

嗨,我在这里尝试了所有可能的方法并阅读了数百个搜索结果,

当我将代码上传到服务器时出现 400 错误,在 xampp 本地它工作得很好。

我的目标是只使用 ajax 运行 php 文件,我不需要发布数据,但使用 post 是我设法让它运行 savetodb.php 的唯一方法这是我的代码:专门查看 ajax 的成功回调

<html>
<head>

    <link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
    <script
        src="https://code.jquery.com/jquery-3.2.1.js"
        integrity="sha256-DZAnKJ/6XZ9si04Hgrsxu/8s717jcIzLy3oi35EouyE="
        crossorigin="anonymous"></script>


    <link rel="stylesheet" type="text/css" href="style.css">
    <script>

        $( document ).ready(function() {
           var high = document.getElementById('high');
           var low = document.getElementById('low');
           var closing = document.getElementById('closing');
           var difference = document.getElementById('difference');
            getData();
        });
        function getData() {

            $.ajax({
                type: 'GET',
                url: 'https://api-fxpractice.oanda.com/v3/instruments/EUR_USD/candles?count=100',
                headers: {
                    'Content-Type': 'application/json',
                    'Authorization': 'Bearer token goes here'
                },
                success: function(data){
                    $.ajax({
                        type: 'POST',
                        data: data.candles[0],
                        contentType: "application/json; charset=utf-8",
                        dataType: "json",
                        headers: {'Content-Type': 'application/json'},
                        url: 'savetodb.php',
                        success: function(){
                            console.log(data);
                        }
                    })
                }

            }).done(function(data) {
                var highNew = data.candles[0]['mid']['h'];
                var lowNew = data.candles[0]['mid']['l'];
                var closeNew = data.candles[0]['mid']['c'];
                var myArray = data.candles;

                var total = 0;
                var difftotal = 0;
                var diff = 0;
                for (var i = 0, l = data.candles.length; i < l; i++) {
                    total  += parseFloat(data.candles[i]['mid']['c']);
                    diff = data.candles[i]['mid']['h'] - data.candles[i]['mid']['l'];
                    difftotal += parseFloat(diff);
                }
                var diffAvg = difftotal / data.candles.length;
                var avg = total / data.candles.length;
                var dec = avg.toFixed(5)
                var dif = diffAvg.toFixed(10)


                high.innerHTML = highNew;
                low.innerHTML = lowNew;
                closing.innerHTML = dec;
                difference.innerHTML= dif;
            });
        }
        setInterval(getData,5000);

    </script>
</head>
<body>
<div class="container">
    <div class="row">
        <div class="col-lg-12"><h1 class="title">EUR/USD</h1></div>

        <div  class="high alert alert-success col-lg-6">
        <span>HIGH</span>
            <span id="high">0.00000</span>
        </div>
        <div class="low alert alert-danger col-lg-6">
            <span>LOW</span>
            <span id="low">0.00000</span>
        </div>
        <div  class="average alert alert-info col-lg-12">
            <span>AVERAGE</span>
            <span id="closing">0.00000</span>
        </div>
        <div  class="average alert alert-info col-lg-12">
            <span>AVERAGE DIFFERENCE</span>
            <span id="difference">0.00000</span>
        </div>
    </div>
</div>
</body>
</html>

And savetodb.php is:

<?php
error_reporting(E_ALL);
ini_set('display_errors', 1);
$ch = curl_init();
//
curl_setopt($ch, CURLOPT_URL,"https://api-fxpractice.oanda.com/v3/instruments/EUR_USD/candles?count=100");
curl_setopt($ch, CURLOPT_HTTPGET , 1);
//curl_setopt($ch, CURLOPT_POSTFIELDS,$vars);  //Post Fields
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

$headers = [
    'Content-Type: application/json;charset=utf-8',
    'Authorization: Bearer token-cdf86287f59f25f0abf14e215a5b3cb1',
];

curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);

$server_output = curl_exec ($ch);
$array = json_decode($server_output,true);
curl_close ($ch);

//print_r($array);
$h = array();
$l = array();
$avg = array();


$con=mysqli_connect("etc","etc","pass","db");

mysqli_query($con,'TRUNCATE TABLE prices');
// Check connection
if (mysqli_connect_errno())
{
    echo "Failed to connect to MySQL: " . mysqli_connect_error();
}


foreach($array['candles'] as $item){
    mysqli_query($con,"INSERT INTO prices (low,high,close) VALUES ('".$item['mid']['l']."','".$item['mid']['h']."','".$item['mid']['c']."')");
}

mysqli_close($con);


?>

安东尼·罗克·约翰逊

我通过重组我的第二个 ajax 调用来修复 400 错误,将其添加为我对第一个 ajax 请求的成功调用:

success: function(data){
                    console.log('ajax success call begins');
                    $.ajax({ url: 'savetodb.php',
                        data: {action: 'test'},
                        type: 'post',
                        success: function(output) {

                        }
                    })
                }

并重构 PHP 页面上的内容以查找 POST 变量“action”,如下所示

<?php
error_reporting(E_ALL);
ini_set('display_errors', 1);

if(isset($_POST['action']) && !empty($_POST['action'])) {
    $action = $_POST['action'];
    switch($action) {
        case 'test' : test();break;
    }
}

function test(){
 // stuff to do here
}

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

$ .ajax 400错误请求

来自分类Dev

AJAX错误:400错误的请求

来自分类Dev

POST 400错误,ajax请求

来自分类Dev

AJAX请求的“ 400错误请求”响应

来自分类Dev

AJAX POST中的400错误的请求错误

来自分类Dev

Yii2 Ajax错误请求(#400)

来自分类Dev

Spring MVC Ajax 400错误请求

来自分类Dev

AJAX POST请求中的HTTP错误400

来自分类Dev

Spring MVC 400错误请求Ajax

来自分类Dev

Spring Ajax调用上的400错误请求

来自分类Dev

POST方法是ajax给出400(错误请求)

来自分类Dev

$ .ajax请求后烧瓶上的错误请求(400)

来自分类Dev

AJAX呼叫错误-状态为400(错误请求)

来自分类Dev

Flask和Ajax发布HTTP 400错误的请求错误

来自分类Dev

使用 Struts 的 JQuery.ajax 错误 400 错误请求

来自分类Dev

AJAX:400错误的要求

来自分类Dev

使用Yii 2在Ajax调用上收到错误请求(#400)

来自分类Dev

JSON Ajax发布数据-获取400错误的请求消息

来自分类Dev

在Rails-React上反应Ajax 400错误请求

来自分类Dev

jQuery $ .ajax通过发送POST接收到400错误请求

来自分类Dev

通过 CLI 发送 400 个错误的 Ajax 请求

来自分类Dev

错误的请求错误 400

来自分类Dev

Spring MVC + Ajax错误400

来自分类Dev

AJAX - 预检 400 错误

来自分类Dev

XMLHttpRequest 400在第二个请求的AJAX调用期间出现错误请求

来自分类Dev

400(错误请求)错误-使用JQuery AJAX上传Spring MVC文件

来自分类Dev

我在用wp_ajax打电话时遇到Wordpress中的400错误请求错误

来自分类Dev

在对Spring控制器的Ajax调用中出现400错误的请求错误

来自分类Dev

python请求400错误