|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 划句顾 于 2021-9-8 13:08 编辑
点击视频--点赞球球了
资源包:
data.zip
(3.74 KB, 下载次数: 13)
代码如下:
这部分和上一个代码有很多一样的地方。
- /***
- *author:LaoGu
- *time :2021/9/4
- *purpose:使用ESP8266-NodeMCU建立一个有多个页面的网站。通过LED页面
- 的文本输入可以控制板上LED的亮度。
- **/
- #include<ESP8266WiFi.h>
- #include<ESP8266WiFiMulti.h>
- #include<ESP8266WebServer.h>
- #include<FS.h>
- ESP8266WiFiMulti wifiMulti;
- ESP8266WebServer esp8266_server(80);
- void setup() {
- Serial.begin(9600);
- Serial.println("");
- pinMode(LED_BUILTIN,OUTPUT);
- wifiMulti.addAP("小G的wife","gyl5201314");
- wifiMulti.addAP("nanjishit","guyiling5201314");
- Serial.println("Connecting...");
-
- int i = 0;
- while(wifiMulti.run()!=WL_CONNECTED){
- delay(1000);
- Serial.print(i++); Serial.print(" ");
- }
- Serial.println("\n");
- Serial.print("Connected to ");
- Serial.println(WiFi.SSID());
- Serial.print("IP address: ");
- Serial.println(WiFi.localIP());
- if(SPIFFS.begin()){
- Serial.println("SPIFFS Started.");
- }else{
- Serial.println("SPIFFS Failed to start.");
- }
- //初始化网络服务器
- esp8266_server.on("/LED-Control",handleLEDControl);
- esp8266_server.onNotFound(handleUserRequest);
- esp8266_server.begin();
- Serial.println("HTTP server started.");
- }
- void loop() {
- esp8266_server.handleClient(); //处理网络请求
- }
复制代码
不一样在这里
- void handleLEDControl(){
- //从浏览器发送的信息中获取PWM控制数值(字符串格式)
- String ledPwm = esp8266_server.arg("ledPwm"); //通过arg()函数,我们可以获取客户端向ESP8266物联网服务器发送的指定参数的数值。
- //将字符串格式的PWM控制数值转换为整数
- int ledPwmVal = ledPwm.toInt();
- //实施引脚PWM设置
- analogWrite(LED_BUILTIN,ledPwmVal);
- //建立基本网页信息显示当前数值以及返回链接
- String httpBody = "LED PWM:" + ledPwm + "<p><a href = "/LED.html"><-LED Page</a></p>";
- esp8266_server.send(200,"text/html",httpBody);
- }
复制代码
处理用户浏览器的HTTP的访问
- void handleUserRequest(){
- //获取用户请求资源
- String reqResource = esp8266_server.uri();
- Serial.print("reqResource: ");
- Serial.println(reqResource);
- //通过handleFileRead函数处理用户请求资源
- bool fileReadOK = handleFileRead(reqResource);
- //如果在SPIFFS无法找到用户访问的资源,则回复404
- if(!fileReadOK){
- esp8266_server.send(404,"text/plain","404: NOT FOUND");
- }
- }
复制代码
下面两个代码也是不怎么改变,和之前一样。
- bool handleFileRead(String resource){
- if(resource.endsWith("/")){
- resource = "/index.html";
- }
- String contentType = getContentType(resource);
- if(SPIFFS.exists(resource)){
- File file = SPIFFS.open(resource,"r");
- esp8266_server.streamFile(file,contentType);
- file.close();
- return true;
- }
- return false;
- }
复制代码
- // 获取文件类型
- String getContentType(String filename){
- if(filename.endsWith(".htm")) return "text/html";
- else if(filename.endsWith(".html")) return "text/html";
- else if(filename.endsWith(".css")) return "text/css";
- else if(filename.endsWith(".js")) return "application/javascript";
- else if(filename.endsWith(".png")) return "image/png";
- else if(filename.endsWith(".gif")) return "image/gif";
- else if(filename.endsWith(".jpg")) return "image/jpeg";
- else if(filename.endsWith(".ico")) return "image/x-icon";
- else if(filename.endsWith(".xml")) return "text/xml";
- else if(filename.endsWith(".pdf")) return "application/x-pdf";
- else if(filename.endsWith(".zip")) return "application/x-zip";
- else if(filename.endsWith(".gz")) return "application/x-gzip";
- return "text/plain";
- }
复制代码
串口:
效果:
演示图片.zip
(1.22 MB, 下载次数: 7)
|
|