`
tmdpzc
  • 浏览: 13779 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

UDP 本地转发 消息,实现松耦合的进程间通信

阅读更多
最近的项目需求,让多个Android应用共用一条链路,采用AIDL Service 觉得耦合度比较高,于是想想能不能用UDP本地转发的方式来将数据传送到那条链路所在的Service中。
于是写了下面两个测试代码。没有定义协议,直接用了对象序列化的方法。

服务器端代码:
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.SocketException;


public class UDPServer extends Thread{
	private byte[] buffer = new byte[1024*4];
 	@Override
	public void run() {
		try {
			DatagramSocket mServerSocket = new DatagramSocket(8803);
			DatagramPacket mPacket = new DatagramPacket(buffer, buffer.length);
			while (true) {
				mServerSocket.receive(mPacket);
				System.out.println("接收到的长度:" + mPacket.getLength());
				System.out.println("端口地址:" + mPacket.getAddress().getHostAddress());
				byte[] data = mPacket.getData();
				ByteArrayInputStream in = new ByteArrayInputStream(data);
				ObjectInputStream obj_in = new ObjectInputStream(in);
				Message msg = (Message) obj_in.readObject();
				System.out.println(msg.toString());
			}
		} catch (SocketException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (ClassNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
	}
}



客户端代码:
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.ObjectOutputStream;
import java.io.UnsupportedEncodingException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.InetSocketAddress;
import java.net.Socket;
import java.net.SocketAddress;
import java.net.SocketException;
import java.util.Scanner;


public class UDPClient extends Thread{
	@Override
	public void run() {
		Scanner reader = new Scanner(System.in);
		SocketAddress address = new InetSocketAddress("127.0.0.1", 8803);
		
		while (true) {
			System.out.println("请输入Message的内容");
			String content = reader.next();
			try {
				ByteArrayOutputStream out = new ByteArrayOutputStream();
				ObjectOutputStream  obj_out = new ObjectOutputStream(out);
				Message msg = new Message(12, content);
				obj_out.writeObject(msg);
				byte[] data = out.toByteArray();
				DatagramPacket mPacket = new DatagramPacket(data, data.length,address);
				DatagramSocket mSocket = new DatagramSocket();
				mSocket.send(mPacket);
				mSocket.close();
			} catch (UnsupportedEncodingException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			} catch (SocketException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			} catch (IOException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
			
			
		}
		
	}
}

分享到:
评论

相关推荐

    UDP 数据转发工具

    7. **性能优化**:UDP数据转发工具可能通过多线程或多进程技术来提高转发效率,尤其是在高负载环境下。 8. **应用场景**:除了上述的实时通信,UDP数据转发还广泛应用于网络诊断、负载均衡、分布式系统中的数据交换...

    socket 实现进程间通信

    本文将深入探讨如何利用socket来实现在同一台机器上三个进程间的通信,同时涉及select()函数、信号处理以及进程重启的技术。 首先,让我们理解什么是socket。Socket是网络编程中的接口,它允许应用程序发送和接收...

    利用UDP协议与socket文件完成两个进程之间的网络通信

    客户端使用UDP套接字发送数据,并可以创建socket文件与本地其他进程通信,传递接收到的信息。这种方式允许网络通信与本地进程间通信的无缝集成。 总结来说,通过UDP协议和socket文件,我们可以实现跨进程的网络通信...

    进程间通信例子

    在Windows环境中,实现进程间通信有多种方式,包括但不限于管道、消息队列、共享内存、套接字、命名管道、事件、信号量、邮件槽等。这个“进程间通信例子”可能是针对Windows Forms(WinForm)应用程序提供的一种...

    windows的udp端口转发工具sokit

    在某些情况下,我们可能需要在Windows系统中实现UDP端口的转发,例如,当本地机器需要通过特定端口接收远程服务器的数据,或者隐藏或重定向服务时。Windows 7的内置命令`netsh interface portproxy`虽然能方便地进行...

    UNIX网络编程 第2版 第2卷 进程间通信

    《UNIX网络编程 第2版 第2卷 进程间通信》是UNIX系统下进行网络编程不可或缺的经典著作,尤其在深入理解和实践进程间通信(IPC,Inter-Process Communication)方面提供了丰富的知识和技术指导。本书详细阐述了如何...

    VB实现进程间通信的源码

    2. **套接字通信**:VB也可以通过Winsock控件实现TCP/IP或UDP套接字通信,允许进程间进行大容量数据的实时交换,适合网络环境中的进程间通信。 3. **内存映射**:通过创建共享内存区域,不同进程可以访问同一块内存...

    头歌UDP Ping程序实现-接收并转发消息

    头歌UDP Ping程序实现-接收并转发消息头歌UDP Ping程序实现-接收并转发消息头歌UDP Ping程序实现-接收并转发消息头歌UDP Ping程序实现-接收并转发消息头歌UDP Ping程序实现-接收并转发消息头歌UDP Ping程序实现-接收...

    linux进程间通信讲义及代码.

    为了实现进程间的有效通信,Linux提供了多种机制,包括管道(Pipe)、有名管道(FIFO)、信号量(Semaphore)、消息队列(Message Queue)、共享内存(Shared Memory)、套接字(Socket)等。下面将对这些通信方式...

    UDP通信方式实现.docx

    UDP 通信方式实现 UDP(User Datagram Protocol,用户数据报协议)是一种无连接的、不可靠的、无序的通信协议。它的特点是传输速度快,但不保证数据的到达顺序和可靠性。UDP 协议以数据报作为数据传输的载体,在...

    进程间通信_socket_udp_非阻塞

    采用UDP方式的进程间通信模型,支持非阻塞,socket编程,采用select网络模型。 采用UDP方式的进程间通信模型,支持非阻塞,socket编程,采用select网络模型。 采用UDP方式的进程间通信模型,支持非阻塞,socket编程...

    深刻理解Linux进程间通信.pdf

    Unix环境下,进程间通信手段基本上是从平台上的进程通信手段继承而来的。而对Unix发展做出重大贡献的两大主力:贝尔实验室和加州大学伯克利分校,两者在进程间通信方面的侧重点不同。贝尔实验室对早期的进程间通信...

    Udp枢纽转发器v2.3

    可同时添加多条转发规则,实现UDP交通枢纽。单个exe文件,完全绿色,支持命令行参数、后台运行。 应用场景一:多个应用程序需要监听设备发来的UDP数据,但设备只能将数据发送到一个目标地址,这时可利用UDP枢纽转发...

    UNIX网络编程 第2卷 进程间通信.pdf(带书签)

    《UNIX网络编程 第2卷 进程间通信》是一本深入探讨UNIX环境下进程间通信机制的权威技术书籍。该书共分为四部分,涵盖了从基础套接口编程到高级套接口编程的多个方面,旨在为读者提供全面的进程间通信知识和编程实践...

    UNIX进程间通信(第二版)

    8. **套接字套件(Socket Families)**:包括AF_UNIX(本地进程间通信)、AF_INET(Internet协议家族,如TCP和UDP)等,每种套接字家族都定义了特定的通信协议和操作。 9. **进程间通信的限制与安全**:包括权限...

    Linux进程间通信方式之socket使用实例

    在现代操作系统中,进程间的通信(IPC)是实现多进程协同工作的重要手段之一。Linux提供了多种进程间通信的方法,包括信号量、消息队列、共享内存以及本文重点介绍的套接字(Socket)等。本文将详细讲解如何利用套接...

    操作系统进程间通信五种方式

    操作系统中的进程间通信(IPC,Inter-Process Communication)是实现多进程协同工作的重要手段,它允许不同进程之间共享数据和信息。本文将详细介绍五种主要的进程间通信方式:管道通信、消息队列通信、共享内存通信...

    udp数据包转发器-UDP协议

    1. **穿透NAT**:在存在网络地址转换(NAT)的环境中,UDP数据包转发器可以帮助两个不在同一网络的设备间建立通信。 2. **端口映射**:当需要将外网访问内网服务时,可以通过UDP转发器将外网请求映射到内网特定服务...

    unix进程间通信(第二版).rar

    在Unix操作系统中,进程间通信(IPC,Inter-Process Communication)是多个进程共享数据、协调工作的重要机制。Unix系统提供了多种IPC方式,包括管道、信号量、消息队列、共享内存、套接字等,每种方式都有其特定的...

    Qt_UDP通信,qt实现udp通信,C,C++

    在IT领域,网络通信是软件开发中的重要组成部分,而UDP(User Datagram Protocol)是一种无连接的、不可靠的传输协议,常用于实时性要求较高的应用,如在线视频、语音通话等。Qt是一个跨平台的C++图形用户界面应用...

Global site tag (gtag.js) - Google Analytics