java socket client

用tornado做了个socket server。无奈联调的人员对接不上。

于是撸出了以下demo

import java.io.*;
import java.net.*;

public class SocketTest{
    SocketTest(){}
    void test()
    {
        try{
            Socket requestSocket = new Socket("xxx.xxx.xxx.xxx", 60006);
            OutputStream out = requestSocket.getOutputStream();
            InputStream in = requestSocket.getInputStream();

            byte[] bb = new byte[16] ;
            for(int i =0;i<13;i++)
            {
                bb[i+3]=(byte)((int)‘a‘+i);
            }
            bb[0]=(byte)0x00;
            bb[1]=(byte)0x0e;
            bb[2]=(byte)0xaa;
            bb[15]=(byte)0xfe;
            System.out.println("client>"+new String(bb));

            out.write(bb);
            out.flush();

            byte[] buffer = new byte[1024];
            in.read(buffer);
            String responseStr = new String(buffer);
            System.out.println("server>"+responseStr);

            out.close();
            in.close();

            requestSocket.close();
        }
        catch(IOException ioException){
            ioException.printStackTrace();
        }
        // catch(ClassNotFoundException classNot){
        //     System.err.println("data received in unknown format");
        // }

    }

    public static void main(String args[])
    {
        SocketTest client = new SocketTest();
        client.test();
    }
}

既要:

1. linux 下编译执行的细节:

javac SocketTest.java

java SocketTest  (不要 java SocketTest.class, 不然一大堆误导加麻烦)

2. 字节操作,在java里面用byte数组,不要担心(128~255)溢出。直接赋值即可。

byte b = (byte)254;

3. 从socket得到原始的输入输出流,不要再用其他包裹,否则会出现诡异的事情。

OutputStream out = requestSocket.getOutputStream();

InputStream in = requestSocket.getInputStream();

时间: 2024-10-26 05:10:41

java socket client的相关文章

Java Socket网络编程Client端详解

此类实现客户端套接字(也可以就叫“套接字”).套接字是两台机器之间的通信端点. Socket client = new Socket(ip,port);//创建一个流套接字并将其连接到指定 IP 地址的指定端口号. 以下为完整的客户端示例: SocketClientDemo.java public class SocketClientDemo { /** * 向指定的地址发送请求数据 * @param ipAddr * @param reqData */ public void sendReq(

Java设置Client Socket链接Server超时时间

Java设置Client Socket链接Server超时时间 学习了:http://blog.csdn.net/tterminator/article/details/52494141 http://blog.csdn.net/fw0124/article/details/41227543 整理如下: Socket client = null; // 创建一个流套接字,连接到指定主机上的指定端口号 // client = new Socket(IP, PORT); client = new S

java socket编程中backlog的含义(zz)

使用Java.NET.ServerSocket能够方便的创建一个服务端套接字,这个类的构造函数有一个参数backlog.下面这段代码,在本机的8888端口上建立了一个套接字,backlog设置为5. [java] view plain copy // port:8888,backlog:5 ServerSocket server = new ServerSocket(8888, 5); 下面的Client是我们的测试类,会创建30个socket连接. [java] view plain copy

java socket编程实例代码讲解

1.所谓socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄.应用程序通常通过"套接字"向网络发出请求或者应答网络请求. 操作java socket时用到的最多的三个方法为: accept():主要用于服务器端产生"阻塞",等待客户端的链接请求,并且返回一个客户端的Socket实例: getInputStream():方法主要用来获得网络连接输入,同时返回一个InputStream对象实例: getOutputStream

Java Socket 编程

1. 背景 网络编程是指编写运行在多个设备(计算机)的程序,这些设备都通过网络连接起来. java.net 包中 J2SE 的 API 包含有类和接口,它们提供低层次的通信细节.你可以直接使用这些类和接口,来专注于解决问题,而不用关注通信细节. java.net 包中提供了两种常见的网络协议的支持: TCP:TCP 是传输控制协议的缩写,它保障了两个应用程序之间的可靠通信.通常用于互联网协议,被称 TCP / IP. UDP:UDP 是用户数据报协议的缩写,一个无连接的协议.提供了应用程序之间要

java socket编程基础(转)

一,网络编程中两个主要的问题 一个是如何准确的定位网络上一台或多台主机,另一个就是找到主机后如何可靠高效的进行数据传输. 在TCP/IP协议中IP层主要负责网络主机的定位,数据传输的路由,由IP地址可以唯一地确定Internet上的一台主机. 而TCP层则提供面向应用的可靠(tcp)的或非可靠(UDP)的数据传输机制,这是网络编程的主要对象,一般不需要关心IP层是如何处理数据的. 目前较为流行的网络编程模型是客户机/服务器(C/S)结构.即通信双方一方作为服务器等待客户提出请求并予以响应.客户则

Java Socket编程

对于Java Socket编程而言,有两个概念,一个是ServerSocket,一个是Socket.服务端和客户端之间通过Socket建立连接,之后它们就可以进行通信了.首先ServerSocket将在服务端监听某个端口,当发现客户端有Socket来试图连接它时,它会accept该Socket的连接请求,同时在服务端建立一个对应的Socket与之进行通信.这样就有两个Socket了,客户端和服务端各一个. 客户端写服务端读 服务端代码 public class Server { public s

JAVA通信系列一:Java Socket技术总结

本文是学习java Socket整理的资料,供参考. 1       Socket通信原理 1.1     ISO七层模型 1.2     TCP/IP五层模型 应用层相当于OSI中的会话层,表示层,应用层. 区别参考:http://blog.chinaunix.net/uid-22166872-id-3716751.html 1.3     TCP报文 (1)序号:Seq序号,占32位,用来标识从TCP源端向目的端发送的字节流,发起方发送数据时对此进行标记. (2)确认序号:Ack序号,占32

Java Socket长连接示例代码

SocketListenerPusher.java代码如下: Java代码   import java.io.IOException; import java.net.InetSocketAddress; import java.net.ServerSocket; import java.net.Socket; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import ja