12-51单片机ESP8266学习-AT指令(ESP8266连接路由器,建立TCP服务器,分别和C#TCP客户端和AndroidTCP客户端通信+花生壳远程通信)

本文涉及的产品
可视分析地图(DataV-Atlas),3 个项目,100M 存储空间
数据可视化DataV,5个大屏 1个月
简介:

先把源码和资料链接放到这里

 

链接:https://pan.baidu.com/s/10MxI8-Q33-M_R2WEHqEi1A 密码:j1sz

 

 

前几篇是介绍的模块建立TCP服务器,不连接路由器,然后进行通信呢,连接路由器最大的好处就是可以实现远程控制

今天呢有喜有悲,悲喜交加,板子终于开始贴片了....

 

今天最让人开心的事情是自己刚做的GPRS的板子和51学习的板子虽然自己马虎画错了一个地方起初也不知道...,但是嘉立创的客服今天打电话说自己那个地方有点问题,然后给自己修改了过来,,,现在感觉在嘉立创做板子就是放心,真的.不是打广告哈,感觉人家的服务就是好

现在看一下自己画的不对的地方

现在只看机械层和底层

直接一个打孔就干掉了这条线..................机械层在画板子的时候如果不注意........下次一定要时刻提醒着自己,画完板子单独看一下机械层和顶层或底层,容易忘

 

现在接着说

其实连接路由器就一条指令

其实应该还有配置设置自己的IP地址固定住,一会在说,咱先连接路由器,然后开启TCP,然后看一下模块的IP,然后进行通信

刚才测试发现一个问题,如果配置了连接无线了(而且保存了),那么上电后模块

 

那么咱们以前的程序就不能用了,,,不能是等待3s后判断有没有ready,,,,应该是复位以后一直检测有没有回复ready,超过3S没有回复就再发送一次指令,发送的指令超过3次

那么咱就重新开始

看一个就行,,,下面的都一样

复制代码
    /*下面的都是一样的模子,注释就写一个*/
    Cnt = 0;
    CntCnt = 0;
    SendDataFlage = 1;
    while(1)
    {
        if(SendDataFlage == 1)//发送指令
        {
          SendDataFlage = 0;
          printf("8266RST\r\n");//这个不是什么指令,我先用串口调试助手模拟
          P0_0 = 1;//这个灯作为指示灯,发送个指令就亮,
          ESP_Rst();//复位8266
       }
        
        DelayMs(1);
        if(UsartFlage == 1)//串口接收到数据
        {
            UsartFlage = 0;
            if(strstr(UsartReceive, "ready"))//有没有ready
            {
                P0_0 = 0;//接收到正确的回复就灭
                DelayMs(500);
                break;
            }
         }
        
        Cnt ++;
        if(Cnt>=3000)//每间隔3S发送一次数据
        {
            SendDataFlage = 1;//允许发送数据
            Cnt = 0;
            CntCnt++;
         }
        if(CntCnt>=3)//超过三次重新开始
        {
            CntCnt = 0;
            Cnt = 0;
            goto start;
        }
  }
复制代码

 

 

所以现在的程序

复制代码
#define MAIN_C_
#include "include.h"

/**
* 介绍:  主函数
* 说明:  每间隔1S发送一次温湿度数据
* 说明:  返回串口接收到的数据,发送方式为中断发送
* 说明:  None
* 说明:  None
* 支持:  QQ946029359 --群 607064330
* 淘宝:  https://shop411638453.taobao.com/
* 作者:  小五
**/

int Cnt = 0;
unsigned char CntCnt = 0;
unsigned char SendDataFlage = 0;

unsigned char ConnectID = 0;
unsigned char i=0;
unsigned char SendDataValue[6]={0xaa,0x55};
int ReadDHT11delay = 0;//设置多少时间读一次DHT11;
void main()
{
    InitUART(115200);
    InitTimer0();
   
    start:
    
    /*下面的都是一样的模子,注释就写一个*/
    Cnt = 0;
    CntCnt = 0;
    SendDataFlage = 1;
    while(1)
    {
        if(SendDataFlage == 1)//发送指令
        {
            SendDataFlage = 0;
      printf("8266RST\r\n");//这个不是什么指令,我先用串口调试助手模拟
          P0_0 = 1;//这个灯作为指示灯,发送个指令就亮,
          ESP_Rst();//复位8266
    }
        
        DelayMs(1);
        if(UsartFlage == 1)//串口接收到数据
        {
      UsartFlage = 0;
            if(strstr(UsartReceive, "ready"))//有没有ready
            {
                P0_0 = 0;//接收到正确的回复就灭
                DelayMs(500);
                break;
            }
    }
        
        Cnt ++;
        if(Cnt>=3000)//每间隔3S发送一次数据
        {
            SendDataFlage = 1;//允许发送数据
            Cnt = 0;
            CntCnt++;
    }
        if(CntCnt>=3)//超过三次重新开始
        {
            CntCnt = 0;
            Cnt = 0;
            goto start;
        }
        
  }
    
    /*配置连接路由器*/
    Cnt = 0;
    CntCnt = 0;
    SendDataFlage = 1;
    while(1)
    {
        if(SendDataFlage)
        {
            SendDataFlage = 0;
            printf("AT+CWJAP_DEF=\"qqqqq\",\"11223344\"\r\n");//连接路由器
          P0_0 = 1;
        }
        
        DelayMs(1);
        if(UsartFlage == 1)
        {
      UsartFlage = 0;
            if(strstr(UsartReceive, "OK"))
            {
                P0_0 = 0;
                DelayMs(500);
                break;
            }
    }
        
        Cnt ++;
        if(Cnt>=3000)//每间隔3S发送一次数据
        {
            SendDataFlage = 1;//允许发送数据
            Cnt = 0;
            CntCnt++;
    }
        if(CntCnt>=3)//超过三次重新开始
        {
            CntCnt = 0;
            Cnt = 0;
            goto start;
        }
  }
    
    
    /*配置模式*/
  Cnt = 0;
    CntCnt = 0;
    SendDataFlage = 1;
    while(1)
    {
        if(SendDataFlage)
        {
      SendDataFlage = 0;
            printf("AT+CWMODE_DEF=3\r\n");//AP+Station
          P0_0 = 1;
    }
        DelayMs(1);
        if(UsartFlage == 1)
        {
      UsartFlage = 0;
            if(strstr(UsartReceive, "OK"))
            {
                P0_0 = 0;
                DelayMs(500);
                break;
            }
    }
        Cnt ++;
        if(Cnt>=3000)//每间隔3S发送一次数据
        {
            SendDataFlage = 1;//允许发送数据
            Cnt = 0;
            CntCnt++;
    }
        if(CntCnt>=3)//超过三次重新开始
        {
            CntCnt = 0;
            Cnt = 0;
            goto start;
        }
  }
    
    /*多连接*/
    Cnt = 0;
    CntCnt = 0;
    SendDataFlage = 1;
    while(1)
    {
        if(SendDataFlage)
        {
      SendDataFlage = 0;
            printf("AT+CIPMUX=1\r\n");//启动多连接
          P0_0 = 1;
    }
        
        DelayMs(1);
        if(UsartFlage == 1)
        {
      UsartFlage = 0;
            if(strstr(UsartReceive, "OK"))
            {
                P0_0 = 0;
                DelayMs(500);
                break;
            }
    }
        Cnt ++;
        if(Cnt>=3000)//每间隔3S发送一次数据
        {
            SendDataFlage = 1;//允许发送数据
            Cnt = 0;
            CntCnt++;
    }
        if(CntCnt>=3)//超过三次重新开始
        {
            CntCnt = 0;
            Cnt = 0;
            goto start;
        }
  }
    /*创建服务器*/
    Cnt = 0;
    CntCnt = 0;
    SendDataFlage = 1;
    while(1)
    {
        if(SendDataFlage)
        {
            SendDataFlage = 0;
            printf("AT+CIPSERVER=1,1001\r\n");//创建服务器
          P0_0 = 1;
        }
        
        DelayMs(1);
        if(UsartFlage == 1)
        {
      UsartFlage = 0;
            if(strstr(UsartReceive, "OK"))
            {
                P0_0 = 0;
                DelayMs(500);
                break;
            }
    }
        Cnt ++;
        if(Cnt>=3000)//每间隔3S发送一次数据
        {
            SendDataFlage = 1;//允许发送数据
            Cnt = 0;
            CntCnt++;
    }
        if(CntCnt>=3)//超过三次重新开始
        {
            CntCnt = 0;
            Cnt = 0;
            goto start;
        }
  }
    
    /*让小灯闪一闪,算是说明正确执行了把*/
  P0_0 = 0;
  DelayMs(200);
    P0_0 = 1;
    DelayMs(200);
  P0_0 = 0;
  DelayMs(200);
    P0_0 = 1;
    DelayMs(200);
    P0_0 = 0;
    
    
    while(1)
    {
        
        if(TimeCnt>=200)
        {
            TimeCnt = 0;
            DHT11_Receive(); 
        }
        
        
        if(UsartFlage == 1)//返回接收的数据
        {
      UsartFlage = 0;
            
            for(i=0;i<10;i++)//找到开始的数据位置,有的固件数据前头有换行,有的没有
            {
        if(UsartReceive[i]=='+' && UsartReceive[i+1]=='I'&& UsartReceive[i+2]=='P')//判断数据的头
                {
                    ConnectID = UsartReceive[i+5];//得到是几号连接的
                    if(ConnectID>=0x30 && ConnectID<=0x34)//得到的ID号有没有越界
                    {
                         for(i=6;i<15;i++)//找到 : 在哪里,才知道真实数据在哪里
                         {
                                if(UsartReceive[i] == ':')
                                {
                                    if(UsartReceive[i+1]==0xaa  && UsartReceive[i+2]==0x55)
                                    {
                                         switch(UsartReceive[i+3])
                                         {
                                                case 0x01:  SendDataValue[2] = 0x01;
                                                                        SendDataValue[3] = DHT11Data[0];
                                                                        SendDataValue[4] = DHT11Data[2];
                                                          ESPSendData(ConnectID-0x30,5,SendDataValue,1000);
                                                                        break;//发送温湿度数据
                                                case 0x02: if(UsartReceive[i+4] == 0x00)
                                                                     {
                                                                         P0_0 = 0;
                                                                     } 
                                                                     else if(UsartReceive[i+4] == 0xff)
                                                                     {
                                                                         P0_0 = 1;
                                                                     }
                                                                     break;
                                                default:break;                          
                                         }
                                         break;//结束for(i=6;i<15)
                                    }
                                }
                         }
                         
                         break;//结束for(i=0;i<10;i++)
                    }
                }
      }
            
    }
    
  }
}
复制代码

多加了一个指令(在复位后执行)

 

 对了\"  在前面介绍了哈  就是代表"

程序下进去了,现在看一下自己的路由器列表

现在测试通信

 

 

用咱做的TCP客户端测试

 

 

 

既然连接路由器了,就可以实现远程了

先用花生壳,,不知道还能不能用,花了6块钱都买了一年了.....

详细的购买花生壳过程,请参考我的这篇文章

http://www.cnblogs.com/yangfengwu/p/7736296.html#3941866

先映射

 

 

 

 

 

 对了说一下,其实直接连接模块的无线也是可以通信的....

现在测试C#TCP客户端

现在用花生壳连接

 

 

 

看来是解析域名出了问题直接百度

咱试一试

可以啦.....

接着再修改一下单片机的程序,8266连接路由器之后是不是因为自动分配的IP,所以对于咱来说是不是不方便哈,如果IP地址变了,,,还要查看,然后花生壳还要跟着修改,,,

现在咱固定模块的IP

两种方式一种是用模块的指令,另一种是在路由器里面修改

咱先用指令修改

 

我先用串口助手配置一下看看回的内容

 

 

 

现在做单片机程序..其实就是加一个指令

复制代码
/*配置连接路由器后分得的IP地址是多少*/
    Cnt = 0;
    CntCnt = 0;
    SendDataFlage = 1;
    while(1)
    {
        if(SendDataFlage)
        {
            SendDataFlage = 0;
            printf("AT+CIPSTA_DEF=\"192.168.1.106\",\"192.168.1.1\",\"255.255.255.0\"\r\n");
          P0_0 = 1;
        }
        
        DelayMs(1);
        if(UsartFlage == 1)
        {
            UsartFlage = 0;
            if(strstr(UsartReceive, "OK"))
            {
                P0_0 = 0;
                DelayMs(500);
                break;
            }
        }
        
        Cnt ++;
        if(Cnt>=3000)//每间隔3S发送一次数据
        {
            SendDataFlage = 1;//允许发送数据
            Cnt = 0;
            CntCnt++;
        }
        if(CntCnt>=3)//超过三次重新开始
        {
            CntCnt = 0;
            Cnt = 0;
            goto start;
        }
  }
复制代码

 

现在也设置一下花生壳

咱用手机远程连接一下

 

现在用路由器修改

咱先把程序修改的屏蔽掉,

复制代码
    /*配置连接路由器后分得的IP地址是多少*/
//     Cnt = 0;
//     CntCnt = 0;
//     SendDataFlage = 1;
//     while(1)
//     {
//         if(SendDataFlage)
//         {
//             SendDataFlage = 0;
//             printf("AT+CIPSTA_DEF=\"192.168.1.106\",\"192.168.1.1\",\"255.255.255.0\"\r\n");
//           P0_0 = 1;
//         }
//         
//         DelayMs(1);
//         if(UsartFlage == 1)
//         {
//       UsartFlage = 0;
//             if(strstr(UsartReceive, "OK"))
//             {
//                 P0_0 = 0;
//                 DelayMs(500);
//                 break;
//             }
//     }
//         
//         Cnt ++;
//         if(Cnt>=3000)//每间隔3S发送一次数据
//         {
//             SendDataFlage = 1;//允许发送数据
//             Cnt = 0;
//             CntCnt++;
//     }
//         if(CntCnt>=3)//超过三次重新开始
//         {
//             CntCnt = 0;
//             Cnt = 0;
//             goto start;
//         }
//   }
复制代码

 

噢噢噢噢噢噢噢知道原因了

 

可以先恢复出厂设置

 

 

 

 不过模块有问题了.................

 

 哦哦哦哦哦知道原因了....要先设置模式默认AP模式是不可以连接路由器的................以前的程序全部有BUG...................

复制代码
#define MAIN_C_
#include "include.h"

/**
* 介绍:  主函数
* 说明:  每间隔1S发送一次温湿度数据
* 说明:  返回串口接收到的数据,发送方式为中断发送
* 说明:  None
* 说明:  None
* 支持:  QQ946029359 --群 607064330
* 淘宝:  https://shop411638453.taobao.com/
* 作者:  小五
**/

int Cnt = 0;
unsigned char CntCnt = 0;
unsigned char SendDataFlage = 0;

unsigned char ConnectID = 0;
unsigned char i=0;
unsigned char SendDataValue[6]={0xaa,0x55};
int ReadDHT11delay = 0;//设置多少时间读一次DHT11;
void main()
{
    InitUART(115200);
    InitTimer0();
   
    start:
    
    /*下面的都是一样的模子,注释就写一个*/
    Cnt = 0;
    CntCnt = 0;
    SendDataFlage = 1;
    while(1)
    {
        if(SendDataFlage == 1)//发送指令
        {
            SendDataFlage = 0;
      printf("8266RST\r\n");//这个不是什么指令,我先用串口调试助手模拟
          P0_0 = 1;//这个灯作为指示灯,发送个指令就亮,
          ESP_Rst();//复位8266
    }
        
        DelayMs(1);
        if(UsartFlage == 1)//串口接收到数据
        {
      UsartFlage = 0;
            if(strstr(UsartReceive, "ready"))//有没有ready
            {
                P0_0 = 0;//接收到正确的回复就灭
                DelayMs(500);
                break;
            }
    }
        
        Cnt ++;
        if(Cnt>=3000)//每间隔3S发送一次数据
        {
            SendDataFlage = 1;//允许发送数据
            Cnt = 0;
            CntCnt++;
    }
        if(CntCnt>=3)//超过三次重新开始
        {
            CntCnt = 0;
            Cnt = 0;
            goto start;
        }
  }
    
    
    /*配置模式*/
  Cnt = 0;
    CntCnt = 0;
    SendDataFlage = 1;
    while(1)
    {
        if(SendDataFlage)
        {
      SendDataFlage = 0;
            printf("AT+CWMODE_DEF=3\r\n");//AP+Station
          P0_0 = 1;
    }
        DelayMs(1);
        if(UsartFlage == 1)
        {
      UsartFlage = 0;
            if(strstr(UsartReceive, "OK"))
            {
                P0_0 = 0;
                DelayMs(500);
                break;
            }
    }
        Cnt ++;
        if(Cnt>=3000)//每间隔3S发送一次数据
        {
            SendDataFlage = 1;//允许发送数据
            Cnt = 0;
            CntCnt++;
    }
        if(CntCnt>=3)//超过三次重新开始
        {
            CntCnt = 0;
            Cnt = 0;
            goto start;
        }
  }
    
    
//     /*配置连接路由器后分得的IP地址是多少*/
//     Cnt = 0;
//     CntCnt = 0;
//     SendDataFlage = 1;
//     while(1)
//     {
//         if(SendDataFlage)
//         {
//             SendDataFlage = 0;
//             printf("AT+CIPSTA_DEF=\"192.168.1.106\",\"192.168.1.1\",\"255.255.255.0\"\r\n");
//           P0_0 = 1;
//         }
//         
//         DelayMs(1);
//         if(UsartFlage == 1)
//         {
//       UsartFlage = 0;
//             if(strstr(UsartReceive, "OK"))
//             {
//                 P0_0 = 0;
//                 DelayMs(500);
//                 break;
//             }
//     }
//         
//         Cnt ++;
//         if(Cnt>=3000)//每间隔3S发送一次数据
//         {
//             SendDataFlage = 1;//允许发送数据
//             Cnt = 0;
//             CntCnt++;
//     }
//         if(CntCnt>=3)//超过三次重新开始
//         {
//             CntCnt = 0;
//             Cnt = 0;
//             goto start;
//         }
//   }
    
    
    /*配置连接路由器*/
    Cnt = 0;
    CntCnt = 0;
    SendDataFlage = 1;
    while(1)
    {
        if(SendDataFlage)
        {
            SendDataFlage = 0;
            printf("AT+CWJAP_DEF=\"qqqqq\",\"11223344\"\r\n");//连接路由器
          P0_0 = 1;
        }
        
        DelayMs(1);
        if(UsartFlage == 1)
        {
      UsartFlage = 0;
            if(strstr(UsartReceive, "OK"))
            {
                P0_0 = 0;
                DelayMs(500);
                break;
            }
    }
        
        Cnt ++;
        if(Cnt>=3000)//每间隔3S发送一次数据
        {
            SendDataFlage = 1;//允许发送数据
            Cnt = 0;
            CntCnt++;
    }
        if(CntCnt>=3)//超过三次重新开始
        {
            CntCnt = 0;
            Cnt = 0;
            goto start;
        }
  }
    
    
    /*多连接*/
    Cnt = 0;
    CntCnt = 0;
    SendDataFlage = 1;
    while(1)
    {
        if(SendDataFlage)
        {
      SendDataFlage = 0;
            printf("AT+CIPMUX=1\r\n");//启动多连接
          P0_0 = 1;
    }
        
        DelayMs(1);
        if(UsartFlage == 1)
        {
      UsartFlage = 0;
            if(strstr(UsartReceive, "OK"))
            {
                P0_0 = 0;
                DelayMs(500);
                break;
            }
    }
        Cnt ++;
        if(Cnt>=3000)//每间隔3S发送一次数据
        {
            SendDataFlage = 1;//允许发送数据
            Cnt = 0;
            CntCnt++;
    }
        if(CntCnt>=3)//超过三次重新开始
        {
            CntCnt = 0;
            Cnt = 0;
            goto start;
        }
  }
    /*创建服务器*/
    Cnt = 0;
    CntCnt = 0;
    SendDataFlage = 1;
    while(1)
    {
        if(SendDataFlage)
        {
            SendDataFlage = 0;
            printf("AT+CIPSERVER=1,1001\r\n");//创建服务器
          P0_0 = 1;
        }
        
        DelayMs(1);
        if(UsartFlage == 1)
        {
      UsartFlage = 0;
            if(strstr(UsartReceive, "OK"))
            {
                P0_0 = 0;
                DelayMs(500);
                break;
            }
    }
        Cnt ++;
        if(Cnt>=3000)//每间隔3S发送一次数据
        {
            SendDataFlage = 1;//允许发送数据
            Cnt = 0;
            CntCnt++;
    }
        if(CntCnt>=3)//超过三次重新开始
        {
            CntCnt = 0;
            Cnt = 0;
            goto start;
        }
  }
    
    /*让小灯闪一闪,算是说明正确执行了把*/
  P0_0 = 0;
  DelayMs(200);
    P0_0 = 1;
    DelayMs(200);
  P0_0 = 0;
  DelayMs(200);
    P0_0 = 1;
    DelayMs(200);
    P0_0 = 0;
    
    
    while(1)
    {
        
        if(TimeCnt>=200)
        {
            TimeCnt = 0;
            DHT11_Receive(); 
        }
        
        
        if(UsartFlage == 1)//返回接收的数据
        {
      UsartFlage = 0;
            
            for(i=0;i<10;i++)//找到开始的数据位置,有的固件数据前头有换行,有的没有
            {
        if(UsartReceive[i]=='+' && UsartReceive[i+1]=='I'&& UsartReceive[i+2]=='P')//判断数据的头
                {
                    ConnectID = UsartReceive[i+5];//得到是几号连接的
                    if(ConnectID>=0x30 && ConnectID<=0x34)//得到的ID号有没有越界
                    {
                         for(i=6;i<15;i++)//找到 : 在哪里,才知道真实数据在哪里
                         {
                                if(UsartReceive[i] == ':')
                                {
                                    if(UsartReceive[i+1]==0xaa  && UsartReceive[i+2]==0x55)
                                    {
                                         switch(UsartReceive[i+3])
                                         {
                                                case 0x01:  SendDataValue[2] = 0x01;
                                                                        SendDataValue[3] = DHT11Data[0];
                                                                        SendDataValue[4] = DHT11Data[2];
                                                          ESPSendData(ConnectID-0x30,5,SendDataValue,1000);
                                                                        break;//发送温湿度数据
                                                case 0x02: if(UsartReceive[i+4] == 0x00)
                                                                     {
                                                                         P0_0 = 0;
                                                                     } 
                                                                     else if(UsartReceive[i+4] == 0xff)
                                                                     {
                                                                         P0_0 = 1;
                                                                     }
                                                                     break;
                                                default:break;                          
                                         }
                                         break;//结束for(i=6;i<15)
                                    }
                                }
                         }
                         
                         break;//结束for(i=0;i<10;i++)
                    }
                }
      }
            
    }
    
  }
}
复制代码

 

 

 

 

花生壳刚才检测原因关了,现在重新用花生壳映射

 

 电脑端就不测试了,,,

其实这篇就改了一下单片机和C#的程序

今天...以前的源码全有BUG.............唉

补充:

如果路由器不能上网,可以这样

 

 注意点:

路由器桥接手机的WIFI信号后,如果没有注意到路由器分得的IP就登录不进路由器了,因为我们登录不进路由器,所以映射的时候怎么知道WIFI的IP地址,咱们可以设置WiFi固定住IP,但是网关和子网掩码呢可以看电脑的

 

 

 

 然后花生壳映射

 

 另一个手机或者本机连接这个就可以

 

相关实践学习
Github实时数据分析与可视化
基于Github Archive公开数据集,将项目、行为等20+种事件类型数据实时采集至Hologres进行分析,并搭建可视化大屏。
阿里云实时数仓实战 - 项目介绍及架构设计
课程简介 1)学习搭建一个数据仓库的过程,理解数据在整个数仓架构的从采集、存储、计算、输出、展示的整个业务流程。 2)整个数仓体系完全搭建在阿里云架构上,理解并学会运用各个服务组件,了解各个组件之间如何配合联动。 3&nbsp;)前置知识要求 &nbsp; 课程大纲 第一章&nbsp;了解数据仓库概念 初步了解数据仓库是干什么的 第二章&nbsp;按照企业开发的标准去搭建一个数据仓库 数据仓库的需求是什么 架构 怎么选型怎么购买服务器 第三章&nbsp;数据生成模块 用户形成数据的一个准备 按照企业的标准,准备了十一张用户行为表 方便使用 第四章&nbsp;采集模块的搭建 购买阿里云服务器 安装 JDK 安装 Flume 第五章&nbsp;用户行为数据仓库 严格按照企业的标准开发 第六章&nbsp;搭建业务数仓理论基础和对表的分类同步 第七章&nbsp;业务数仓的搭建&nbsp; 业务行为数仓效果图&nbsp;&nbsp;
目录
相关文章
|
2月前
|
缓存 监控 Java
Java Socket编程最佳实践:优化客户端-服务器通信性能
【6月更文挑战第21天】Java Socket编程优化涉及识别性能瓶颈,如网络延迟和CPU计算。使用非阻塞I/O(NIO)和多路复用技术提升并发处理能力,减少线程上下文切换。缓存利用可减少I/O操作,异步I/O(AIO)进一步提高效率。持续监控系统性能是关键。通过实践这些策略,开发者能构建高效稳定的通信系统。
73 1
|
2月前
|
IDE Java 开发工具
从零开始学Java Socket编程:客户端与服务器通信实战
【6月更文挑战第21天】Java Socket编程教程带你从零开始构建简单的客户端-服务器通信。安装JDK后,在命令行分别运行`SimpleServer`和`SimpleClient`。服务器监听端口,接收并回显客户端消息;客户端连接服务器,发送“Hello, Server!”并显示服务器响应。这是网络通信基础,为更复杂的网络应用打下基础。开始你的Socket编程之旅吧!
28 3
|
2月前
|
Java
Java Socket编程与多线程:提升客户端-服务器通信的并发性能
【6月更文挑战第21天】Java网络编程中,Socket结合多线程提升并发性能,服务器对每个客户端连接启动新线程处理,如示例所示,实现每个客户端的独立操作。多线程利用多核处理器能力,避免串行等待,提升响应速度。防止死锁需减少共享资源,统一锁定顺序,使用超时和重试策略。使用synchronized、ReentrantLock等维持数据一致性。多线程带来性能提升的同时,也伴随复杂性和挑战。
50 0
|
2月前
|
安全 Java 网络安全
Java Socket编程教程:构建安全可靠的客户端-服务器通信
【6月更文挑战第21天】构建安全的Java Socket通信涉及SSL/TLS加密、异常处理和重连策略。示例中,`SecureServer`使用SSLServerSocketFactory创建加密连接,而`ReliableClient`展示异常捕获与自动重连。理解安全意识,如防数据截获和中间人攻击,是首要步骤。通过良好的编程实践,确保网络应用在复杂环境中稳定且安全。
54 0
|
3天前
|
API Windows
揭秘网络通信的魔法:Win32多线程技术如何让服务器化身超级英雄,同时与成千上万客户端对话!
【8月更文挑战第16天】在网络编程中,客户/服务器模型让客户端向服务器发送请求并接收响应。Win32 API支持在Windows上构建此类应用。首先要初始化网络环境并通过`socket`函数创建套接字。服务器需绑定地址和端口,使用`bind`和`listen`函数准备接收连接。对每个客户端调用`accept`函数并在新线程中处理。客户端则通过`connect`建立连接,双方可通过`send`和`recv`交换数据。多线程提升服务器处理能力,确保高效响应。
14 6
|
2天前
|
网络协议 安全 Unix
6! 用Python脚本演示TCP 服务器与客户端通信过程!
6! 用Python脚本演示TCP 服务器与客户端通信过程!
|
7天前
|
运维 安全 网络安全
运维笔记:基于阿里云跨地域服务器通信
运维笔记:基于阿里云跨地域服务器通信
34 1
|
4天前
|
物联网 C# Windows
看看如何使用 C# 代码让 MQTT 进行完美通信
看看如何使用 C# 代码让 MQTT 进行完美通信
|
4天前
|
Java
Java模拟文件发送给服务器,服务器将文件转发给其他用户,并保存到服务器本地,其他用户可以接收,并保存到本地磁盘,支持各种文件格式,并解决通信中服务器怎么区分客户端发来的文件类型
Java模拟文件发送给服务器,服务器将文件转发给其他用户,并保存到服务器本地,其他用户可以接收,并保存到本地磁盘,支持各种文件格式,并解决通信中服务器怎么区分客户端发来的文件类型
|
8天前
|
开发框架 .NET API
C#/.NET/.NET Core推荐学习书籍(24年8月更新)
C#/.NET/.NET Core推荐学习书籍(24年8月更新)

热门文章

最新文章