题目描述
模拟实现网桥的转发功能,以从文件中读取帧模拟网桥从网络中收到一帧,即从两个文件中读入一系列帧,从第一个文件中读入一帧然后从第二个文件中再读入一帧,如此下去。对每一帧,显示网桥是否会转发,及显示转发表内容。
题目要求
Windows 或 Linux 环境下运行,程序应在单机上运行。
分析
用程序模拟网桥功能,可以假定用两个文件分别代表两个网段上的网络帧数据。而两个文件中的数据应具有帧的特征,即有目的地址,源地址和帧内数据。程序交替读入帧的数据,就相当于网桥从网段中得到帧数据。对于网桥来说,能否转发帧在于把接收到的帧与网桥中的转发表相比较。判断目的地址后才决定是否转发。由此可见转发的关键在于构造转发表。这里转发表可通过动态生成。
程序设计思路
1.使用BufferedReader读入两个文件,每次读入一行,交替读入,这里判断源地址,目的地址,数据,采用的是利用String类提高的split()方法,给每个段加入一个分隔符,利用split()传入正则表达式可以正确匹配到,分割成一个长度为3的字符串数组;
2.转发表是使用HashMap来创建,因为哈希表的key不能重复,所以使用key来表示目的地址,value来表示源地址,即这个网桥的端口地址;这样做的前提是一个目的地址只能通过一个端口来转发
3.帧的保存:使用Frame类来保存该帧的目的地址,源地址和帧内数据以及是否能够转发;每次获取一个帧并判别是否转发后都要加入一个list,便于最后输出结果。
4.转发表匹配:主要是获取目的地址的value,然后比较是否与源地址匹配,即:frame.resMac.equals(map.get(frame.desMac))。然后再设置frame.isTransfer属性,再加入list当中。
源代码及运行结果
代码:
package com.deserts.network;
import java.io.*;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* @ClassName BridgeTest
* @Description TODO
* @Author deserts
* @Date 2021/5/25 22:37
*/
public class BridgeTest {
//模拟路由转发表
static Map<String, String> map;
static {
//初始化转发表
map = new HashMap<>();
map.put( "AA-BB-CC-DD", "11-22-33-44");
map.put("1A-1B-2A-2B", "11-22-33-44");
map.put("3A-3B-4A-4B"