概述

网络模型

网络通讯的要素

ip地址:网络中设备的标识符

端口:用于标识同一台设备上不同的进程,有效端口:0~65535,其中0~1024是系统使用端口或者保留端口

TCP与UDP

UDP特点

面向无连接,速度快,不可靠

数据包中封装了数据、源和目的

每个数据报最大为64K

TCP特点

面向连接,通过三次握手建立连接,安全可靠

经常用于大数据的传输

Socket套接字

Socket就是为网络服务提供的一种机制

通信的两端都有Socket

网络通信其实就是Socket间的通信

数据在两个Socket间通过IO传输

UDP传输

DatagramSocket:UDP套接字

DatagramPacket:UDP数据报

下面是UDP实现的简单传输

  1. 1: import java.net.*;

  1. 2: import java.io.*;

  1. 3: 

  1. 4: /*

  1. 5: 服务器读取键盘的数据,变成大写发送给客户端

  1. 6: */

  1. 7: 

  1. 8: class UdpServerDemo

  1. 9: {

  1. 10: public static void main(String[] args) throws Exception

  1. 11: {

  1. 12: //建立udp服务

  1. 13: DatagramSocket ds = new DatagramSocket();

  1. 14: 

  1. 15: //建立键盘输入流

  1. 16: BufferedReader bufr =

  1. 17: new BufferedReader(new InputStreamReader(System.in));

  1. 18: 

  1. 19: String line = null;

  1. 20: 

  1. 21: while( (line = bufr.readLine()) != null)

  1. 22: {

  1. 23: //定义数据包

  1. 24: byte[] data = line.toUpperCase().getBytes();

  1. 25: InetAddress ia = InetAddress.getLocalHost();

  1. 26: int port = 10000;

  1. 27: DatagramPacket dp = new DatagramPacket(data,data.length,ia,port);

  1. 28: 

  1. 29: //发送数据包

  1. 30: ds.send(dp);

  1. 31: }

  1. 32:

  1. 33: //关闭资源

  1. 34: //ds.close();

  1. 35: 

  1. 36: }

  1. 37: }

  1. 38: 

  1. 39: class UdpClientDemo

  1. 40: {

  1. 41: public static void main(String[] args) throws Exception

  1. 42: {

  1. 43: //建立UDP服务

  1. 44: DatagramSocket ds = new DatagramSocket(10000);

  1. 45:

  1. 46: //定义接收数据包

  1. 47: byte[] data = new byte[1024];

  1. 48: DatagramPacket dp = new DatagramPacket(data,1024);

  1. 49: 

  1. 50: while(true)

  1. 51: {

  1. 52: //接收数据包

  1. 53: ds.receive(dp);

  1. 54:

  1. 55: //打印相关信息

  1. 56: System.out.println("Address:"+dp.getAddress().getHostAddress()+"---port:"+dp.getPort());

  1. 57: System.out.println(new String(dp.getData(),0,dp.getLength()));

  1. 58: }

  1. 59: 

  1. 60: //关闭资源

  1. 61: //ds.close();

  1. 62: 

  1. 63: }

  1. 64: }

TCP传输

ServerSocket:服务端套接字

Socket:客户端套接字

下面是用tcp实现的简单上传图片功能

  1. 1: import java.io.*;

  1. 2: import java.net.*;

  1. 3: 

  1. 4: class UploadPicClient

  1. 5: {

  1. 6: public static void main(String[] args) throws Exception

  1. 7: {

  1. 8: //建立客户端TCP服务

  1. 9: InetAddress ia = InetAddress.getLocalHost();

  1. 10: Socket s = new Socket(ia,10000);

  1. 11:

  1. 12: //建立本地文件字节流

  1. 13: BufferedInputStream bufi = new BufferedInputStream(new FileInputStream("1.jpeg"));

  1. 14:

  1. 15: //建立tcp输出流

  1. 16: BufferedOutputStream bufo = new BufferedOutputStream(s.getOutputStream());

  1. 17:

  1. 18: //读取本地文件,通过tcp输出流传输到服务器

  1. 19: int len = -1;

  1. 20: byte[] data = new byte[1024];

  1. 21: 

  1. 22: while( (len = bufi.read(data)) != -1 )

  1. 23: {

  1. 24: bufo.write(data,0,len);

  1. 25: bufo.flush();

  1. 26: }

  1. 27:

  1. 28: //关闭tcp输出流,相当于为服务器发送了一个结束标记 :-1

  1. 29: s.shutdownOutput();

  1. 30:

  1. 31: //建立tcp输入流

  1. 32: BufferedReader bufr =

  1. 33: new BufferedReader(new InputStreamReader(s.getInputStream()));

  1. 34: 

  1. 35: //打印读取到的确认信息

  1. 36: System.out.println(bufr.readLine());

  1. 37:

  1. 38: //关闭资源

  1. 39: s.close();

  1. 40: }

  1. 41: }

  1. 42: 

  1. 43: class UploadPicServer

  1. 44: {

  1. 45: public static void main(String[] args) throws Exception

  1. 46: {

  1. 47: //建立服务器tcp服务

  1. 48: ServerSocket ss = new ServerSocket(10000);

  1. 49:

  1. 50: //等待客户端连接

  1. 51: Socket s = ss.accept();

  1. 52: 

  1. 53: //打印客户机ip信息

  1. 54: System.out.println(s.getInetAddress().getHostName()+" connecting...");

  1. 55:

  1. 56: //建立tcp读取流

  1. 57: BufferedInputStream bufi = new BufferedInputStream(s.getInputStream());

  1. 58: 

  1. 59: //为本地文件建立输入流

  1. 60: BufferedOutputStream bufo = new BufferedOutputStream(new FileOutputStream("pic.jpeg"));

  1. 61:

  1. 62: //读取网络数据,写入到本地文件

  1. 63: int len = -1;

  1. 64: byte[] data = new byte[1024];

  1. 65: 

  1. 66: while( (len = bufi.read(data)) != -1)

  1. 67: {

  1. 68: bufo.write(data,0,len);

  1. 69: bufo.flush();

  1. 70: }

  1. 71:

  1. 72: //建立tcp输出流

  1. 73: PrintWriter pw = new PrintWriter(s.getOutputStream(),true);

  1. 74:

  1. 75: //发送服务器确认信息

  1. 76: pw.println("上传成功");

  1. 77:

  1. 78: //关闭资源

  1. 79: s.close();

  1. 80: ss.close();

  1. 81: }

  1. 82: }

URL-URLConnection

URL:

Uniform Resource Locator,俗称网页地址

String getFile()

         获取此 URL 的文件名。

String getHost()

         获取此 URL 的主机名(如果适用)。

String getPath()

         获取此 URL 的路径部分。

int getPort()

         获取此 URL 的端口号。

String getProtocol()

         获取此 URL 的协议名称。

String getQuery()

         获取此 URL 的查询部

URLConnection    openConnection()

         返回一个 URLConnection 对象,它表示到 URL 所引用的远程对象的连接。

URLConnection

URLConnection内部已经封装好了网络读写流,直接调用方法获取即可

InputStream    getInputStream()

         返回从此打开的连接读取的输入流。

OutputStream    getOutputStream()

         返回写入到此连接的输出流。

下面是URL实现的简单的浏览器,暂时没有调用HTML解析引擎,所以读到的数据都是带标签的html代码

  1. 1: import java.awt.*;

  1. 2: import java.awt.event.*;

  1. 3: import java.io.*;

  1. 4: import java.net.*;

  1. 5: 

  1. 6: class MyWindow

  1. 7: {

  1. 8: private Frame f;

  1. 9: private TextField tf;

  1. 10: private TextArea ta;

  1. 11: private Button b;

  1. 12: private Dialog dErrorUrl;

  1. 13: private Label lErrorUrl;

  1. 14: private Button bErrorUrl;

  1. 15: 

  1. 16: MyWindow()

  1. 17: {

  1. 18: init();

  1. 19: }

  1. 20: 

  1. 21: //初始化窗口

  1. 22: private void init()

  1. 23: {

  1. 24: f = new Frame();

  1. 25: f.setTitle("我的浏览器");

  1. 26: f.setBounds(200,200,800,600);

  1. 27: 

  1. 28: tf = new TextField(100);

  1. 29: ta = new TextArea(30,110);

  1. 30: b = new Button("转到");

  1. 31: 

  1. 32: f.setLayout(new FlowLayout());

  1. 33: 

  1. 34: f.add(tf);

  1. 35: f.add(b);

  1. 36: f.add(ta);

  1. 37: 

  1. 38: dErrorUrl = new Dialog(f,"Error Url!",true);

  1. 39: dErrorUrl.setBounds(300,300,240,90);

  1. 40: dErrorUrl.setLayout(new FlowLayout());

  1. 41: lErrorUrl = new Label();

  1. 42: bErrorUrl = new Button("Ok");

  1. 43: 

  1. 44: dErrorUrl.add(lErrorUrl);

  1. 45: dErrorUrl.add(bErrorUrl);

  1. 46: 

  1. 47: action();

  1. 48: 

  1. 49: f.setVisible(true);

  1. 50: }

  1. 51:

  1. 52: //一些简单事件响应

  1. 53: private void action()

  1. 54: {

  1. 55: //窗口关闭动作

  1. 56: f.addWindowListener(new WindowAdapter()

  1. 57: {

  1. 58: public void windowClosing(WindowEvent e)

  1. 59: {

  1. 60: System.exit(0);

  1. 61: }

  1. 62: });

  1. 63:

  1. 64: //URL输入动作

  1. 65: tf.addKeyListener(new KeyAdapter()

  1. 66: {

  1. 67: public void keyPressed(KeyEvent e)

  1. 68: {

  1. 69: if(e.getKeyCode() == KeyEvent.VK_ENTER)

  1. 70: toUrl();

  1. 71:

  1. 72: //ta.setText(tf.getText());

  1. 73: }

  1. 74: });

  1. 75:

  1. 76: b.addActionListener(new ActionListener()

  1. 77: {

  1. 78: public void actionPerformed(ActionEvent e)

  1. 79: {

  1. 80: toUrl();

  1. 81: }

  1. 82: });

  1. 83: 

  1. 84: bErrorUrl.addActionListener(new ActionListener()

  1. 85: {

  1. 86: public void actionPerformed(ActionEvent e)

  1. 87: {

  1. 88: dErrorUrl.setVisible(false);

  1. 89: }

  1. 90: });

  1. 91: 

  1. 92: dErrorUrl.addWindowListener(new WindowAdapter()

  1. 93: {

  1. 94: public void windowClosing(WindowEvent e)

  1. 95: {

  1. 96: dErrorUrl.setVisible(false);

  1. 97: }

  1. 98: });

  1. 99: 

  1. 100: }

  1. 101: 

  1. 102: //打开网站

  1. 103: private void toUrl()

  1. 104: {

  1. 105: URL url = null;

  1. 106: try

  1. 107: {

  1. 108: //获取文本框中的url

  1. 109: url = new URL(tf.getText());

  1. 110: }

  1. 111: catch (Exception e)

  1. 112: {

  1. 113: lErrorUrl.setText(e.toString());

  1. 114: dErrorUrl.setVisible(true);

  1. 115: }

  1. 116:

  1. 117: if(url != null)

  1. 118: {

  1. 119: ta.setText("");

  1. 120: 

  1. 121: try

  1. 122: {

  1. 123: //创建URL连接

  1. 124: URLConnection conn = url.openConnection();

  1. 125: //获取输入流

  1. 126: BufferedInputStream bufr = new BufferedInputStream(conn.getInputStream());

  1. 127:

  1. 128: //读取网站服务器返回的数据

  1. 129: byte[] buf = new byte[1024];

  1. 130: int len = -1;

  1. 131: 

  1. 132: while( (len= bufr.read(buf)) != -1)

  1. 133: {

  1. 134: //打印到文本区域

  1. 135: ta.append(new String(buf,0,len));

  1. 136: }

  1. 137:

  1. 138: //打开本地浏览器

  1. 139: //Runtime.getRuntime().exec("rundll32 url.dll,FileProtocolHandler "+url);

  1. 140: }

  1. 141: catch (IOException e)

  1. 142: {

  1. 143: lErrorUrl.setText(e.toString());

  1. 144: dErrorUrl.setVisible(true);

  1. 145: }

  1. 146: catch (Exception ex)

  1. 147: {

  1. 148: ta.append("\r\n"+ex.toString()+"\r\n");

  1. 149: }

  1. 150: 

  1. 151: }

  1. 152:

  1. 153: }

  1. 154: }

  1. 155: 

  1. 156: class MyBrowserDemo

  1. 157: {

  1. 158: public static void main(String[] args)

  1. 159: {

  1. 160: new MyWindow();

  1. 161: }

  1. 162: }

Java笔记(二十九)……网络编程的更多相关文章

  1. Python学习日记(二十九) 网络编程

    早期的计算机通信需要有一个中间件,A要给B传东西,A必须要把信息传给中间件,B再把从中间件中拿到信息 由于不同机器之间需要通信就产生了网络 软件开发的架构 1.C/S架构 服务器-客户机,即Clien ...

  2. Java学习笔记二十九:一个Java面向对象的小练习

    一个Java面向对象的小练习 一:项目需求与解决思路: 学习了这么长时间的面向对象,我们只是对面向对象有了一个简单的认识,我们现在来做一个小练习,这个例子可以使大家更好的掌握面向对象的特性: 1.人类 ...

  3. angular学习笔记(二十九)-$q服务

    angular中的$q是用来处理异步的(主要当然是http交互啦~). $q采用的是promise式的异步编程.什么是promise异步编程呢? 异步编程最重要的核心就是回调,因为有回调函数,所以才构 ...

  4. Java笔记(十九) 反射

    反射 反射是在运行时获取类型的信息,再根据这些信息进行操作. 一.Class类 每个已加载的类在内存中都有一份类信息,每个对象都有指向它的类信息的引用. 在Java中,类信息对应的类就是java.la ...

  5. 菜鸡的Java笔记 第十九 - java 继承

    继承性的主要目的,继承的实现,继承的限制                继承是面向对象中的第二大主要特点,其核心的本质在于:可以将父类的功能一直沿用下去                为什么需要继承? ...

  6. Java笔记(二十八)……IO流下 IO包中其他常用类以及编码表问题

    PrintWriter打印流 Writer的子类,既可以接收字符流,也可以接收字节流,还可以接收文件名或者文件对象,非常方便 同时,还可以设置自动刷新以及保持原有格式写入各种文本类型的print方法 ...

  7. Java笔记(二十六)……IO流上 字节流与字符流

    概述 IO流用来处理设备之间的数据传输 Java对数据的操作时通过流的方式 Java用于操作流的对象都在IO包中 流按操作的数据分为:字节流和字符流 流按流向不同分为:输入流和输出流 IO流常用基类 ...

  8. Java笔记(二十五)……其他常用API

    System类 工具类全部都是静态方法 常用方法 获取系统属性信息 static PropertiesgetProperties() static StringgetProperty(String k ...

  9. Java笔记(二十四)……集合工具类Collections&Arrays

    Collections 集合框架的工具类,方法全部为静态 Collections与Collection的区别 Collection是集合框架的一个顶层接口,里面定义了单列集合的共性方法 Collect ...

随机推荐

  1. phpcms前端页面上传文件

    PHPCMS其实有一个叫做附件的模块,上传用的就是这个东西,现在我们来看一下对应的文件:phpcms\modules\attachment \attachments.php就是这个文件,大概在29行上 ...

  2. 如何配置SSH Keys登录

    SSH Keys简介: 使用SSH Keys的登录远程虚拟云主机的方式比单独使用密码登录更加安全,简单的密码很可能被暴力破解.而目前来看采用长度大于1024位的RSA加密算法,几乎是不可能被破解的.S ...

  3. Python获取两个ip之间的所有ip

    int_ip = lambda x: '.'.join([str(x/(256**i)%256) for i in range(3,-1,-1)]) ip_int = lambda x:sum([25 ...

  4. RS232与RS485时序分析

    转载于:RS232,RS485波形分析 经常遇到初学者,对单片机串行通讯出了问题不知道如何办的情况.其实最有效的调试方法是用示波器观察收发数据的波形.通过观察波形可以确定以下情况: 是否有数据接收或发 ...

  5. iOS8中的UIActionSheet添加UIDatePicker后,UIDatePicker不显示问题

    解决方法:   IOS8以前: UIActionSheet* startsheet = [[UIActionSheet alloc] initWithTitle:title delegate:self ...

  6. Grails的redirect无法跳转时的一个可能原因

    由于controller的命名一般首字母大写,如Login 此时如 class LoginController { def index = { redirect(action:Login, param ...

  7. selenium各种场景下的启动Firefox

    开始学习selenium时为了启动Firefox可谓费尽周折,在大神的帮助下才堪堪搞定,走出了selenium的第一步:jdk1.8 + selenium_2.46 + Firefox国际版40.0. ...

  8. css中文本框与按钮对不齐解决方案

    我们先对对input标记设定样式,代码如下: html 代码 <form> <input type=”text” name=”text1” id=”text1” /> < ...

  9. no identities are available for signing

    原地址:http://www.cnblogs.com/imzzk/p/3501868.html 今天将做好的app提交到app store,结果就出现标题上的错误.“No identities are ...

  10. 利用ZABBIX的RPC-JSON作API扩展应用示例

    计划将ZABBIX的一些状态可以在另一个应用的显示GRAPH及链接. 故而在网上找了几个文档,作了一个测试. https://www.zabbix.com/documentation/2.4/manu ...