Java Socket应用(六)——服务器响应客户端

转载请注明:http://blog.csdn.net/uniquewonderq

通过输入流来读取客户端信息,相应的时候通过输出流来实现。

服务端类的代码:

package com.test;

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.ServerSocket;
import java.net.Socket;
import java.util.logging.Level;
import java.util.logging.Logger;

/**
 *
 * @author wonderq
 */
public class server {//服务器端
    public static void main(String[] args) {
        try {
            //1.创建一个服务器端Socket,即serverSocket,指定绑定的端口,并监听此端口。
            ServerSocket serverSocket=new ServerSocket(8888);
            //2.调用serverSocket的accept()方法,等待客户端的连接
            System.out.println("==服务器即将启动,等待客户端的连接==");
            Socket socket=serverSocket.accept();
            //3.获取输入流用来读取客户端所发出的登录信息
            InputStream is=socket.getInputStream();//字节输入流
            InputStreamReader isr=new InputStreamReader(is);//将字节流转化为字符流
            //为字符流添加缓冲
            BufferedReader bufferedReader=new BufferedReader(isr);
            String info=null;
            //循环读取客户端提交的信息
            while((info=bufferedReader.readLine())!=null){
                System.out.println("我是服务器,客户端提交的信息是:"+info);
            }
            socket.shutdownInput();
            //4.获取输出流,响应客户端的请求
               OutputStream os= socket.getOutputStream();
               PrintWriter pw=new PrintWriter(os);//转化为打印流
               pw.write("欢迎您!");
               pw.flush();//刷新缓存
                //5.关闭相关的资源
            bufferedReader.close();
            is.close();
            isr.close();
            socket.close();
            serverSocket.close();
            os.close();
            pw.close();
        } catch (IOException ex) {
            Logger.getLogger(server.class.getName()).log(Level.SEVERE, null, ex);
        }
    }
}

客户端类的代码:

package com.test;

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;
import java.util.logging.Level;
import java.util.logging.Logger;

/**
 *
 * @author wonderq
 */
public class client {//客户端
    public static void main(String[] args) {
        try {
            //1.创建客户端Socket,指定服务器地址和端口号
            Socket socket=new Socket("127.0.0.1", 8888);
            //2.获取输出流,用来向服务器发送信息
              OutputStream os=socket.getOutputStream();//字节输出流
              //转换为打印流
              PrintWriter pw=new PrintWriter(os);
              pw.write("用户名:wonderq;密码:root");
              pw.flush();//刷新缓存,向服务器端输出信息
              //关闭输出流
              socket.shutdownOutput();
              //3.获取输入流,用来读取服务器端的响应信息
              InputStream is=socket.getInputStream();
              BufferedReader br=new BufferedReader(new InputStreamReader(is));
              String info=null;
            while((info=br.readLine())!=null){
                System.out.println("我是客户端,服务器端返回的信息是:"+info);
            }
              //4.关闭资源
              br.close();
              is.close();
              pw.close();
              os.close();
              socket.close();
        } catch (IOException ex) {
            Logger.getLogger(client.class.getName()).log(Level.SEVERE, null, ex);
        }
    }
}

还是先运行服务器端类,之后再运行客户端类:

服务器端类输出结果:

客户端类的输出结果:

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-08-02 21:46:24

Java Socket应用(六)——服务器响应客户端的相关文章

python socket之tcp服务器与客户端demo

python socket之tcp服务器与客户端demo 作者:vpoet 日期:夏季 server: # -*- coding: cp936 -*- ''' 建立一个python server,监听指定端口, 如果该端口被远程连接访问,则获取远程连接,然后接收数据, 并且做出相应反馈. ''' import socket if __name__=="__main__": print "Server is starting" sock = socket.socket

socket编程之服务器和客户端

服务端和客户端就像银行出纳员和客户样,一个银行出纳员(服务器),不吃不睡的服务排队的客户,每个客户都会有要解决的问题,一旦完成,客户就会走开,出纳员等待下一个客户的到来. 服务器端: from socket import * from time import ctime HOST = '' #空白,是对bind方法的标识,可以使用任何可用的地址 PORT = 21567 BUFSIZ = 1024 #缓冲区大小设为1kb ADDR = (HOST, PORT) tcpSerSock = sock

Java Socket 死循环while如何判断客户端断开

多线程的服务器程序 线程中等待客户端的消息 部分代码如下:      boolean done=clientRequest.isConnected();//判断客户端Socket是否连接        while(done)//客户端是连接的    {         try {    input = clientRequest.getInputStream();    Binput = new BufferedInputStream(input);    str = "" + Bin

关于优化游戏服务器响应客户端消息的一点思考

现在假设有如下构建的游戏服务器,游戏服务器有一组gate服务器,用来验证客户端,并且通过gate服务器来与一组主服务器,然后主服务器与关系服务器进行通信. 其中relation服务器用来处理各种关系,例如好友关系,师徒关系等.现在有一个玩家A添加玩家B为好友,那么客户端发送给服务端的消息流程如上所示.首先gate收到客户端消息,进行验证等,然后转发给Main1服务器, 这里假设玩家A的信息存储在Main1服务器上,然后Main1服务器检测玩家A的各种要求,如果满足要求,则将消息转发给Main2服

socket,实现服务器和客户端对话

服务器: #define _CRT_SECURE_NO_WARNINGS#include<stdio.h>#include<string>#include<WinSock2.h> //网络库用2.2版本 目前系统的最高版本#pragma comment(lib,"Ws2_32.lib") //加载动态连接库 x32.x64都是用ws2_32.lib这一个版本//上面为第二版 第一版头文件为WinSock.h 动态库为wsock32.libusing

JAVA基础篇—模拟服务器与客户端通信

第一种: 客户端class Client package 服务器发送到客户端; import java.io.BufferedReader; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.Socket; public class Client { public static void main(String[] args) { try { Socket socket=new Socket

C# Socket通信的服务器与客户端

客户端代码: using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Net; using System.Net.Sockets; using System.Threading; namespace ClientSocket { class Program { private static byte[] result = new byte[1024]; s

java Socket 长连接 心跳包 客户端 信息收发 demo

今天写了个socket的测试小程序,代码如下 import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.net.Socket; import java.net.UnknownHostException; /** * @author 某家: * @version 创建时间:2015年8月17日 下午3:04:14 * 类说明 */ public class Con

盘点用Java抓取HTTP服务器和FTP服务器的网页数据或图片等数据的实用技巧

摘要 在信息时代,常常需要通过编程的方式来灵活整理各种网络数据.首先涉及到如何方便准确地抓取网络数据.下面盘点用Java程序来访问HTTP服务器以及FTP服务器的各种实用技巧.主要介绍了Java Socket.java.net.URL类.Selenuim软件包.Apache HttpClients.Apache FTPClient来和HTTP服务器以及FTP服务器通信的方法以及其优缺点. 参考资料 (1)本文参考了笔者所写的<Java网络编程核心技术详解>,2020年上半年出版. (2)Jav