2017-10-16 8 views
1

使用してアルドゥイーノからGETリクエストを送信します。私のデータベースに何も見ていないことを除いて、すべてが完璧に動作しているようです。カントは、私は私が私のオンラインのホスティングにあるPHPスクリプトにENC28J60を使用して、私のArduinoからGETリクエストを送信する簡単なアプリケーションを構築していENC28J60

ピン:

ENC SO - >アルドゥイーノピン12

ENC SI - >アルドゥイーノピン11

ENC SCK - >アルドゥイーノピン13

ENC CS - > Arduinoのピン10

ENC VCC - >アルドゥイーノ3V3ピン

ENC GND - > Aここrduino GNDピン

はArduinoのコードです:

#include <EtherCard.h> 



#define PATH "index.php" 
#define VARIABLE "test" 

// ethernet interface mac address, must be unique on the LAN 
byte mymac[] = { 0x74,0x69,0x69,0x2D,0x30,0x31 }; 

const char website[] PROGMEM = "billyval-com.stackstaging.com"; 

byte Ethernet::buffer[700]; 
uint32_t timer; 
Stash stash; 

void setup() { 
    Serial.begin(57600); 
    Serial.println("\n[webClient]"); 

    if (ether.begin(sizeof Ethernet::buffer, mymac) == 0) 
    Serial.println("Failed to access Ethernet controller"); 
    if (!ether.dhcpSetup()) 
    Serial.println("DHCP failed"); 

    ether.printIp("IP: ", ether.myip); 
    ether.printIp("GW: ", ether.gwip); 
    ether.printIp("DNS: ", ether.dnsip); 

    if (!ether.dnsLookup(website)) 
    Serial.println("DNS failed"); 

    ether.printIp("SRV: ", ether.hisip); 
} 

void loop() { 
    ether.packetLoop(ether.packetReceive()); 

    if (millis() > timer) { 
    timer = millis() + 10000; 

    byte sd = stash.create(); 
    stash.print("variable="); 
    stash.print(VARIABLE); 
    stash.save(); 


      Stash::prepare(PSTR("GET http://$F/$F HTTP/1.1" "\r\n" 
        "Host: $F" "\r\n" 
        "Content-Length: $D" "\r\n" 
        "Content-Type: application/x-www-form-urlencoded; charset=UTF-8" "\r\n" 
        "\r\n" 
        "$H"), 
     website, PSTR(PATH), website, stash.size(), sd); 

    // send the packet - this also releases all stash buffers once done 
    ether.tcpSend(); 

    } 
} 

、ここでは基本的なPHPスクリプトです:ここ

<?php 

$link = mysqli_connect("xxxx", "xxx", "xxx", "xxx"); 
if(mysqli_connect_error()){ 
    die("database failed"); 
} 

if(isset($_GET['variable'])){ 

    $query = "INSERT INTO variables (variable) VALUES ('". $_GET['variable'] ."') "; 
    mysqli_query($link, $query); 

} 

?> 

は、私は、シリアルモニターから取るものです:

[Webクライアント]

IP:192.168.10.10

GW:XXX

DNS:XXX

SRV:私はベースをチェックするときXXX

は、しかし、私は、挿入されたものを参照してください傾けます。しかし、私は次のようにブラウザで手動で行う場合: billyval-com.stackstaging.com/index.php?variable=x私は、データベースに挿入された値(X)を見ることができます。 投稿を変更しましたが、変更が反映されません。

私は、問題がどこにあるかそれを把握カントと誰かが私を助けることができる場合、私はそれをここに投稿してください。

ありがとうございます。

+0

GET HTTPリクエストにメッセージ本文が含まれていないようにしてください。 –

+0

あなたはより魅力的になりますか? Stash :: prepareから何かを削除しなければならないと思いますか? – kakavia

+0

https://www.w3schools.com/tags/ref_httpmethods.asp –

答えて

0

あなたGET要求はOKではありません:あなたはアプリケーション/ x-www-form-urlencodedでを使用するよう

Stash::prepare(PSTR("GET http://$F/$F HTTP/1.1" "\r\n" 
    "Host: $F" "\r\n" 
    "Content-Length: $D" "\r\n" 
    "Content-Type: application/x-www-form-urlencoded; charset=UTF-8" "\r\n" 
    "\r\n" 
    "$H"), 
website, PSTR(PATH), website, stash.size(), sd); 

それは、POST要求する必要があります。 POSTはデータ送信に適しています。あなたのコードにこれを適用する

POST /index.php HTTP/1.1 
Host: billyval-com.stackstaging.com 
Connection: close 
Content-Length: 200 
Content-Type: application/x-www-form-urlencoded 

variable1=1&variable2=2 

POST要求は次のようになります

Stash::prepare(PSTR("POST /$F HTTP/1.1" "\r\n" 
    "Host: $F" "\r\n" 
    "Content-Length: $D" "\r\n" 
    "Content-Type: application/x-www-form-urlencoded" "\r\n" 
    "\r\n" 
    "$H"), 
PSTR(PATH), website, stash.size(), sd); 

また、PHPのコードが変化する必要があります:

if(isset($_POST['variable'])){ 

    $query = "INSERT INTO variables (variable) VALUES ('". $_POST['variable'] ."') "; 
    mysqli_query($link, $query); 

} 

また、 read this

関連する問題