当前位置:七道奇文章资讯编程技术Java编程
日期:2011-03-22 16:14:00  来源:本站整理

<b>网络编程:谈谈TCP和UDP的一些简单操纵</b>[Java编程]

赞助商链接



  本文“<b>网络编程:谈谈TCP和UDP的一些简单操纵</b>[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

网络编程中最重要的就是SOCKET,它其实也就是监听端口的原理.和我们用手机发短信的原理应当是大致无二(我是这样理解的),而JAVA最超卓的一点也就是“无痛楚连网”.

网络最基本的精神就是让两台机械衔接起来,“被呼唤的一方”也就是服务器,而“找人的一方”则叫做客户机,所以说在衔接中服务器、客户机也就是一个相对的概念了.而我们对机械的标识主如果通过IP地址和端口来辨别的.

“传输掌握协议”TCP和“用户数据报协议”是两种差别的协议,JAVA对这两种协议的支持基本是一致的,而它们本身最大的辨别也就是发送的坚固性和速率,前者相比后者是坚固协议,后者当然是速度快得多了,下面我们辨别用两个SOCKET下演示:

eg1:
//Clients.java
import java.io.*;
import java.net.*;
public class Clients
{
public static void main(String[] args) throws Exception
{
InetAddress addr = InetAddress.getByName(null);
Socket socket = new Socket(addr,2000);
PrintWriter out =
new PrintWriter(
new BufferedWriter(
new OutputStreamWriter(
socket.getOutputStream())),true);
byte[] b = new byte[2048];
String msg = new String(b,0,System.in.read(b));
out.println(msg);
socket.close();
}
}
//Servers.java
import java.io.*;
import java.net.*;
   public class Servers
{
public static void main(String[] args) throws Exception
{
ServerSocket s = new ServerSocket(2000);
try{
while(true){
Socket socket = s.accept();
try{
BufferedReader in =
new BufferedReader(
new InputStreamReader(
socket.getInputStream()));
StringBuffer sb = new StringBuffer();
int c;
while( (c = in.read()) != -1 ){
char ch = (char)c;
sb.append(ch);
}
System.out.println(sb.toString());
   }catch(IOException e){
socket.close();
}finally{
socket.close();
}
}//while
}finally{
s.close();
}//try
}//main
}
此程式主要用Servers来举行无限监听,而Clients是客户机发送程式,他们的端口全采取2000.
eg2:
   //UDPsend.java
import java.io.*;
import java.net.*;
   /**
* This class sends the specified text or file as a datagram to the
* specified port of the specified host.
**/
public class UDPSend {
public static final String usage =
"Usage: java UDPSend ...
" +
" or: java UDPSend -f ";
   public static void main(String args[]) {
try {
// Check the number of arguments
if (args.length < 3)
throw new IllegalArgumentException("Wrong number of args");
   // Parse the arguments
String host = args[0];
int port = Integer.parseInt(args[1]);
   // Figure out the message to send.
// If the third argument is -f, then send the contents of the file
// specified as the fourth argument. Otherwise, concatenate the
// third and all remaining arguments and send that.
byte[] message;
if (args[2].equals("-f")) {
File f = new File(args[3]);
int len = (int)f.length(); // figure out how big the file is
message = new byte[len]; // create a buffer big enough
FileInputStream in = new FileInputStream(f);
int bytes_read = 0, n;
do { // loop until we've read it all
n = in.read(message, bytes_read, len-bytes_read);
bytes_read += n;
} while((bytes_read < len)&& (n != -1));
}
else { // Otherwise, just combine all the remaining arguments.
String msg = args[2];
for (int i = 3; i < args.length; i++) msg += " " + args[i];
message = msg.getBytes();
}
   // Get the internet address of the specified host
InetAddress address = InetAddress.getByName(host);
   // Initialize a datagram packet with data and address
DatagramPacket packet = new DatagramPacket(message, message.length,
address, port);
   // Create a datagram socket, send the packet through it, close it.
DatagramSocket dsocket = new DatagramSocket();
dsocket.send(packet);
dsocket.close();
}
catch (Exception e) {
System.err.println(e);
System.err.println(usage);
}
}
}
//UDPreceive.java
import java.io.*;
import java.net.*;
   /**
* This program waits to receive datagrams sent the specified port.
* When it receives one, it displays the sending host and prints the
* contents of the datagram as a string. Then it loops and waits again.
**/
public class UDPReceive {
public static final String usage = "Usage: java UDPReceive ";
public static void main(String args[]) {
try {
if (args.length != 1)
throw new IllegalArgumentException("Wrong number of args");
   // Get the port from the command line
int port = Integer.parseInt(args[0]);
   // Create a socket to listen on the port.
DatagramSocket dsocket = new DatagramSocket(port);
   // Create a buffer to read datagrams into. If anyone sends us a
// packet containing more than will fit into this buffer, the
// excess will simply be discarded!
byte[] buffer = new byte[2048];
   // Create a packet to receive data into the buffer
DatagramPacket packet = new DatagramPacket(buffer, buffer.length);
   // Now loop forever, waiting to receive packets and printing them.
for(;;) {
// Wait to receive a datagram
dsocket.receive(packet);
   // Convert the contents to a string, and display them
String msg = new String(buffer, 0, packet.getLength());
System.out.println(packet.getAddress().getHostName() +
": " + msg);
   // Reset the length of the packet before reusing it.
// Prior to Java 1.1, we'd just create a new packet each time.
packet.setLength(buffer.length);
}
}
catch (Exception e) {
System.err.println(e);
System.err.println(usage);
}
}
}

在UDP中主要的类是DatagramSocket()和DatagramPacket(),而在UDPreceive中,被承受的字节是受限制,这些感受不是太好,既然buf是一个字节数组,我们实在是很奇特为什么构建器自己不能调查出数组的长度呢?唯一能猜想的缘由就是C气势的编程使然,那边的数组不能自己奉告我们它有多大.

而我们实际利用的历程中,当然不但仅限于这些,此中要考虑有多台客户机来衔接服务器,所以要考虑到线程Thread的利用,假如再加上SWING,便可以做一个近似于QQ的SOCKET功效了,这仅仅限于我在学习SOCKET时的一些领悟.供大家参考.


  以上是“<b>网络编程:谈谈TCP和UDP的一些简单操纵</b>[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • <b>hosts是什么 hosts文件在什么位置 若何改正hosts</b>
  • <b>在 Windows 8 中手动安装语言包</b>
  • <b>五个常见 PHP数据库问题</b>
  • Windows中Alt键的12个高效快速的利用本领介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • <b>详解MySQL存储历程参数有三种范例(in、out、inout)</b>
  • <b>Win8系统恢复出来经典的开始菜单的办法</b>
  • <b>Win8系统花屏怎么办 Win8系统花屏的办理办法</b>
  • <b>Windows 7系统下无线网卡安装</b>
  • <b>为什么 Linux不需求碎片整理</b>
  • <b>Windows 8中删除账户的几种办法(图)</b>
  • <b>教你如安在win7下配置路由器</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .