广州大学 计算机网络实验5 网络程序设计 写一个程序来模拟网桥功能 2020.12

本文主要是介绍广州大学 计算机网络实验5 网络程序设计 写一个程序来模拟网桥功能 2020.12,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、网桥的定义

网桥是一个局域网与另一个局域网之间建立连接的桥梁。属于数据链路层的一种设备。

网桥的作业是拓展网络和通信手段,在各种传输介质中发送数据信号,拓展网络的距离,同时又有选择地将现有地址的信号从一个传输介质发送到另一个传输介质,并能有效抵限制两个介质系统中无关紧要的通信。

网桥可分为本地网桥和远程网桥。本地网桥指在传输介质允许长度范围内互联网络的网桥,远程网桥是指连接的距离超过网络的常规范围时使用的远程桥,通过远程桥互联的局域网将成为广域网,如果使用远程网桥,远程桥必须成对出现。

目前流行的网桥实现:交换机。

2、写一个程序来模拟网桥功能

模拟实现网桥的转发功能,以从文件中读取帧模拟网桥从网络中收到一帧,即从两个文件中读入一系列帧,从第一个文件中读入一帧然后从第二个文件中再读入一帧,如此下去。对每一帧,显示网桥是否会转发,及显示转发表内容。

在这里插入图片描述
换一个图:

在这里插入图片描述

我的方式

我们简化帧和交换表的格式,用txt来模拟帧和转发表。

帧的格式:

【源地址】 【目的地址】 【帧数据】

我们用a-z 26个字母来表示不同的地址。
在现实中,帧数据应该是一些二进制串,在这个实验中,重点不在这些二进制串,我们用data字符串来表示。

在这里插入图片描述

交换表的格式:

【地址】 【网段】 【记录时间】

我们用A、B、C这 26个大写字母来表示不同的网段。

因为交换表一开始是可以为空的,可以通过自学习功能来慢慢补全,补的时候就会记录下时间。

在这里插入图片描述

程序运行逻辑:

在这里插入图片描述

实验文件夹:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

实验结果

在这里插入图片描述
在这里插入图片描述

通过自学习之后的交换表:

在这里插入图片描述

代码:

此代码比较啰嗦。。并且为了让代码看起来想多公整,没有考虑字符流的异常抛出,关闭流等问题,有可能会有问题。

import java.io.*;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;public class Bridege {//从一开始就设定网段A,B有多少台主机public static String[] pcSegA = new String[]{"a","b","c"};public static String[] pcSegB = new String[]{"l","j","k"};//文件读取public static BufferedReader readTxt(String fileName) throws Exception {//创建字符流FileReader fr = new FileReader(fileName);BufferedReader br = new BufferedReader(fr);return br;}//转发算法public static void transfer(String flag,String curLine,Map addrToSegMap,PrintWriter pw){//1、获取源地址和目的地址String[] conment = curLine.split(" ");String src = conment[0];String dst = conment[1];System.out.println("源地址:"+src);System.out.println("目的地址:"+dst);//2、交换表记录源地址SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String time = sdf.format(new Date());addrToSegMap.put(src,flag);//写入到交换表之中pw.println(src+" "+flag+" "+time);//3、在交换表中找目的地址if(addrToSegMap.containsKey(dst)){System.out.println("交换表中找到接受网段"+dst+",进行转发");}else{System.out.println("交换表中没有找到接受网段"+dst+",进行广播");if(boardcast(flag,dst)){System.out.println("广播中找到接受网段"+dst+",进行转发");}else{System.out.println("广播未找到接受网段"+dst+",丢弃此帧");}}}public static boolean boardcast(String flag,String dst){if(flag.equals("A")){//找B网段for (int i = 0; i < pcSegB.length; i++) {if( dst.equals(pcSegB[i]) ){return true;}}}else{//找A网段for (int i = 0; i < pcSegA.length; i++) {if( dst.equals(pcSegA[i]) ){return true;}}}return false;}public static void main(String[] args) throws Exception{//1、程序读入网段A,网段B,交换表BufferedReader brA = readTxt("src/segmentA.txt");BufferedReader brB = readTxt("src/segmentB.txt");BufferedReader brSwap = readTxt("src/swaptable.txt");System.out.println("开始读入交换表数据··········");//2、把交换表中 地址——》网段 映射写在一个哈希表上Map<String,String> addrToSegMap= new HashMap<>();//第一行是标题不读brA.readLine();brB.readLine();brSwap.readLine();String flag = "A";//当网段的帧已经全部读完.则置为trueboolean segaIsReaded = false;boolean segbIsReaded = false;//读取交换表内容while(true){String curLine = brSwap.readLine();//读到文件末尾if(curLine == null){break;}//以空格为分隔符,分别是 地址,网段,时间String[] conment = curLine.split(" ");System.out.println(conment[0]+" "+conment[1]+" "+conment[2]);//添加进入哈希表addrToSegMap.put(conment[0],conment[1]);}//已经不用再读取交换表了brSwap.close();System.out.println("交换表数据读入完毕··········");//设置为追加写入模式FileWriter fw = new FileWriter("src/swaptable.txt",true);PrintWriter pw = new PrintWriter(fw);System.out.println("开始读入网段帧数据··········");System.out.println("=============================================");//开始读入A,B网段的内容while(true){//两个网段的内容都读完,跳出。if(segaIsReaded && segbIsReaded){break;}if(!segaIsReaded && flag.equals("A")){String curLine = brA.readLine();//网段A读完if(curLine == null){segaIsReaded = true;//下一次读网段Bflag = "B";continue;}//网段A未读完System.out.println("收到网段"+flag+"的一个帧数据,开始转发··········");transfer(flag,curLine,addrToSegMap,pw);System.out.println("=============================================");flag = "B";continue;}//防止跳出之后flag = "B";if(!segbIsReaded && flag == "B"){String curLine = brB.readLine();//网段B读完if(curLine == null){segbIsReaded = true;//下一次读网段Aflag = "A";continue;}//网段B未读完System.out.println("收到网段"+flag+"的一个帧数据,开始转发··········");transfer(flag,curLine,addrToSegMap,pw);System.out.println("=============================================");flag = "A";continue;}//防止跳出之后flag = "A";}System.out.println("全部网段帧数据读入完毕··········");//关闭流brA.close();brB.close();fw.flush();pw.close();fw.close();System.out.println("程序结束");}
}

这篇关于广州大学 计算机网络实验5 网络程序设计 写一个程序来模拟网桥功能 2020.12的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/413526

相关文章

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了

poj 2112 网络流+二分

题意: k台挤奶机,c头牛,每台挤奶机可以挤m头牛。 现在给出每只牛到挤奶机的距离矩阵,求最小化牛的最大路程。 解析: 最大值最小化,最小值最大化,用二分来做。 先求出两点之间的最短距离。 然后二分匹配牛到挤奶机的最大路程,匹配中的判断是在这个最大路程下,是否牛的数量达到c只。 如何求牛的数量呢,用网络流来做。 从源点到牛引一条容量为1的边,然后挤奶机到汇点引一条容量为m的边

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

EMLOG程序单页友链和标签增加美化

单页友联效果图: 标签页面效果图: 源码介绍 EMLOG单页友情链接和TAG标签,友链单页文件代码main{width: 58%;是设置宽度 自己把设置成与您的网站宽度一样,如果自适应就填写100%,TAG文件不用修改 安装方法:把Links.php和tag.php上传到网站根目录即可,访问 域名/Links.php、域名/tag.php 所有模板适用,代码就不粘贴出来,已经打