Java网络编程详解

目录

网络编程

1、概述

2、网络通信的要素

3、IP

4、端口

5、通信协议

6、TCP

文件上传

Tomcat

7、UDP

单方发送单方接受

双方发送接收

8、URL

URL测试

URL下载网络资源


网络编程

1、概述

信件:

计算机网络:

计算机网络是指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路和通信设备连接起来,在网络操作系统,网络管理软件及网络通信协议的管理和协调下,实现资源共享和信息传递的计算机系统。

网络编程的目的:

传播交流信息,数据交换,通信

想要达到这个效果需要什么:

  1. 如何准确的定位到一台主机。端口:定位到这个计算机上的某个资源

  2. 找到了这个主机,如何传输数据?

2、网络通信的要素

如何实现网络的通信?

通信双方的地址:

  • ip

  • 端口号

规则:网络通信的协议

TCP/IP参考模型:

形象化记忆:

小结:

  1. 网络编程中有两个主要的问题

    • 如何精准的定位到网络上的一台主机或者多台主机上

    • 找到主机之后如何进行通信

  2. 网络编程中的要素

    • IP和端口号 IP

    • 网络通信协议 UDP,TCP

3、IP

IP地址:InetAddress

  • 唯一定位一台计算机

  • 127.0.0.1:本机的localhost

  • ip地址的分类

    • IPV4/IPV6

      • IPV4127.0.0.1 ,四个字节组成,0~255,有42亿(30亿在北美,亚洲4亿,2011年耗尽)

      • IPV6:128位,8个无符号整数

         2001:0bb2:aaaa:0012:1122:1acd:0000:1213//格式
    • 公网(互联网)-私网(局域网)

      • ABCD类地址

      • 192.168.xx.xx 专门给组织内部使用!

  • 域名:记忆IP问题

    • IP:如www.vip.com

InetAddress类:

 package com.study.lesson01;
 ​
 import java.net.Inet4Address;
 import java.net.InetAddress;
 import java.net.UnknownHostException;
 ​
 public class TestInetAddress {
 ​
     public static void main(String[] args) {
         try {
             //查询本机地址
             InetAddress inetAddress1 = InetAddress.getByName("127.0.0.1");
             System.out.println(inetAddress1);
             InetAddress inetAddress3 = InetAddress.getByName("localhost");
             System.out.println(inetAddress3);
             InetAddress inetAddress4 = InetAddress.getLocalHost();
             System.out.println(inetAddress4);
 ​
             //查询网站IP地址
             InetAddress inetAddress2 = InetAddress.getByName("www.baidu.com");
             System.out.println(inetAddress2);
 ​
             //常用方法
             //System.out.println(inetAddress2.getAddress());
             System.out.println(inetAddress2.getCanonicalHostName());//规范的名字
             System.out.println(inetAddress2.getHostAddress());//ip
             System.out.println(inetAddress2.getHostName());//域名,或者自己电脑的名字
 ​
         } catch (UnknownHostException e) {
             e.printStackTrace();
         }
     }
 }

4、端口

端口表示计算机上一个程序的进程:

  • 不同的进程有不同端口号~用来区分软件

  • 被规定0~65536

  • TCP,UDP:65535*2 单个协议下,端口号不能冲突!

  • 端口分类

    • 公有端口 0~1023

      • HTTP :80

      • HTTPS :443

      • FTP :21

      • Telent :23

    • 程序注册端口:1024~49151,分配用户或者程序

      • Tomcat:8080

      • MySQL :3306

      • Oracle:1521

    • 动态、私有:49152~65535

       netstat -ano #查看所有的端口
       netstat -ano|findstr "5900" #查看指定窗口
       tasklist|findstr "8696" #查看指定端口的进程
       Ctrl+shift+ESC #任务管理器快捷键
    •  package com.study.lesson01;
       ​
       import java.net.InetSocketAddress;
       ​
       public class TestInetSocketAddress {
       ​
           public static void main(String[] args) {
               InetSocketAddress socketAddress = new InetSocketAddress("127.0.0.1", 8080);
               InetSocketAddress socketAddress2 = new InetSocketAddress("localhost", 8080);
               System.out.println(socketAddress);
               System.out.println(socketAddress2);
       ​
               System.out.println(socketAddress.getAddress());
               System.out.println(socketAddress.getHostName());//地址
               System.out.println(socketAddress.getPort());//端口
       ​
           }
       }

5、通信协议

协议:约定,就好比我们现在说的普通话~

网络通信协议:速率,传输码率,代码结构,传输控制...

TCP/IP协议簇:实际上是一组协议

重要:

  • TCP:用户传输协议

  • UDP:用户数据报协议

出名的协议:

  • TCP:用户传输协议

  • IP:网络互连协议

TCP、UDP 对比:

TCP:打电话

  • 连接稳定

  • 三次握手 四次挥手

     最少需要三次,保证稳定连接
     A:你瞅啥?
     B:瞅你咋的?
     A:干一场!
     ​
     A:我要走了~
     B:你真的要走了吗?
     B:你真的真的要走了吗?
     A:我真的要走了~

    三次握手、四次挥手

  • 客户端、服务端

  • 传输完成、释放连接

  • 效率低

UDP:发短信

  • 不连接、不稳定

  • 客户端、服务端:没有明确的界限

  • 不管是否准备好,都可以发送

  • DDOS:洪水攻击!(饱和攻击)

6、TCP

客户端

  1. 连接服务器Socket-->socket = new Socket(serverIp,port);

  2. 发送消息-->os = socket.getOutputStream(); os.write("欢迎来到网络编程".getBytes());

 package com.study.lesson02;
 ​
 import java.io.IOException;
 import java.io.OutputStream;
 import java.net.InetAddress;
 import java.net.Socket;
 import java.net.UnknownHostException;
 import java.nio.charset.StandardCharsets;
 ​
 //客户端
 public class TcpClientDemo01 {
     public static void main(String[] args) {
 ​
         Socket socket = null;
         OutputStream os = null;
         try {
             //1.要知道服务器的地址,端口号
             InetAddress serverIp = InetAddress.getByName("127.0.0.1");
             int port = 9999;
             //2.创建一个socket连接
             socket = new Socket(serverIp,port);
             //3.发送消息IO流
             os = socket.getOutputStream();
             os.write("欢迎来到网络编程".getBytes());
 ​
         } catch (Exception e) {
             e.printStackTrace();
 ​
         }finally {
             if(os!=null){
                 try {
                     os.close();
                 } catch (IOException e) {
                     e.printStackTrace();
                 }
             }
             if(socket!=null){
                 try {
                     socket.close();
                 } catch (IOException e) {
                     e.printStackTrace();
                 }
             }
         }
     }
 }

服务器

  1. 建立服务的端口ServiceSocket-->serverSocket = new ServerSocket(9999);

  2. 等待用户的连接 accept-->socket = serverSocket.accept();

  3. 接受用户的消息-->is = socket.getInputStream();

  4. 管道流存储输出-->baos = new ByteArrayOutputStream(); byte[] buffer = new byte[1024]; int len; while((len=is.read(buffer))!=-1){ baos.write(buffer,0,len); } System.out.println(baos.toString());

 package com.study.lesson02;
 ​
 import java.io.ByteArrayOutputStream;
 import java.io.IOException;
 import java.io.InputStream;
 import java.net.ServerSocket;
 import java.net.Socket;
 ​
 //服务端
 public class TcpServeDemo01 {
     public static void main(String[] args) {
 ​
         ServerSocket serverSocket = null;
         Socket socket =null;
         InputStream is = null;
         ByteArrayOutputStream baos = null;
 ​
         try {
             //1.我得有一个地址
             serverSocket = new ServerSocket(9999);
 ​
             while (true){
                 //2.等待客户端连接过来
                 socket = serverSocket.accept();
                 //3。读取客户端消息
                 is = socket.getInputStream();
 ​
                 //管道流
                 baos = new ByteArrayOutputStream();
                 byte[] buffer = new byte[1024];
                 int len;
                 while((len=is.read(buffer))!=-1){
                     baos.write(buffer,0,len);
                 }
                 System.out.println(baos.toString());
             }
 ​
             /*
             byte[] buffer = new byte[1024];
             int len;
             while((len=is.read(buffer))!=-1){
                 String msg = new String(buffer,0,len);
                 System.out.println(msg);
             }
             * */
 ​
 ​
         } catch (IOException e) {
             e.printStackTrace();
         }finally {
             //关闭资源
             if(baos!=null){
                 try {
                     baos.close();
                 } catch (IOException e) {
                     e.printStackTrace();
                 }
             }
             if(is!=null){
                 try {
                     is.close();
                 } catch (IOException e) {
                     e.printStackTrace();
                 }
             }
             if(socket!=null){
                 try {
                     socket.close();
                 } catch (IOException e) {
                     e.printStackTrace();
                 }
             }
             if(serverSocket!=null){
                 try {
                     serverSocket.close();
                 } catch (IOException e) {
                     e.printStackTrace();
                 }
             }
 ​
         }
     }
 }

文件上传

服务器

 package com.study.lesson02;
 ​
 import java.io.*;
 import java.net.ServerSocket;
 import java.net.Socket;
 ​
 public class TcpServeDemo02 {
     public static void main(String[] args) throws Exception {
         //1.创建服务
         ServerSocket serverSocket = new ServerSocket(9000);
         //2.监听客户端的连接
         Socket socket = serverSocket.accept();//阻塞式监听,会一直等待客户端的连接
         //3.获取输入流
         InputStream is = socket.getInputStream();
 ​
         //4.文件输出
         FileOutputStream fos = new FileOutputStream(new File("receive.jpg"));
         byte[] buffer = new byte[1024];
         int len;
         while((len=is.read(buffer))!=-1){
             fos.write(buffer,0,len);
         }
         //通知客户端我接受完毕了
         OutputStream os = socket.getOutputStream();
         os.write("我接收完毕了~可以断开~".getBytes());
 ​
         //关闭资源
         fos.close();
         is.close();
         socket.close();
         serverSocket.close();
     }
 }

客户端

 package com.study.lesson02;
 ​
 import java.io.*;
 import java.net.InetAddress;
 import java.net.Socket;
 import java.net.UnknownHostException;
 ​
 public class TcpClientDemo02 {
     public static void main(String[] args) throws Exception {
 ​
         //1.创建一个socket连接
         Socket socket = new Socket(InetAddress.getByName("127.0.0.1"), 9000);
         //2.创建一个输出流
         OutputStream os = socket.getOutputStream();
 ​
         //3.读取文件
         FileInputStream fis = new FileInputStream(new File("Zombatar_1.jpg"));
         //4.写出文件
         byte[] buffer = new byte[1024];
         int len;
         while((len=fis.read(buffer))!=-1){
             os.write(buffer,0,len);
         }
         //通知服务器,我已经结束了
         socket.shutdownOutput();//我已经传输完毕~
 ​
         //确定服务器接收完毕,才能够断开连接
         InputStream inputStream = socket.getInputStream();
         //String byte[]
         ByteArrayOutputStream baos = new ByteArrayOutputStream();
 ​
         byte[] buffer2 = new byte[1025];
         int len2;
         while((len2=inputStream.read(buffer2))!=-1){
             baos.write(buffer2,0,len2);
         }
         System.out.println(baos.toString());
 ​
         //5.关闭资源
         fis.close();
         os.close();
         socket.close();
     }
 }

Tomcat

服务端

  • 自定义-->S

  • Tomcat服务器-->S

客户端

  • 自定义-->C

  • 浏览器-->B

7、UDP

发短信:不用连接。需要知道对方的地址!


单方发送单方接受

发送消息

 package com.study.lesson03;
 ​
 import java.net.DatagramPacket;
 import java.net.DatagramSocket;
 import java.net.InetAddress;
 import java.net.SocketException;
 ​
 public class UdpClientDemo01 {
     public static void main(String[] args) throws Exception {
         //1.建立一个Socket
         DatagramSocket socket = new DatagramSocket();
 ​
         //2.建个包
         String msg = "你好啊!服务器!";
         InetAddress localhost = InetAddress.getByName("localhost");
         int port = 9090;
 ​
         //数据,数据的长度起始,,发送给谁
         DatagramPacket packet = new DatagramPacket(msg.getBytes(), 0, msg.getBytes().length, localhost, port);
 ​
         //3.发送包
         socket.send(packet);
 ​
         //4.关闭流
         socket.close();
 ​
     }
 }

接收消息、

 package com.study.lesson03;
 ​
 import java.net.DatagramPacket;
 import java.net.DatagramSocket;
 import java.net.SocketException;
 ​
 public class UdpServeDemo01 {
     public static void main(String[] args) throws Exception {
         //开放端口
         DatagramSocket socket = new DatagramSocket(9090);
         //接收数据包
         byte[] buffer = new byte[1024];
         DatagramPacket packet = new DatagramPacket(buffer, 0, buffer.length);
 ​
         socket.receive(packet);//阻塞接受
         System.out.println(packet.getAddress().getHostAddress());
         System.out.println(new String(packet.getData(),0,packet.getLength()));
 ​
 ​
         //关闭连接
         socket.close();
 ​
     }
 }

循环发送

 package com.study.ChatDemo01;
 ​
 import java.io.BufferedReader;
 import java.io.InputStreamReader;
 import java.net.DatagramPacket;
 import java.net.DatagramSocket;
 import java.net.InetSocketAddress;
 import java.net.SocketException;
 ​
 public class UdpSenderDemo01 {
     public static void main(String[] args) throws Exception {
 ​
         DatagramSocket socket = new DatagramSocket(8888);
 ​
         //准备数据,控制台读取System.in
         BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
 ​
         while(true){
             String data = reader.readLine();
             byte[] datas = data.getBytes();
             DatagramPacket packet = new DatagramPacket(datas, 0, datas.length, new InetSocketAddress("localhost", 6666));
 ​
             socket.send(packet);
             if (data.equals("bye")){
                 break;
             }
         }
         socket.close();
     }
 }

循环接收

 package com.study.ChatDemo01;
 ​
 import java.net.DatagramPacket;
 import java.net.DatagramSocket;
 import java.net.SocketException;
 import java.nio.charset.StandardCharsets;
 ​
 public class UdpReceiveDemo01 {
     public static void main(String[] args) throws Exception {
         DatagramSocket socket = new DatagramSocket(6666);
 ​
         while(true){
 ​
             //准备接受的包裹
             byte[] container = new byte[1024];
             DatagramPacket packet = new DatagramPacket(container, 0, container.length);
             socket.receive(packet);//阻塞式接受包裹
 ​
             //断开连接 bye
             byte[] data = packet.getData();
             String receiveData = new String(data,0, data.length);
 ​
             System.out.println(receiveData);
 ​
             if (receiveData.equals("bye")){
                 break;
             }
         }
         socket.close();
     }
 }
双方发送接收

在线咨询:两个人都可以是发送方,也可以是接收方!

发送端:

 package com.study.ChatDemo01;
 ​
 import java.io.BufferedReader;
 import java.io.IOException;
 import java.io.InputStreamReader;
 import java.net.DatagramPacket;
 import java.net.DatagramSocket;
 import java.net.InetSocketAddress;
 ​
 public class TalkSend implements Runnable{
     DatagramSocket socket = null;
     BufferedReader reader = null;
 ​
     private int fromPort;
     private String toIp;
     private int toPort;
 ​
     public TalkSend(int fromPort, String toIp, int toPort) {
         this.fromPort = fromPort;
         this.toIp = toIp;
         this.toPort = toPort;
 ​
         try {
             socket = new DatagramSocket(fromPort);
             reader = new BufferedReader(new InputStreamReader(System.in));
         } catch (Exception e) {
             e.printStackTrace();
         }
     }
 ​
     @Override
     public void run() {
 ​
         while(true){
             try {
                 String data = reader.readLine();
                 byte[] datas = data.getBytes();
                 DatagramPacket packet = new DatagramPacket(datas, 0, datas.length, new InetSocketAddress(this.toIp, this.toPort));
 ​
                 socket.send(packet);
                 if (data.equals("bye")){
                     break;
                 }
             } catch (IOException e) {
                 e.printStackTrace();
             }
         }
 ​
 ​
         socket.close();
     }
 }

接收端

 package com.study.ChatDemo01;
 ​
 import java.io.IOException;
 import java.net.DatagramPacket;
 import java.net.DatagramSocket;
 import java.net.SocketException;
 ​
 public class TalkReceive implements Runnable{
     DatagramSocket socket = null;
 ​
     private int port;
     private String msgFrom;
 ​
     public TalkReceive(int port,String msgFrom) {
         this.port = port;
         this.msgFrom = msgFrom;
         try {
             socket = new DatagramSocket(port);
         } catch (SocketException e) {
             e.printStackTrace();
         }
     }
 ​
     @Override
     public void run() {
         while(true){
 ​
             try {
                 //准备接受的包裹
                 byte[] container = new byte[1024];
                 DatagramPacket packet = new DatagramPacket(container, 0, container.length);
                 socket.receive(packet);//阻塞式接受包裹
 ​
                 //断开连接 bye
                 byte[] data = packet.getData();
                 String receiveData = new String(data,0, data.length);
 ​
                 System.out.println(msgFrom +":"+receiveData);
 ​
                 if (receiveData.equals("bye")){
                     break;
                 }
             } catch (IOException e) {
                 e.printStackTrace();
             }
         }
         socket.close();
     }
 }
 ​

学生端:

 package com.study.ChatDemo01;
 ​
 public class TalkStudent {
     public static void main(String[] args) {
         //开启两个线程
         new Thread(new TalkSend(7777,"localhost",9999)).start();
         new Thread(new TalkReceive(8888,"老师")).start();
     }
 }

老师端:

 package com.study.ChatDemo01;
 ​
 public class TalkTeacher {
     public static void main(String[] args) {
         new Thread(new TalkSend(5555,"localhost",8888)).start();
         new Thread(new TalkReceive(9999,"学生")).start();
     }
 }

8、URL

统一资源定位符:定位互联网上某一个资源~


 协议://ip地址:端口/项目名/资源
URL测试
 package com.study.lesson04;
 ​
 import java.net.MalformedURLException;
 import java.net.URL;
 ​
 public class URLDemo01 {
     public static void main(String[] args) throws MalformedURLException {
         URL url = new URL("http://localhost:8080/helloworld/index.jsp?username=kuangshen&password=123");
         System.out.println(url.getProtocol());//协议
         System.out.println(url.getHost());//主机ip
         System.out.println(url.getPort());//端口
         System.out.println(url.getPath());//文件
         System.out.println(url.getFile());//全路径
         System.out.println(url.getQuery());//参数
     }
 }
URL下载网络资源
 package com.study.lesson04;
 ​
 import java.io.FileOutputStream;
 import java.io.InputStream;
 import java.net.HttpURLConnection;
 import java.net.MalformedURLException;
 import java.net.URL;
 import java.net.URLConnection;
 ​
 public class URLDown {
     public static void main(String[] args) throws Exception {
         //1.下载地址
         URL url = new URL("https://m701.music.126.net/20240310184733/9ca3dc22ed39dd04044ede9b4ce9f672/jdyyaac/obj/w5rDlsOJwrLDjj7CmsOj/32103516877/3532/074b/bdea/4f512dfb86fec567b51062cc17695e22.m4a");
 ​
         //2.连接到这个资源 HTTP
         HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
 ​
         InputStream inputStream = urlConnection.getInputStream();
 ​
         FileOutputStream fos = new FileOutputStream("a.m4a");
 ​
         byte[] buffer = new byte[1024];
         int len;
         while((len=inputStream.read(buffer))!=-1){
             fos.write(buffer,0,len);//写出这个数据
         }
         fos.close();
         inputStream.close();
         urlConnection.disconnect();
     }
 }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/448713.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

微服务配置中心

什么是配置中心 配置中心是一种用于管理应用程序或系统配置信息的中央服务。它允许开发人员在多个环境(如开发、测试、生产)之间共享配置,并且可以在不停止应用程序的情况下动态更新配置。 配置中心是统一管理各种应用配置的工具。它能够集中…

导出谷歌浏览器收藏的网页,并查看网页保存的登录密码

导出谷歌浏览器(Chrome)收藏的网页(书签): 打开谷歌浏览器。在浏览器右上角找到并点击三个垂直排列的小点(或称汉堡菜单)以打开主菜单。在下拉菜单中选择“书签” > “书签管理器”。在书签…

R语言扩展包与MaxEnt模型的集成:实现高效的物种分布模拟

在生态学研究中,物种分布模拟是一项至关重要的任务。它有助于我们理解物种与环境之间的复杂关系,预测物种在气候变化或人类活动影响下的潜在分布变化。近年来,随着计算机技术的不断发展,基于机器学习的物种分布模拟方法逐渐成为研…

Day35:安全开发-JavaEE应用原生反序列化重写方法链条分析触发类类加载

目录 Java-原生使用-序列化&反序列化 Java-安全问题-重写方法&触发方法 Java-安全问题-可控其他类重写方法 思维导图 Java知识点: 功能:数据库操作,文件操作,序列化数据,身份验证,框架开发&…

Oracle 层级查询(Hierarchical Queries)

如果一张表中的数据存在分级(即数据间存在父子关系),利用普通SQL语句显示数据间的层级关系非常复杂,可能需要多次连接才能完整的展示出完成的层级关系,更困难的是你可能不知道数据到底有多少层。而利用Oracle的层级查询…

java Day7 正则表达式|异常

文章目录 1、正则表达式1.1 常用1.2 字符串匹配,提取,分割 2、异常2.1 运行时异常2.2 编译时异常2.3 自定义异常2.3.1 自定义编译时异常2.3.2 自定义运行时异常 1、正则表达式 就是由一些特定的字符组成,完成一个特定的规则 可以用来校验数据…

一体机电脑辐射超标整改

电脑一体机是目前台式机和笔记本电脑之间的一个新型的市场产物,它将主机部分、显示器部分整合到一起的新形态电脑,该产品的创新在于内部元件的高度集成。随着无线技术的发展,电脑一体机的键盘、鼠标与显示器可实现无线链接,机器只…

NLP:文本相似度计算

前面我们已经实现了把长段的句子,利用HanLP拆分成足够精炼的分词,后面我们要实现“联想”功能,我这里初步只能想到通过文本相似度计算来实现。下面介绍一下文本相似度计算 (当然HanLP也有文本相似度计算的方法,这里我…

手把手教使用静默 搭建Oracle 19c 一主一备ADG集群

一、环境搭建 主机IPora19192.168.134.239ora19std192.168.134.240 1.配置yum源 1.配置网络yum源 1.删除redhat7.0系统自带的yum软件包; rpm -qa|grep yum >oldyum.pkg 备份原信息rpm -qa|grep yum|xargs rpm -e --nodeps 不检查依赖,直接删除…

23.网络游戏逆向分析与漏洞攻防-网络通信数据包分析工具-实现配置工具数据结构

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 如果看不懂、不知道现在做的什么,那就跟着做完看效果 内容参考于:易道云信息技术研究院VIP课 上一个内容:22.加载配置文件…

springboot同时接收json数据和 MultipartFile

首先测试接口发送方式。。。。。注意发送结构&#xff01; 后端接收RequestPart SaCheckPermission("system:records:add")Log(title "【用药纪录】", businessType BusinessType.INSERT)RepeatSubmit()PostMapping()public R<Void> add( RequestP…

Linux最小系统安装无法查看IP地址

1&#xff0c;出现原因 服务器重启完成之后&#xff0c;我们可以通过linux的指令 ip addr 来查询Linux系统的IP地址&#xff0c;具体信息如下: 从图中我们可以看到&#xff0c;并没有获取到linux系统的IP地址&#xff0c;这是为什么呢&#xff1f;这是由于启动服务器时未加载网…

Redis核心数据结构之字典(一)

字典 概述 字典又称为符号表(symbol table)、关联数组(associative array)或映射(map)&#xff0c;是一种保存键值对(key-value pair)的抽象数据结构&#xff0c;在字典中&#xff0c;一个键(key)可以和一个值(value)进行关联(或者说将键映射为值)&#xff0c;这些关联的键和…

网络攻防中nginx安全配置,让木马上传后不能执行、让木马执行后看不到非网站目录文件、命令执行后权限不能过高

网络攻防中nginx安全配置,让木马上传后不能执行、让木马执行后看不到非网站目录文件、命令执行后权限不能过高。 0x01 Nginx介绍 nginx本身不能处理PHP,它只是个web服务器,当接收到请求后,如果是php请求,则发给php解释器处理,并把结果返回给客户端。nginx一般是把请求发…

宏任务与微任务:JavaScript异步编程的秘密

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

伊芙丽签约实在智能,实在Agent数字员工助力品牌效能飙升

近日&#xff0c;国内知名时尚女装品牌伊芙丽与实在智能达成合作&#xff0c;引入业内领先的平台级自动化产品实在Agent数字员工——取数宝&#xff0c;自动获取天猫、淘宝、抖音等线上平台营销数据&#xff0c;开启全域化营销的“提效之旅”。 实在Agent智能体 伊芙丽集团成立…

大数据 - Spark系列《十三》- spark集群部署模式

Spark系列文章&#xff1a; 大数据 - Spark系列《一》- 从Hadoop到Spark&#xff1a;大数据计算引擎的演进-CSDN博客 大数据 - Spark系列《二》- 关于Spark在Idea中的一些常用配置-CSDN博客 大数据 - Spark系列《三》- 加载各种数据源创建RDD-CSDN博客 大数据 - Spark系列《…

刘敏:楼氏动铁和麦克风助力听力健康技术发展 | 演讲嘉宾公布

一、助辅听器材Ⅱ专题论坛 助辅听器材Ⅱ专题论坛将于3月28日同期举办&#xff01; 听力贯穿人的一生&#xff0c;听觉在生命的各个阶段都是至关重要的功能&#xff0c;听力问题一旦出现&#xff0c;会严重影响生活质量。助辅听器材能有效提高生活品质。在这里&#xff0c;我们将…

【动态规划】代码随想录算法训练营第五十一天 | 309.最佳买卖股票时机含冷冻期, 714.买卖股票的最佳时机含手续费,总结(待补充)

309.最佳买卖股票时机含冷冻期 1、题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 2、文章讲解&#xff1a;代码随想录 3、题目&#xff1a; 给定一个整数数组&#xff0c;其中第 i 个元素代表了第 i 天的股票价格 。 设计一个算法计算出最大利润。在满足…

力扣题解30. 串联所有单词的子串

Python&Java双语解决力扣必刷算法&#xff0c;题号30. 串联所有单词的子串 目录 题目描述 解题思路 完整代码 Python Java 题目描述 给定一个字符串 s 和一个字符串数组 words。 words 中所有字符串 长度相同。 s 中的 串联子串 是指一个包含 words 中所有字符串以…