-
Notifications
You must be signed in to change notification settings - Fork 48
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
HTTPS GET request - ESP8266 - ENC28j60 #5
Comments
Hello! The EthernetLarge library doesn't compile on the ESP8266, and more importantly doesn't support the ENC8j60 module. You'll want to replace EthernetLarge with a library that supports your module, such as UIPEthernet. I went ahead and modified the EthernetHTTPS example sketch to work with UIPEthernet: /*
Web client
This sketch connects to a website (http://www.arduino.cc/asciilogo.txt)
using an Arduino Wiznet Ethernet shield.
Circuit:
* Ethernet shield attached to pins 10, 11, 12, 13
created 18 Dec 2009
by David A. Mellis
modified 9 Apr 2012
by Noah Koontz, based on work by Adrian McEwen and Tom Igoe
*/
// NOTE: This example REQUIRES the EthernetLarge library.
// You can get it here: https://github.com/OPEnSLab-OSU/EthernetLarge
#include <SPI.h>
#include <UIPEthernet.h>
#include <SSLClient.h>
#include "trust_anchors.h"
// Enter a MAC address for your controller below.
// Newer Ethernet shields have a MAC address printed on a sticker on the shield
byte mac[] = { 0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED };
// if you don't want to use DNS (and reduce your sketch size)
// use the numeric IP instead of the name for the server:
//IPAddress server(54,85,55,79); // numeric IP for Google (no DNS)
const char server[] = "www.arduino.cc"; // name address for Arduino (using DNS)
const char server_host[] = "www.arduino.cc"; // leave this alone, change only above two
// Set the static IP address to use if the DHCP fails to assign
IPAddress ip(192, 168, 0, 177);
IPAddress myDns(8, 8, 8, 8);
// Choose the analog pin to get semi-random data from for SSL
// Pick a pin that's not connected or attached to a randomish voltage source
const int rand_pin = 10;
// Initialize the SSL client library
// We input an EthernetClient, our trust anchors, and the analog pin
EthernetClient base_client;
SSLClient client(base_client, TAs, (size_t)TAs_NUM, rand_pin);
// Variables to measure the speed
unsigned long beginMicros, endMicros;
unsigned long byteCount = 0;
bool printWebData = true; // set to false for better speed measurement
void setup() {
// You can use Ethernet.init(pin) to configure the CS pin
Ethernet.init(10); // Most Arduino shields
//Ethernet.init(5); // MKR ETH shield
//Ethernet.init(0); // Teensy 2.0
//Ethernet.init(20); // Teensy++ 2.0
//Ethernet.init(15); // ESP8266 with Adafruit Featherwing Ethernet
//Ethernet.init(33); // ESP32 with Adafruit Featherwing Ethernet
// Open serial communications and wait for port to open:
Serial.begin(115200);
while (!Serial) {
; // wait for serial port to connect. Needed for native USB port only
}
// start the Ethernet connection:
Serial.println("Initialize Ethernet with DHCP:");
if (Ethernet.begin(mac) == 0) {
Serial.println("Failed to configure Ethernet using DHCP");
} else {
Serial.print(" DHCP assigned IP ");
Serial.println(Ethernet.localIP());
}
// give the Ethernet shield a second to initialize:
delay(2000);
Serial.print("connecting to ");
Serial.print(server);
Serial.println("...");
// if you get a connection, report back via serial:
auto start = millis();
// specify the server and port, 443 is the standard port for HTTPS
if (client.connect(server, 443)) {
auto time = millis() - start;
Serial.print("Took: ");
Serial.println(time);
// Make a HTTP request:
client.println("GET /asciilogo.txt HTTP/1.1");
client.println("User-Agent: SSLClientOverEthernet");
client.print("Host: ");
client.println(server_host);
client.println("Connection: close");
client.println();
} else {
// if you didn't get a connection to the server:
Serial.println("connection failed");
}
beginMicros = micros();
}
void loop() {
// if there are incoming bytes available
// from the server, read them and print them:
int len = client.available();
if (len > 0) {
byte buffer[80];
if (len > 80) len = 80;
client.read(buffer, len);
if (printWebData) {
Serial.write(buffer, len); // show in the serial monitor (slows some boards)
}
byteCount = byteCount + len;
}
// if the server's disconnected, stop the client:
if (!client.connected()) {
endMicros = micros();
Serial.println();
Serial.println("disconnecting.");
client.stop();
Serial.print("Received ");
Serial.print(byteCount);
Serial.print(" bytes in ");
float seconds = (float)(endMicros - beginMicros) / 1000000.0;
Serial.print(seconds, 4);
float rate = (float)byteCount / seconds / 1000.0;
Serial.print(", rate = ");
Serial.print(rate);
Serial.print(" kbytes/second");
Serial.println();
// do nothing forevermore:
while (true) {
delay(1);
}
}
} In order to run this sketch you'll need to update SSLClient to v1.4.4 and install the UIPEthernet library. I don't have the hardware to test the sketch, but I was able to compile it without issues. Let me know if it works! On another note, it looks TLS over ethernet is being integrated into the ESP8266 core: esp8266/Arduino#6680, so in the future you won't need SSLClient. Oh well. |
Hi prototypicalpro, thanks for your fast response, now I have the 1.4.4 version (Downloaded from https://www.arduinolibraries.info/libraries/ssl-client). With the new library <UIPEthernet.h> it works ok, I can connect with my LAN network and I have an IP but when I try connect with the server "if (client.connect("jsonplaceholder.typicode.com", 443)) {" using SSL conection I receive an error in the Serial Monitor, I reduce the code to understand it better, my code is below: NOTE: when I compile this code to my NodeMCU 1.0 (ESP-12E Module) I receive this message: ATTENTION: The SSLClient-1.4.4 library is intended to run on samd architecture (s) and may be incompatible with your current card which runs on esp8266 architecture (s). `#include <SPI.h> byte mac[] = { 0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED }; EthernetClient base_client; void setup() { if (client.connect("jsonplaceholder.typicode.com", 443)) { } void loop() { The Output in my Serial Monitor is: Started When I change the line to connect with the server by this, I can connect with the page: "if (base_client.connect("jsonplaceholder.typicode.com", 80)) {" Then my ENC28j60 is working ok with the ESP8266 and I can query a web service using HTTP. //------------------------------------------------------------------------------------------------------------------------// DHCP assigned IP 192.168.1.104 disconnecting. ets Jan 8 2013,rst cause:4, boot mode:(3,6) wdt reset disconnecting. //---------------------------------------------------------------------------------------// I dont know why my microcontroller is restarting with your example. Thanks for your help friend. |
That's interesting. The code where the SSLClient is failing is here (SSLClient.cpp:21): ...
const bool connect_ok = get_arduino_client().connect(host, port);
if (!connect_ok) {
m_error("Failed to connect using m_client. Are you connected to the internet?", func_name);
setWriteError(SSL_CLIENT_CONNECT_FAIL);
return 0;
}
... All ...
if(!base_client.connect(host, port))
... However this would suggest that your test Could you try running |
Hi my friend, // ---------- Code: void setup() { if (base_client.connect("jsonplaceholder.typicode.com", 443)) {
} else { // ---------- Response in serial port: 400 Bad RequestThe plain HTTP request was sent to HTTPS portcloudflare This is normal because the UIPEthernet send this information (Get request) in HTTP way, so this request can't arrive in the 443 port (https port). Thanks for your help my friend. |
Alright, so we know for sure that UIPEthernet is not the problem. I made some changes and released v1.4.6, could you update SSLClient and give the sketch I sent you another shot? |
Hi friend, I've uploaded your code, only I've commented this line Ethernet.init(10); all the code is equal. This is what I'm receiving in my serial port: //----------------------------------------------------------------------- Initialize Ethernet with DHCP: User exception (panic/abort/assert)
ctx: sys ets Jan 8 2013,rst cause:2, boot mode:(3,6) load 0x4010f000, len 1392, room 16 Initialize Ethernet with DHCP: disconnecting. |
Alright, so Unfortunately, since this was a design choice, reducing the memory usage of SSLClient is not an easy fix. I can do some additional investigation of this issue, however your best bet is probably going to be to wait for this pull request to the ESP8266 core which will add support for SSL to all network interfaces. I will add a note to the README that the ESP8266 is not supported until I can address this issue. Sorry I couldn't be of more help. Send me an update if you make any progress. |
hello, i am facing the same problem after 4 years. no idea how to improve it. any ideas? |
Hi, I'm traying to compile the SSLClient library in my ESP8266 but I have this message:
Several libraries were found for "EthernetLarge.h"
using: /home/xx/Arduino/libraries/EthernetLarge-master
Several libraries were found for "SSLClient.h"
using: /home/xx/Arduino/libraries/SSLClient
Several libraries were found for "SPI.h"
using: /home/xx/.arduino15/packages/esp8266/hardware/esp8266/2.6.3/libraries/SPI
exit status 1
Error compiling for card NodeMCU 1.0 (ESP-12E Module).
I'm wanna use the SSLClient library to query a HTTPS web service using an ESP8266 (NodeMCU 1.0 ESP-12E) with a ENC28j60 (Ethernet module), I wanna know if this is possible.
Thanks.
The text was updated successfully, but these errors were encountered: