java socket 传送字节流(前后台)


因为考虑到数据传送的安全性.所以,用字节流进行socket的传输..例子如下:

客户端:

//获得流
byteOut = new ByteArrayOutputStream();
out = new DataOutputStream(byteOut);
    
//转为字节流
byte[] messes=message.getBytes("GBK");
//获得长度
int length=messes.length;
    
//把欲发送的长度转换成字节流
byte[] lengthbytes = ByteUtil.integerToBytes(length, 4);
    
//System.out.println("将要写过去的数据为:"+messes.length);
    
System.out.println("开始写socket到后台============================");
   
//把长度写过去
byteOut.write(lengthbytes);
//把内容写过去
byteOut.write(messes);
    
out.flush();    

附ByteUtil方法:

public static byte[] integerToBytes(int integer, int len) {
//   if (integer < 0) { throw new IllegalArgumentException("Can not cast negative to bytes : " + integer); }
   ByteArrayOutputStream bo = new ByteArrayOutputStream();
   for (int i = 0; i < len; i ++) {   
    bo.write(integer);
    integer = integer >> 8;
   }
   return bo.toByteArray();
}


服务端:

DataInputStream in = new DataInputStream(receiver.getSocket()
     .getInputStream());

//读取长度
int len=ByteUtil.bytesToInteger(ByteUtil.readBytes(in,4));


//读取内容
String mess = new String(ByteUtil.readBytes(in, len)).trim();


附换转读取方法:
public static byte[] readBytes(InputStream in, long length) throws IOException {
   ByteArrayOutputStream bo = new ByteArrayOutputStream();
   byte[] buffer = new byte[1024];
   int read = 0;
   while (read < length) {
    int cur = in.read(buffer, 0, (int)Math.min(1024, length - read));
    if (cur < 0) { break; }
    read += cur;
    bo.write(buffer, 0, cur);
   }
   return bo.toByteArray();
}

public static int bytesToInteger(byte[] bytes)
{ return bytesToInteger(bytes, 0, bytes.length); }

这样写的socket程序的可容错性会更强.

http://hi.baidu.com/qinghua9/blog/item/71109422a9ae8dfbd7cae288.html

使用 C# 和 Java 实现 Socket 传输 Protobuf 字节流的过程可以分为以下几个步骤: 1. 定义 Protobuf 消息结构 首先,需要使用 Protocol Buffers 定义消息结构。假设我们要传输的消息结构如下: ``` message Person { string name = 1; int32 age = 2; repeated string phone_number = 3; } ``` 2. 生成代码 使用 protobuf 编译器生成 C# 和 Java 的代码,方法如下: ``` protoc --csharp_out=. person.proto protoc --java_out=. person.proto ``` 3. C# 实现 Socket 发送 首先,在 C# 中创建一个 `Person` 对象,并将其序列化为字节数组,然后将其发送到 Java 服务器: ```csharp using System; using System.Net.Sockets; using Google.Protobuf; class Program { static void Main(string[] args) { // 创建 Person 对象 var person = new Person { Name = "张三", Age = 18, PhoneNumber = { "123456789", "987654321" } }; // 将 Person 对象序列化为字节数组 byte[] data = person.ToByteArray(); // 创建 Socket 连接 var socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp); socket.Connect("127.0.0.1", 8888); // 发送数据 socket.Send(data); // 关闭连接 socket.Shutdown(SocketShutdown.Both); socket.Close(); } } ``` 4. Java 实现 Socket 接收 在 Java 中,我们需要创建一个 `ServerSocket`,并监听指定的端口。当有连接请求时,我们可以使用 `Socket` 接收数据,并将其反序列化为 `Person` 对象: ```java import com.example.PersonOuterClass.Person; import com.google.protobuf.InvalidProtocolBufferException; import java.io.IOException; import java.net.ServerSocket; import java.net.Socket; public class Main { public static void main(String[] args) throws IOException { // 创建 ServerSocket,监听指定端口 ServerSocket serverSocket = new ServerSocket(8888); while (true) { // 等待连接 Socket socket = serverSocket.accept(); // 读取数据 byte[] buffer = new byte[socket.getInputStream().available()]; socket.getInputStream().read(buffer); try { // 将字节数组反序列化为 Person 对象 Person person = Person.parseFrom(buffer); System.out.println(person); } catch (InvalidProtocolBufferException e) { e.printStackTrace(); } // 关闭连接 socket.shutdownInput(); socket.close(); } } } ``` 这样,就完成了 C# 和 Java 之间通过 Socket 传输 Protobuf 字节流的实例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值