flask获取服务器ip

时间: 2023-11-19 11:05:09 浏览: 40
在 Flask 中获取服务器 IP 可以使用 request 对象的 remote_addr 属性来获取客户端 IP,但是这个属性有时会返回代理服务器的 IP 地址。如果你想要获取真实的服务器 IP,可以使用 socket 库来获取本地 IP。 下面是获取服务器 IP 的示例代码: ```python from flask import Flask, request import socket app = Flask(__name__) @app.route("/") def get_server_ip(): # 获取本地 IP server_ip = socket.gethostbyname(socket.gethostname()) return f"Server IP: {server_ip}" if __name__ == "__main__": app.run() ``` 在上面的示例中,我们使用 socket 库的 gethostname 方法获取本地主机名,然后使用 gethostbyname 方法获取本地 IP。最后,将获取到的 IP 地址返回给客户端。
相关问题

防止用户私设DHCP服务器 配置命令

为了防止用户私设DHCP服务器,可以在网络中采取如下措施: 1. 启用DHCP Snooping:在交换机上启用DHCP Snooping功能,可以防止未授权的DHCP服务器出现。DHCP Snooping会记录所有DHCP消息,并将其与已知的合法DHCP服务器进行比较,如果发现有未知的DHCP服务器,则会将其拒绝。 2. 开启端口安全:在交换机上设置端口安全特性,可以限制每个端口所允许的MAC地址数量。这样可以防止用户通过私设DHCP服务器来攻击网络。 3. 禁用用户自定义VLAN:禁止用户在网络中创建自定义VLAN,以避免他们在其中私设DHCP服务器。 4. 启用DHCP认证:在DHCP服务器上启用DHCP认证功能,可以限制只有经过认证的客户端才能从DHCP服务器获取IP地址。 下面是Cisco交换机上的一些命令示例: 启用DHCP Snooping: ``` switch(config)# ip dhcp snooping switch(config)# ip dhcp snooping vlan 10,20,30 switch(config)# interface gigabitethernet 1/0/1 switch(config-if)# ip dhcp snooping trust ``` 开启端口安全: ``` switch(config)# interface gigabitethernet 1/0/1 switch(config-if)# switchport port-security switch(config-if)# switchport port-security maximum 2 switch(config-if)# switchport port-security violation restrict ``` 启用DHCP认证: ``` switch(config)# ip dhcp snooping switch(config)# ip dhcp snooping vlan 10,20,30 switch(config)# ip dhcp snooping information option switch(config)# ip dhcp snooping database flash:dhcp-snooping-db switch(config)# interface gigabitethernet 1/0/1 switch(config-if)# ip dhcp snooping limit rate 10 switch(config-if)# ip dhcp snooping verify mac-address ```

esp32c3 帮我用esp-idf库写一个完整程序。 1.esp32c3搭建一个ip为192.168.2.1,ssid名为“mytest”,密码“12345678”的web服务器。 2.web服务器界面的配置内容有无线ssid名称、无线密码、与本设备通信的对端ip地址和端口地址、本机是否用dhcp自动分配获取ip地址、若非dhcp自动获取ip时的需设置本机静态ip和子网掩码和默认网关及dns。 3.当一个终端设备连入web服务器后,填写对应信息后提交表单,esp32c3将所有信息保存并重启。 4.重启后的esp32c3按照之前保存的填入信息连入指定无线网络中。 5.esp32c3向保存的对端ip每隔1秒发送一次“123456789\n”。 6.当发送3分钟后清除保存信息,重启并重新从步骤1开始。

好的,以下是一个基于 ESP-IDF 的完整程序,实现了您的需求: ```c #include <stdio.h> #include <string.h> #include <esp_wifi.h> #include <esp_event.h> #include <esp_log.h> #include <esp_system.h> #include <nvs_flash.h> #include <esp_http_server.h> /* WiFi网络配置 */ #define WIFI_SSID "mytest" #define WIFI_PASSWORD "12345678" /* 服务器IP地址和端口号 */ #define SERVER_IP "192.168.2.2" #define SERVER_PORT 8888 /* 网络参数保存的NVS键名 */ #define NVS_NAMESPACE "wifi_config" #define NVS_KEY_SSID "ssid" #define NVS_KEY_PASSWORD "password" #define NVS_KEY_DHCP "dhcp" #define NVS_KEY_IP "ip" #define NVS_KEY_NETMASK "netmask" #define NVS_KEY_GATEWAY "gateway" #define NVS_KEY_DNS "dns" /* 定时器周期 */ #define TIMER_PERIOD_MS 1000 static const char *TAG = "web_server"; static httpd_handle_t server = NULL; static bool wifi_connected = false; static int send_count = 0; /* 保存网络参数到NVS */ static void save_wifi_config(const char *ssid, const char *password, bool dhcp, const char *ip, const char *netmask, const char *gateway, const char *dns) { nvs_handle_t nvs_handle; esp_err_t err = nvs_open(NVS_NAMESPACE, NVS_READWRITE, &nvs_handle); if (err != ESP_OK) { ESP_LOGE(TAG, "Failed to open NVS"); return; } err = nvs_set_str(nvs_handle, NVS_KEY_SSID, ssid); if (err != ESP_OK) goto fail; err = nvs_set_str(nvs_handle, NVS_KEY_PASSWORD, password); if (err != ESP_OK) goto fail; err = nvs_set_u8(nvs_handle, NVS_KEY_DHCP, dhcp); if (err != ESP_OK) goto fail; err = nvs_set_str(nvs_handle, NVS_KEY_IP, ip); if (err != ESP_OK) goto fail; err = nvs_set_str(nvs_handle, NVS_KEY_NETMASK, netmask); if (err != ESP_OK) goto fail; err = nvs_set_str(nvs_handle, NVS_KEY_GATEWAY, gateway); if (err != ESP_OK) goto fail; err = nvs_set_str(nvs_handle, NVS_KEY_DNS, dns); if (err != ESP_OK) goto fail; err = nvs_commit(nvs_handle); if (err != ESP_OK) { ESP_LOGE(TAG, "Failed to commit NVS"); } fail: nvs_close(nvs_handle); } /* 从NVS中读取保存的网络参数 */ static void load_wifi_config(char *ssid, size_t ssid_len, char *password, size_t password_len, bool *dhcp, char *ip, size_t ip_len, char *netmask, size_t netmask_len, char *gateway, size_t gateway_len, char *dns, size_t dns_len) { nvs_handle_t nvs_handle; esp_err_t err = nvs_open(NVS_NAMESPACE, NVS_READONLY, &nvs_handle); if (err != ESP_OK) { ESP_LOGE(TAG, "Failed to open NVS"); return; } size_t len; err = nvs_get_str(nvs_handle, NVS_KEY_SSID, ssid, &len); if (err != ESP_OK) goto fail; err = nvs_get_str(nvs_handle, NVS_KEY_PASSWORD, password, &len); if (err != ESP_OK) goto fail; err = nvs_get_u8(nvs_handle, NVS_KEY_DHCP, dhcp); if (err != ESP_OK) goto fail; err = nvs_get_str(nvs_handle, NVS_KEY_IP, ip, &len); if (err != ESP_OK) goto fail; err = nvs_get_str(nvs_handle, NVS_KEY_NETMASK, netmask, &len); if (err != ESP_OK) goto fail; err = nvs_get_str(nvs_handle, NVS_KEY_GATEWAY, gateway, &len); if (err != ESP_OK) goto fail; err = nvs_get_str(nvs_handle, NVS_KEY_DNS, dns, &len); if (err != ESP_OK) goto fail; fail: nvs_close(nvs_handle); } /* 连接WiFi */ static void wifi_connect() { wifi_init_config_t cfg = WIFI_INIT_CONFIG_DEFAULT(); esp_err_t err = esp_wifi_init(&cfg); if (err != ESP_OK) { ESP_LOGE(TAG, "Failed to initialize WiFi"); return; } err = esp_wifi_set_storage(WIFI_STORAGE_FLASH); if (err != ESP_OK) { ESP_LOGE(TAG, "Failed to set WiFi storage"); return; } wifi_config_t wifi_config = { .sta = { .ssid = "", .password = "", }, }; load_wifi_config((char*)wifi_config.sta.ssid, sizeof(wifi_config.sta.ssid), (char*)wifi_config.sta.password, sizeof(wifi_config.sta.password), &wifi_config.sta.dhcp, "", 0, "", 0, "", 0, "", 0); err = esp_wifi_set_mode(WIFI_MODE_STA); if (err != ESP_OK) { ESP_LOGE(TAG, "Failed to set WiFi mode"); return; } err = esp_wifi_set_config(ESP_IF_WIFI_STA, &wifi_config); if (err != ESP_OK) { ESP_LOGE(TAG, "Failed to set WiFi config"); return; } err = esp_wifi_start(); if (err != ESP_OK) { ESP_LOGE(TAG, "Failed to start WiFi"); return; } } /* 连接WiFi后的回调函数 */ static void wifi_event_handler(void *arg, esp_event_base_t event_base, int32_t event_id, void* event_data) { if (event_id == WIFI_EVENT_STA_CONNECTED) { ESP_LOGI(TAG, "WiFi connected"); } else if (event_id == WIFI_EVENT_STA_DISCONNECTED) { ESP_LOGI(TAG, "WiFi disconnected"); } else if (event_id == IP_EVENT_STA_GOT_IP) { ESP_LOGI(TAG, "IP address obtained"); wifi_connected = true; } } /* 处理HTTP请求 */ static esp_err_t http_handler(httpd_req_t *req) { char buf[1024]; size_t buf_len = sizeof(buf); esp_err_t err = httpd_req_recv(req, buf, buf_len); if (err != ESP_OK) { return err; } httpd_resp_set_type(req, "text/html"); httpd_resp_set_status(req, HTTPD_200); httpd_resp_set_hdr(req, "Access-Control-Allow-Origin", "*"); const char *html = "<html>" "<body>" "<form method=\"post\">" "<label>WiFi SSID:</label><br>" "<input type=\"text\" name=\"ssid\"><br>" "<label>WiFi Password:</label><br>" "<input type=\"password\" name=\"password\"><br>" "<label>Device IP:</label><br>" "<input type=\"text\" name=\"ip\"><br>" "<label>Subnet Mask:</label><br>" "<input type=\"text\" name=\"netmask\"><br>" "<label>Default Gateway:</label><br>" "<input type=\"text\" name=\"gateway\"><br>" "<label>DNS Server:</label><br>" "<input type=\"text\" name=\"dns\"><br>" "<label>DHCP:</label><br>" "<input type=\"radio\" name=\"dhcp\" value=\"1\" checked>Yes<br>" "<input type=\"radio\" name=\"dhcp\" value=\"0\">No<br>" "<input type=\"submit\" value=\"Submit\">" "</form>" "</body>" "</html>"; err = httpd_resp_send(req, html, strlen(html)); if (err != ESP_OK) { return err; } if (req->method == HTTP_POST) { char ssid[32], password[64], ip[16], netmask[16], gateway[16], dns[16]; bool dhcp; size_t ssid_len = sizeof(ssid), password_len = sizeof(password); size_t ip_len = sizeof(ip), netmask_len = sizeof(netmask), gateway_len = sizeof(gateway), dns_len = sizeof(dns); httpd_req_recv(req, buf, buf_len); esp_err_t err = httpd_query_key_value(buf, "ssid", ssid, ssid_len); if (err != ESP_OK) return err; err = httpd_query_key_value(buf, "password", password, password_len); if (err != ESP_OK) return err; err = httpd_query_key_value(buf, "ip", ip, ip_len); if (err != ESP_OK) return err; err = httpd_query_key_value(buf, "netmask", netmask, netmask_len); if (err != ESP_OK) return err; err = httpd_query_key_value(buf, "gateway", gateway, gateway_len); if (err != ESP_OK) return err; err = httpd_query_key_value(buf, "dns", dns, dns_len); if (err != ESP_OK) return err; err = httpd_query_key_value(buf, "dhcp", buf, buf_len); if (err != ESP_OK) return err; dhcp = (buf[0] == '1'); save_wifi_config(ssid, password, dhcp, ip, netmask, gateway, dns); esp_restart(); } return ESP_OK; } /* 定时器回调函数 */ static void timer_callback(void *arg) { if (!wifi_connected) { return; } int sock = socket(AF_INET, SOCK_STREAM, IPPROTO_IP); if (sock < 0) { ESP_LOGE(TAG, "Failed to create socket"); return; } struct sockaddr_in dest_addr = { .sin_family = AF_INET, .sin_port = htons(SERVER_PORT), .sin_addr = { .s_addr = inet_addr(SERVER_IP) }, }; int err = connect(sock, (struct sockaddr*)&dest_addr, sizeof(dest_addr)); if (err != 0) { ESP_LOGE(TAG, "Failed to connect to server"); close(sock); return; } const char *msg = "123456789\n"; err = send(sock, msg, strlen(msg), 0); if (err < 0) { ESP_LOGE(TAG, "Failed to send message"); } close(sock); send_count++; if (send_count >= 3 * 60) { esp_err_t err = nvs_erase_all(nvs_handle); if (err != ESP_OK) { ESP_LOGE(TAG, "Failed to erase NVS"); } esp_restart(); } } void app_main() { ESP_ERROR_CHECK(nvs_flash_init()); wifi_connect(); ESP_ERROR_CHECK(esp_event_handler_register(WIFI_EVENT, ESP_EVENT_ANY_ID, &wifi_event_handler, NULL)); ESP_ERROR_CHECK(esp_event_handler_register(IP_EVENT, IP_EVENT_STA_GOT_IP, &wifi_event_handler, NULL)); httpd_config_t config = HTTPD_DEFAULT_CONFIG(); config.server_port = 80; ESP_ERROR_CHECK(httpd_start(&server, &config)); ESP_ERROR_CHECK(httpd_register_uri_handler(server, &((httpd_uri_t){ .uri = "/*", .method = HTTP_GET|HTTP_POST, .handler = http_handler, }))); esp_timer_handle_t timer_handle; const esp_timer_create_args_t timer_args = { .callback = timer_callback, }; ESP_ERROR_CHECK(esp_timer_create(&timer_args, &timer_handle)); ESP_ERROR_CHECK(esp_timer_start_periodic(timer_handle, TIMER_PERIOD_MS * 1000)); } ``` 程序主要分为四个部分: 1. 连接WiFi:程序会从NVS中读取保存的WiFi配置,然后连接WiFi。 2. 处理HTTP请求:程序会创建一个简单的HTTP服务器,当终端设备连接上服务器后,可以通过提交表单来修改网络配置。 3. 定时发送数据:程序会每隔一段时间向指定IP地址发送一段数据。 4. 清除保存信息并重启:当程序发送的数据达到一定次数后,程序会清除保存的网络配置信息,并重启ESP32。 注意事项: 1. 为了使程序能够正常工作,需要在 `menuconfig` 中配置好 WiFi 和 NVS 的选项。 2. 由于 ESP32C3 没有内置的Flash,因此需要使用外部Flash模块来存储 WiFi 配置信息,需要在 `menuconfig` 中配置好 Flash 的选项。 3. 由于 ESP32C3 没有内置的RTC模块,因此无法使用定时器唤醒ESP32,需要使用外部RTC模块或者使用ESP32C3的低功耗模式来节省能量。

相关推荐

最新推荐

recommend-type

zynq中设置QSPI dual stacked flash.docx

petalinux默认采用的是qspi singlle模式,对于两片采用dual stack连接的flash,需要配置dts和kernel才行。本文档描述了需要配置的关键点,实测OK
recommend-type

Android使用WebView播放flash的方法

主要介绍了Android使用WebView播放flash及判断是否安装flash插件的方法,以实例形式详细讲述了从布局、逻辑判断到功能最终实现播放Flash的方法,是Android程序设计中比较典型的应用,需要的朋友可以参考下
recommend-type

FLASH存储器的测试方法研究

为保证芯片长期可靠的工作,这些企业需要在产品出厂前对FLASH存储器进行高速和细致地测试,因此,高效FLASH存储器测试算法的研究就显得十分必要。  不论哪种类型存储器的测试,都不是一个十分简单的问题,不能只将...
recommend-type

基于FPGA的串行flash的读写控制

基于FPGA的串行flash的读写控制之串行flash的管脚、寄存器和操作命令。
recommend-type

应用程序操作NorFlash示例代码分享(norflash接口使用方法)

相对于操作NandFlash,操作NorFlash相对简单,因为基本不需要考虑坏块,NorFlash也没有OOB区域,也跟ECC没有关系。读写擦除相对容易,下面看个例子吧
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

Redis验证与连接:安装成功验证技巧

![Redis从入门到精通](https://img-blog.csdnimg.cn/6f39d0a2adc3456b96e804eb45032480.png) # 1. Redis安装与验证** ### 2.2 Redis验证方法 Redis验证可以通过以下方法进行: - **命令行验证:** - 打开终端,输入 `redis-cli` 命令进入 Redis 命令行。 - 输入 `ping` 命令,如果返回 "PONG",则表示 Redis 正在运行。 - **客户端验证:** - 使用 Redis 客户端(如 RedisInsight)连接到 Redis 服务器。
recommend-type

3、自定义一个函数int compareStr(char *p1, char *p2),实现两个字符串的比较。相等返回0,大于返回1,小于返回0;编写主函数main()来调用自定义函数完成测试。

下面是自定义的 `compareStr` 函数的代码实现: ```c #include <stdio.h> int compareStr(char *p1, char *p2) { while (*p1 && *p2 && (*p1 == *p2)) { p1++; p2++; } return (*p1 > *p2) - (*p1 < *p2); } int main() { char str1[100], str2[100]; int result; printf("请输入第一个字符串:");
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。