2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
网络通信协议:通信协议是对计算机必须遵守的规则,只有遵守这些规则,计算机之间才能进行通信。
java.net 包中提供了两种常见的网络协议的支持
Kolmisuuntainen kättely TCP:ssä: TCP-protokollassa tiedon lähetyksen valmisteluvaiheessa asiakkaan ja palvelimen välillä on kolme vuorovaikutusta yhteyden luotettavuuden varmistamiseksi.
协议 + IP地址 + 端口号
TCP通信能实现两台计算机之间的数据交互,通信的两端,要严格区分为客户端(Client)与服务端(Server)。
Javassa on kaksi luokkaa TCP-viestintäohjelmien toteuttamiseen:
Socket 类:该类实现客户端套接字,套接字指的是两台设备之间通讯的端点。
Rakennusmenetelmä:
public Socket(String host, int port)
:Luo socket-objektin ja yhdistää sen määritetyn isännän määritettyyn porttinumeroon. Jos määritetty isäntä on tyhjä, se vastaa määritettyä osoitetta, joka on silmukkaosoite (Palautusosoite (127.xxx) on paikallissilmukkaosoite (Loopback Address))。
Jäsenmenetelmät:
public InputStream getInputStream()
: Palauttaa tämän liittimen tulovirran.public OutputStream getOutputStream()
: Palauttaa tämän liittimen lähtövirran.public void close()
: Sulje tämä liitäntä.public void shutdownOutput()
: Poistaa tämän liittimen lähtövirran käytöstä.ServerSocket 类:这个类实现了服务器套接字,该对象等待通过网络的请求。
Rakennusmenetelmä:
public ServerSocket(int port): Tämän rakentajan avulla voit sitoa sen osoittimeen luotaessa ServerSocket-objektia.
Tietyssä portin numerossa parametriportti on portin numero.
Jäsenmenetelmät:
public Socket accept()
: Kuuntele ja hyväksy yhteydet ja palauta uusi Socket-objekti viestintää varten asiakkaan kanssa.tätä menetelmää
Estää, kunnes yhteys on muodostettu.
TCP-viestintäanalyysi:
Esimerkki koodista:
import java.io.IOException;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;
public class ServerTCP {
public static void main(String[] args) throws IOException {
System.out.println("服务端启动 , 等待连接 .... ");
// 1.创建 ServerSocket对象,绑定端口,开始等待连接
ServerSocket ss = new ServerSocket(6666);
// 2.接收连接 accept 方法, 返回 socket 对象.
Socket server = ss.accept();
// 3.通过socket 获取输入流
InputStream is = server.getInputStream();
// 4.一次性读取数据
// 4.1 创建字节数组
byte[] b = new byte[1024];
// 4.2 据读取到字节数组中.
int len = is.read(b);
// 4.3 解析数组,打印字符串信息
String msg = new String(b, 0, len);
System.out.println(msg);
//5.关闭资源.
is.close();
server.close();
}
}
Palvelin määrittää portin numeron, hankkii Socket-objektin accept()-menetelmällä, hakee syöttövirran asiakasobjektin kautta ja lukee lopuksi tiedot ja odottaa asiakkaan lähettämää viestiä.
import java.net.Socket;
public class ClientTCP {
public static void main(String[] args) throws Exception {
System.out.println("客户端 发送数据");
// 1.创建 Socket ( ip , port ) , 确定连接到哪里.
Socket client = new Socket("localhost", 6666);
// 2.获取流对象 . 输出流
OutputStream os = client.getOutputStream();
// 3.写出数据.
os.write("你好么? tcp ,我来了".getBytes());
// 4. 关闭资源 .
os.close();
client.close();
}
}
Kun asiakas on luotu, määritä yhteyden IP-osoite ja portin numero helpottaaksesi yhteyden muodostamista palvelimeen, saadaksesi lähtövirta ja lähtötiedot asiakkaan Socket-objektin kautta.
数据准备:
Aseta tiedosto nimeltä test.jpg D-aseman alle ja luo testikansio
Esimerkki koodista:
import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;
public class FileUpload_Server {
public static void main(String[] args) throws IOException {
System.out.println("服务器 启动..... ");
// 1. 创建服务端ServerSocket
ServerSocket serverSocket = new ServerSocket(6666);
// 2. 循环接收,建立连接
while (true) {
Socket accept = serverSocket.accept();
/* 3. socket对象交给子线程处理,进行读写操作Runnable接口中,只有一个run方法,使用lambda表达式简化格式 */
new Thread(() -> {
try ( //3.1 获取输入流对象
BufferedInputStream bis = new BufferedInputStream(accept.getInputStream());
//3.2 创建输出流对象, 保存到本地 .
FileOutputStream fis = new FileOutputStream("D:/test/" + System.currentTimeMillis() + ".jpg");
BufferedOutputStream bos = new BufferedOutputStream(fis)) {
// 3.3 读写数据
byte[] b = new byte[1024 * 8];
int len;
while ((len = bis.read(b)) != -1) {
bos.write(b, 0, len);
}
// 4.=======信息回写===========================
System.out.println("back ........");
OutputStream out = accept.getOutputStream();
out.write("上传成功".getBytes());
out.close();
//5. 关闭 资源
bos.close();
bis.close();
accept.close();
System.out.println("文件上传已保存");
} catch (IOException e) {
e.printStackTrace();
}
}).start();
}
}
}
Täällä luomme ensin palvelinobjektin, käytämme while(true)-toimintoa varmistaaksemme jatkuvan yhteyden palvelimeen ja aloitamme sitten säikeen varmistaaksemme, että kun käyttäjä lataa suuren tiedoston, se ei vaikuta muiden tiedostoja lataavien käyttäjien tehokkuuteen. Käytä järjestelmän millisekuntia + '.jpg' asettaaksesi tiedoston nimen varmistaaksesi, että tiedoston nimi ei korvaudu saman tiedostonimen vuoksi latauksen aikana.
import java.io.*;
import java.net.Socket;
public class FileUpload_Client {
public static void main(String[] args) throws IOException {
// 1.创建流对象
// 1.1 创建输入流,读取本地文件
BufferedInputStream bis = new BufferedInputStream(new FileInputStream("D:\test.jpg"));
// 1.2 创建输出流,写到服务端
Socket socket = new Socket("localhost", 6666);
BufferedOutputStream bos = new BufferedOutputStream(socket.getOutputStream());
//2.写出数据.
byte[] b = new byte[1024 * 8 ];
int len ;
while (( len = bis.read(b))!=-1) {
bos.write(b, 0, len);
}
// 关闭输出流,通知服务端,写出数据完毕
socket.shutdownOutput();
System.out.println("文件发送完毕");
// 3. =====解析回写============
InputStream in = socket.getInputStream();
byte[] back = new byte[20];
in.read(back);
System.out.println(new String(back));
in.close();
// ============================
// 4.释放资源
socket.close();
bis.close();
}
}
Tästä näemme, että palvelimemme onnistui tallentamaan käyttäjän lähettämän tiedoston kiintolevylle.
Java-ystävät ovat tervetulleita tutustumaan artikkeliin. Kirjoittaja päivittää sitä edelleen ja odottaa huomiotasi ja kokoelmaasi. . .