Java 复习9网路编程 20131008

前言:

Java语言在网络通信上面的开发要远远领先于其他编程语言,这是Java开发中最重要的应用,可以基于协议的编程,如Socket,URLConnection等等,之后面的Web开发就是Servlet开发还有各种框架等等,基本上都是基于网络编程的。在上大二的时候,自己学习过Java网络编程的知识,现在好像都忘了,再有就是JSP,Servlet等等这些编程的知识也都忘得差不多了,所以这一段时间回忆一下关于网络编程和Web编程的知识。

1.网络通信编程

TCP/IP(Transport Control Protocol / Internet Protocol) 是Internet最基本的协议。IP协议规定了数据传输的是的基本单元格式,数据包的递交办法和路由选择。TCP协议是提供的是可靠地面向对象的数据流传输服务的规则和约定。简单的说IP协议是单向的,TCP模式下,对方发送给你一个数据包,你要发送一个确认数据包给对方,这样来确认数据传输的可靠性。

2.使用URL进行网络连接

URL(Uniform Resource Loactor): 用于完整描述internet网页的和其他资源唯一标识,通常用的构造方法有:

public URL(String spec); URL url = new URL(“http://yangtengfei.duapp.com/index.php”)

public URL(URL context, String spec);

public URL(String protocol, String host, String file);

public URL(String protocol,String host, int port, String file);

使用URL获取指定的URL的数据流:

URL url  = null;

try {

url = new URL("http://yangtengfei.duapp.com/index.html");

} catch (MalformedURLException e) {

e.printStackTrace();

}

System.out.println("protocol:"+url.getProtocol());

System.out.println("host:"+ url.getHost());

try {

System.out.println("content:" + url.getContent().toString());

} catch (IOException e) {

e.printStackTrace();

}

System.out.println("port:" + url.getPort());

System.out.println("file:" + url.getFile());

System.out.println("Ref: " + url.getRef());

System.out.println("UserInfo" + url.getUserInfo());

try {

url.openConnection();

} catch (IOException e) {

e.printStackTrace();

}

try {

BufferedInputStream bis = new BufferedInputStream(url.openStream());

byte []buf = new byte[100];

int count = -1;

while((count=bis.read(buf, 0, 100))  != -1){

System.out.print(new String(buf,0,count));

}

} catch (IOException e) {

e.printStackTrace();

}

3.Socket编程

Java定义了Socket和ServerSocket两个类socket表示客户端,ServerSocket表示服务器端。

构造函数:

Socket(InetAddress address, int port [, boolean stream]);

Socket(String host,int port[, boolean stream]);

Socket(SocketImpl impl);

Socket(String host,int port,InetAddress localAddress, int localport);

Socket(InetAddress address, int port, InetAddress localAddr, int localport);

ServerSocket(int port);

ServerSocket(int port, int backlog, InetAddress binAddr/*local address*/);

Server 端编程:

ss.accept() 接受一个连接,返回一个socket,然后通过socket打开输入输出流发送数据。

Socket socket = null;

BufferedInputStream  bis = null;

BufferedOutputStream bos = null;

try {

socket = ss.accept();

bis = new BufferedInputStream(socket.getInputStream());

bos = new BufferedOutputStream(socket.getOutputStream());

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

当然Server段不可能只有一个客户端连接,这就需要在没接受一个连接的时候,将accept连接返回的socket作为参数触底给一个线程,让一个线程根据socket获得输入输出流,并且收发数据。同时数据流的收发建议使用Buffer缓存机制。

网络编程中少不了是数据流操作,同时还有字节流的操作,对于网络传输的数据基本上都是基于字节流的,一般不会使用字符流,所以我们在数据流操作的时候需要使用字节流而不是字节流。

字节流的操作,参看之前整理的输入输出流的笔记。

追梦的飞飞

于广州中山大学 20131008

HomePage: http://yangtengfei.duapp.com

Java复习9网路编程的更多相关文章

  1. Java复习10.Servlet编程

    Java复习10. Servlet编程知识 20131008 前言: 之前在大三下的时候,学习了一个月的JSP和Servlet知识,但是没有什么项目经验,把JSP Web开发学习实录看了前面几张,后面 ...

  2. Java中的网络编程

    ​ Java中的网路编程主要是Java的Socket编程,属于JavaEE中的高级的部分,以下内容是对java网路编程的一个小结,代码都是经过编译调试的 C/S程序应用:客户/服务器模式,如QQ客户端 ...

  3. Java复习11. 单例编程

    Java复习11. 单例编程 1.最简单的写法,那个方式是线程不安全的 public class Singleton {     private static Singleton instance; ...

  4. java 复习001

    java 复习001 比较随意的记录下我的java复习笔记 ArrayList 内存扩展方法 分配一片更大的内存空间,复制原有的数据到新的内存中,让引用指向新的内存地址 ArrayList在内存不够时 ...

  5. Java复习8.多线程

    Java复习8 多线程知识 20131007 前言: 在Java中本身就是支持多线程程序的,而不是像C++那样,对于多线程的程序,需要调用操作系统的API 接口去实现多线程的程序,而Java是支持多线 ...

  6. Java复习7.输入输出流

    Java复习7.输入输出流 20131005 前言: Java中涉及数据的读写,都是基于流的,这一块的知识相当重要,而且在Java中的数据,char字符是16bit的,所以存在字节流和字符流的区别.如 ...

  7. Java复习5.面向对象

    Java 复习5面向对象知识 20131004 前言: 前几天整理了C++中的面向对象的知识,学习Java语言,当然最重要的就是面向对象的知识,因为可以说Java是最正宗的面向对象语言,相比C++,更 ...

  8. Java复习1.基本知识

    Java语言概述 20131003 开头语: 开发领域,重要的编程语言基本都是C/C++,然后就是Java, C/C++就不用说了,另外掌握Java对你是有很大的帮助的,而且也会扩宽你的择业范围.同时 ...

  9. JavaEE-实验一 Java常用工具类编程

    该博客仅专为我的小伙伴提供参考而附加,没空加上代码具体解析,望各位谅解 1.  使用类String类的分割split 将字符串  “Solutions to selected exercises ca ...

随机推荐

  1. 性能调优之MySQL篇一:MySQL性能计数器

    计数器 计数器分析 Threads_connected 表示当前有多少个客户连接该mysql服务器,连接数是否过多,网络是否存在问题,它是动态变化的,当达到最大连接数时,数据库系统就不能提供更多的连接 ...

  2. 微服务-使用Redis实现分布式缓存

    在单体中对于key信息和用户信息是放在内存中放的,通过session进行管理. 微服务是要放在分布式缓存中,以实现服务的无状态化. @Autowired private StringRedisTemp ...

  3. HDFS只支持文件append操作, 而依赖HDFS的HBase如何完成数据的增删改查

    转:http://www.th7.cn/db/nosql/201510/135382.shtml 1. HDFS的文件append功能 早期版本的HDFS不支持任何的文件更新操作,一旦一个文件创建.写 ...

  4. Kafka学习之(一)了解一下Kafka及关键概念和处理机制

    Kafka是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模小打的网站中所有动作流数据.优势 高吞吐量:非常普通的硬件Kafka也可以支持每秒100W的消息,即使在非常廉价的商用机器上也能做 ...

  5. [NOI2014]起床困难综合症(二进制+贪心)

    题目 [NOI2014]起床困难综合症 做法 先用全\(0\)和全\(1\)去运行一下,再在满足\(m\)的限制下,贪心地从高位到低位选择即可

  6. 20145322第一次JAVA实验报告

    20145322第一周JAVA实验报告 课程:Java程序设计 班级:1453 指导教师:娄嘉鹏 实验名称:Java开发环境的熟悉(Linux + Eclipse) 实验日期:2016.04.08 实 ...

  7. 【读书笔记】《深入浅出nodejs》第三章 异步I/O

    1. 为什么要异步I/O (1)用户体验上: 并发的优势: M+N+... -> max(M,N,...)  --> 使后端能够快速的响应资源 *并发的劣势:... (2)资源分配: 单线 ...

  8. 转:MySQL 的show processlist

    processlist 命令的输出结果显示了有哪些线程在运行,可以帮助识别出有问题的查询语句,两种方式使用这个命令. 1.        进入 mysql/bin 目录下输入 mysqladmin p ...

  9. hiho#1080 更为复杂的买卖房屋姿势 线段树+区间更新

    #1080 : 更为复杂的买卖房屋姿势 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho都是游戏迷,“模拟都市”是他们非常喜欢的一个游戏,在这个游戏里面他们 ...

  10. ANDROID教程目录

    html5 如何打包成apk,将H5封装成android应用APK文件的几种方法