网络编程详解-TCP

  一,TCP协议的特点 
              面向连接的协议(有发送端就一定要有接收端)

     通过三次连接握手建立连接

  通过四次握手断开连接

  基于IO流传输数据

  传输数据大小没有限制

  速度慢但可靠

  二,TCP协议相关的两个类
       Socket(一个socket对象表示一个客户端对象)
             常用构造方法介绍

   Socket(String host, int  port)

        host参数为服务器的ip地址字符串

       port参数为服务器的端口号

  大家记忆的时候可以使用这一种记忆方式 :记住socket是个客户端对象就可以了,参数就想socket对象既然是客户端对象他就需要连接服务器,那么他需要什么呢,连接服务器肯定需要服务端的IP和地址才能够连接。

  三,常用方法介绍

  OutputStream    getOutputStream() 获取字节输出流(该字节输出可以向服务端输出数据,只能获取一次,调用该方法多少次,获取到的还是同一个对象)
  InputStream   getInputStream() 获取字节输入流(该字节输入流可以读取服务器端方式过来的数据,只能获取一次,调用该方法多少次,获取到的还是同一个对象)
  void   shutdownOutputStream() 关闭输出流(在socket里面作用就是告诉服务器端,数据已经传输完成,调用该方法以后获取到的输出流就不能使用了)
  void  close() 关闭资源
  int  getPort() 获取服务器端的端口
  InetAddress getInetAddress()

  四,获取服务器端的IP地址对象

   ServerSocket(一个该类对象就代表一个服务端对象)
                      常用构造方法介绍

      ServerSocket(int port)

      port参数为服务端的端口号

   常用方法介绍

       Socket  accept() 等待客户端连接,获取一个客户端对象
       InteAddress    getInteAdderss() 获取连接的客户端的ip对象
  

  五,网络编程(TCP-服务端响应客户端)代码

         1.客户端代码

 import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.net.Socket;
import java.util.Scanner; public class UserClint_3 {
static Scanner sc = new Scanner(System.in);
public static void main(String[] args) throws IOException {
//1.创建客户端套接字
Socket s = new Socket("localhost", 152);
//2.创建客户端输出流
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(s.getOutputStream()));
//3.用户输入用户和密码,并写入输出流
System.out.println("请输入用户名:");
String user = sc.nextLine();
System.out.println("请输入用户密码:");
String password = sc.nextLine();
bw.write(user);
bw.flush();
bw.newLine();
bw.write(password);
bw.flush(); //4.通知服务端客户端用户信息写入完毕
s.shutdownOutput(); //5.创建输入流来接受服务端响应的信息
BufferedReader br= new BufferedReader(new InputStreamReader(s.getInputStream()));
String info = br.readLine();
//6.输出响应信息
System.out.println(info);
//7.关闭套接字
s.close();
}
}

  2.将客户登录信息放在在User.Properties文件中,持久化信息库 

 username=lsx
pwd=123
username=wn
pwd=123

  3.服务器端代码

 import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.HashMap;
import java.util.Map;
import java.util.Properties; public class UserServer_3 {
public static Map<String, String> User() throws IOException{
//将用户信息存放在User.properties文件中
//创建properties类获取用户信息
Properties p = new Properties();
//通过load()方法读取用户信息
p.load(new FileInputStream("User.Properties"));
//通过getProperty()方法获取用户信息的键,得到用户信息的值
String user = p.getProperty("username");
String pwd = p.getProperty("pwd"); //创建map集合,将用户信息的键以及对应的值放入集合中
Map<String, String> map = new HashMap<>();
map.put("username", user);
map.put("pwd", pwd);
return map;
}
public static void main(String[] args) throws IOException {
//1.创建服务器端套接字
ServerSocket ss = new ServerSocket(152);
//2.监听客户端套接字
Socket s = ss.accept();
//3.创建输入流用来读取客户端发送的用户信息
BufferedReader br = new BufferedReader(new InputStreamReader(s.getInputStream()));
//4.读取客户端发送的用户信息
String username = br.readLine();
String password = br.readLine(); //5.调用map集合,拿到map集合里面的用户信息和客户端发送的信息进行比对
Map<String, String> map = User();
//6.创建输出流用来响应客户端
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(s.getOutputStream()));
//7.进行信息比对
if(map.get("username").equals(username)&&map.get("pwd").equals(password)){
//8.写入响应信息
bw.write("恭喜您,登录成功!");
bw.flush();
}else{
bw.write("登录失败,用户或用户密码错误!");
bw.flush();
}
//9.关闭客户端套接字
s.close();
}
}

java容器和数据结构详解:链接:https://pan.baidu.com/s/1jR9neu9JuTy4UpBN1p83bQ  提取码:lutu 

java网络编程(TCP详解)的更多相关文章

  1. java网络编程(UDP详解)

    UDP详解 一,TCP/IP协议栈中,TCP协议和UDP协议的联系和区别? 联系: TCP和UDP是TCP/IP协议栈中传输层的两个协议,它们使用网络层功能把数据包发送到目的地,从而为应用层提供网络服 ...

  2. java并发编程 | 锁详解:AQS,Lock,ReentrantLock,ReentrantReadWriteLock

    原文:java并发编程 | 锁详解:AQS,Lock,ReentrantLock,ReentrantReadWriteLock 锁 锁是用来控制多个线程访问共享资源的方式,java中可以使用synch ...

  3. java 网络编程-tcp/udp

    --转自:http://blog.csdn.net/nyzhl/article/details/1705039 直接把代码写在这里,解释看这里吧:http://blog.csdn.net/nyzhl/ ...

  4. Java网络编程——TCP/UDP

    UDP:面向无连接 ☆ 将数据及源地址和目的地址封装成数据包中 ☆ 每个数据报的大小限制在64K ☆ 不可靠协议 ☆ 不需要建立连接,速度快 TCP:面向有连接 ☆ 建立连接,形成传输数据的通道 ☆ ...

  5. java网络编程TCP传输—流操作—拿到源后的写入动作

    在网络编程中的TCP传输里,拿到Socket的源后,应该怎么进行读写操作呢,下面我列举了两种方法,希望大家帮忙补充···· 1.利用byte数组作为一个缓冲区进行读写 客户端上传 //获取socket ...

  6. java并发编程 | 线程详解

    个人网站:https://chenmingyu.top/concurrent-thread/ 进程与线程 进程:操作系统在运行一个程序的时候就会为其创建一个进程(比如一个java程序),进程是资源分配 ...

  7. Java分享笔记:Java网络编程--TCP程序设计

    [1] TCP编程的主要步骤 客户端(client): 1.创建Socket对象,构造方法的形参列表中需要InetAddress类对象和int型值,用来指明对方的IP地址和端口号. 2.通过Socke ...

  8. Java网络编程(TCP客户端)

    TCP传输:两个端点建立连接后会有一个传输数据的通道,这个通道就称为流,而且是建立在网络基础上的流,之为socket流,该流中既可以读取也可以写入. TCP的两个端点:一个客户端:ServerSock ...

  9. JAVA网络编程TCP通信

    Socket简介: Socket称为"套接字",描述IP地址和端口.在Internet上的主机一般运行多个服务软件,同时提供几种服务,每种服务都打开一个Socket,并绑定在一个端 ...

随机推荐

  1. clang 编译 OC

    clang -fobjc-arc -framework Foundation helloworld.m -o helloworld.out OVERVIEW: clang LLVM compiler ...

  2. jQuery基础笔记(1)

    day54 参考:https://www.cnblogs.com/liwenzhou/p/8178806.html 1. 为什么要学jQuery?  MySQL Python              ...

  3. git aliases

    单独的 alias git config --global alias.co checkout git config --global alias.br branch git config --glo ...

  4. GCD 中使用 dispatch group 进行同步操作

    话不多说,先上代码,在分析 Code - (void)viewDidLoad { [super viewDidLoad]; dispatch_group_t group1 = dispatch_gro ...

  5. JavaScript里的Date 对象属性及对象方法--实现简单的日历

    上网搜索"js 日历插件"就会出来各种效果的功能丰富的日历插件,很多都可以下载源码,然后根据各自的需求对源码进行修改就可以直接用了. 但今天讲的不是如何使用这些插件,而是讲如何实现 ...

  6. leetcode-166-分数到小数(用余数判断有没有出现小数的循环体)

    题目描述:   给定两个整数,分别表示分数的分子 numerator 和分母 denominator,以字符串形式返回小数. 如果小数部分为循环小数,则将循环的部分括在括号内. 示例 1: 输入: n ...

  7. 【xsy1143】 兔子的数字 搜索

    题目大意:请找到第$k$大的数,满足各位数字之和等于各位数字之积.其中$k≤10^{18}$. 首先我们要确定这个第$k$大的数有多大 我们用$f[i][j][he][ji]$表示我们要搜索一个$i$ ...

  8. POJ 2245

    //此题一看便是简单的回溯题用DFS+回溯便可以做出来了. #include <iostream> #define MAXN 20 using namespace std; int _m[ ...

  9. hive算法报错..

    hive普通语句查询报错.. 查到以下设定项,,附加在语句前执行成功.. 但是有可能没有真正的执行.. 试到最后使用标红的三行附加在语法前执行成功 set hive.execution.engine= ...

  10. Dubbo架构设计详解(转载)

    原文地址:http://shiyanjun.cn/archives/325.html Dubbo是Alibaba开源的分布式服务框架,它最大的特点是按照分层的方式来架构,使用这种方式可以使各个层之间解 ...