利用socket进行远程过程调用

  • ServiceServer 服务端,一开始启动这个
package com.huachao.socket;

import java.net.InetSocketAddress;
import java.net.ServerSocket;
import java.net.Socket;

public class ServiceServer {
    public static void main(String[] args) throws Exception {
        //创建一个ServerSocket
        ServerSocket server = new ServerSocket();
        //绑定到本机的8899端口
        server.bind(new InetSocketAddress("localhost", 8899));
        //接收客户端请求
        //accept是一个阻塞方法,会一直等待,到有客户端请求连接才返回
        
        
        while(true){
            Socket socket = server.accept();
            new Thread(new ServiceServerTask(socket)).start();
        }
        
    }
}
  • 子线程,调用getData,返回调用结果
package com.huachao.socket;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.Socket;

public class ServiceServerTask implements Runnable{
    private Socket socket;
    public ServiceServerTask(Socket socket) {
        this.socket = socket;
    }
    //业务逻辑:跟客户端进行数据交互
    @Override
    public void run() {
        InputStream in = null;
        OutputStream out = null;
        try {
            in = socket.getInputStream();
            out = socket.getOutputStream();
            
            BufferedReader br = new BufferedReader(new InputStreamReader(in));
            PrintWriter pw = new PrintWriter(out);
            
            
            //从网络通信输入流中读取客户端发送过来的数据
            //注意:socketinputstream的读数据的方法都是阻塞的
            String param = br.readLine();
            /**
             * 作业:
             * 将以下业务调用逻辑写成更加通用的:可以根据客户端发过来的调用类名、调用方法名、调用该参数来灵活调用
             * 
             * 《反射》
             * 
             */
            GetDataServiceImpl impl = new GetDataServiceImpl();
            String result = impl.getData(param);
            
            
            pw.println(result);
            pw.flush();
            
            
        } catch (IOException e) {
            e.printStackTrace();
        }finally {
            try {
                in.close();
                out.close();
                socket.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
    
}
  • 被远程调用的方法
package com.huachao.socket;

public class GetDataServiceImpl {
    public String getData(String param){
        return "ok-"+param;
    }
}
  • ServiceClient 客户端
package com.huachao.socket;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.Socket;

public class ServiceClient {
    public static void main(String[] args) throws Exception {
        Socket socket = new Socket("localhost", 8899);
        InputStream in = socket.getInputStream();
        OutputStream out = socket.getOutputStream();
        
        PrintWriter pw = new PrintWriter(out);
        pw.println("hello");
        pw.flush();

        BufferedReader br = new BufferedReader(new InputStreamReader(in));
        String result = br.readLine();
        System.out.println(result);
        
        in.close();
        out.close();
        socket.close();
        
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,188评论 19 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 33,607评论 18 399
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,637评论 25 709
  • 今天是羊年大点三十,明天就是猴年。没想到今天胡欣流产了。中午胡欣说肚子痛,还流了血。稍稍收拾了一下就去了医院。在急...
    小王加油啊阅读 1,886评论 0 0
  • 原兄难追忆,非我知者谁? 若可早华年,称兄并进退。 此局无容处,但愿生死随。 少友黑白面,兽禽无可窜。
    沐梵晟阅读 1,378评论 0 2

友情链接更多精彩内容