经典 socket通讯 -- 已验证

[tcp通信]

来源:不详;

client:

  1. package com.defonds.socket.begin;
  2. import java.io.BufferedReader;
  3. import java.io.DataInputStream;
  4. import java.io.DataOutputStream;
  5. import java.io.IOException;
  6. import java.io.InputStreamReader;
  7. import java.net.Socket;
  8. public class Client {
  9. public static final String IP_ADDR = "localhost";//服务器地址
  10. public static final int PORT = 12345;//服务器端口号
  11. public static void main(String[] args) {
  12. System.out.println("客户端启动...");
  13. System.out.println("当接收到服务器端字符为 \"OK\" 的时候, 客户端将终止\n");
  14. while (true) {
  15. Socket socket = null;
  16. try {
  17. //创建一个流套接字并将其连接到指定主机上的指定端口号
  18. socket = new Socket(IP_ADDR, PORT);
  19. //读取服务器端数据
  20. DataInputStream input = new DataInputStream(socket.getInputStream());
  21. //向服务器端发送数据
  22. DataOutputStream out = new DataOutputStream(socket.getOutputStream());
  23. System.out.print("请输入: \t");
  24. String str = new BufferedReader(new InputStreamReader(System.in)).readLine();
  25. out.writeUTF(str);
  26. String ret = input.readUTF();
  27. System.out.println("服务器端返回过来的是: " + ret);
  28. // 如接收到 "OK" 则断开连接
  29. if ("OK".equals(ret)) {
  30. System.out.println("客户端将关闭连接");
  31. Thread.sleep(500);
  32. break;
  33. }
  34. out.close();
  35. input.close();
  36. } catch (Exception e) {
  37. System.out.println("客户端异常:" + e.getMessage());
  38. } finally {
  39. if (socket != null) {
  40. try {
  41. socket.close();
  42. } catch (IOException e) {
  43. socket = null;
  44. System.out.println("客户端 finally 异常:" + e.getMessage());
  45. }
  46. }
  47. }
  48. }
  49. }
  50. }

服务端:

  1. package com.defonds.socket.begin;
  2. import java.io.BufferedReader;
  3. import java.io.DataInputStream;
  4. import java.io.DataOutputStream;
  5. import java.io.InputStreamReader;
  6. import java.net.ServerSocket;
  7. import java.net.Socket;
  8. public class Server {
  9. public static final int PORT = 12345;//监听的端口号
  10. public static void main(String[] args) {
  11. System.out.println("服务器启动...\n");
  12. Server server = new Server();
  13. server.init();
  14. }
  15. public void init() {
  16. try {
  17. ServerSocket serverSocket = new ServerSocket(PORT);
  18. while (true) {
  19. // 一旦有堵塞, 则表示服务器与客户端获得了连接
  20. Socket client = serverSocket.accept();
  21. // 处理这次连接
  22. new HandlerThread(client);
  23. }
  24. } catch (Exception e) {
  25. System.out.println("服务器异常: " + e.getMessage());
  26. }
  27. }
  28. private class HandlerThread implements Runnable {
  29. private Socket socket;
  30. public HandlerThread(Socket client) {
  31. socket = client;
  32. new Thread(this).start();
  33. }
  34. public void run() {
  35. try {
  36. // 读取客户端数据
  37. DataInputStream input = new DataInputStream(socket.getInputStream());
  38. String clientInputStr = input.readUTF();//这里要注意和客户端输出流的写方法对应,否则会抛 EOFException
  39. // 处理客户端数据
  40. System.out.println("客户端发过来的内容:" + clientInputStr);
  41. // 向客户端回复信息
  42. DataOutputStream out = new DataOutputStream(socket.getOutputStream());
  43. System.out.print("请输入:\t");
  44. // 发送键盘输入的一行
  45. String s = new BufferedReader(new InputStreamReader(System.in)).readLine();
  46. out.writeUTF(s);
  47. out.close();
  48. input.close();
  49. } catch (Exception e) {
  50. System.out.println("服务器 run 异常: " + e.getMessage());
  51. } finally {
  52. if (socket != null) {
  53. try {
  54. socket.close();
  55. } catch (Exception e) {
  56. socket = null;
  57. System.out.println("服务端 finally 异常:" + e.getMessage());
  58. }
  59. }
  60. }
  61. }
  62. }
  63. }
时间: 2024-10-11 13:13:31

经典 socket通讯 -- 已验证的相关文章

Protobuf实现Android Socket通讯开发教程

本节为您介绍Protobuf实现Android Socket通讯开发教程,因此,我们需要先了理一下protobuf 是什么? Protocol buffers是一种编码方法构造的一种有效而可扩展的格式的数据. 谷歌使用其内部几乎RPC协议和文件格式的所有协议缓冲区. protobuf 适用的语言 正宗(Google 自己内部用的)的protobuf支持三种语言:Java .c++和Pyton,很遗憾的是并不支持.Net 或者 Lua 等语言,但社区的力量是不容忽视的,由于protobuf确实比J

Socket通讯探索(二)-socket集群

前面我们在章节“Socket通讯探索(一)”中如何实现一个tcp连接,但是这仅仅是一个最初级的BIO实现,且没有添加线程池,实际应用中很少采用这种方式,因为不得不考虑当大量的Tcp连接建立的时候,服务端如何安全稳定的运行?为什么呢? 1.BIO实现方式,是阻塞式的(上一节最后面的实现方式虽然无数据的时候,不会阻塞): 2.服务端为每条连接都开辟了一个线程进行处理,而且在连接不断开的情况下,线程不会得到释放: 基于以上情况,当有大量的连接建立的时候,服务端会开辟大量的线程处理并得不到释放,而线程会

客户端技术的一点思考(数据存储用SQLite, XMPP通讯用Gloox, Web交互用LibCurl, 数据打包用Protocol Buffer, socket通讯用boost asio)

今天看到CSDN上这么一篇< 彻底放弃没落的MFC,对新人的忠告!>, 作为一个一直在Windows上搞客户端开发的C++程序员,几年前也有过类似的隐忧(参见 落伍的感觉), 现在却有一些不同的想法. 首先,个人职业发展是否成功, 技术只是其中一小块,尤其是在大公司, 更多的是依靠所谓的软实力.作为一个对技术有追求的工匠,我们下面重点说技术相关的. 现在回头看计算机行业的发展,我们看到不同的发展阶段: 1. PC时代,这个时代离我们并不遥远, 也有是2000年前后, 该时代最鲜明的特征是Win

iOS开发socket通讯

写写socket通讯那些事儿.     socket通讯公司用于给服务器发一些指令用于控制智能家居类的设备.socket无非就是发过来发过去,至于具体内容跟服务器协商就好.接下来先说说与socket通讯配合使用的socket Tool 的mac 工具.首先打开工具(工具连接以及socket用到的文件:SocketToolfor_mac_and_Third_for_xocde_socket.zip)选择Tcp Server 然后点击创建 端口号输入一个数字,60000 把. 注意可能完成之后这个数

试解析Tomcat运行原理(一)--- socket通讯

关于这篇文章也确实筹划了很久,今天决定开篇写第一篇,说起tomcat首先很容易联想到IIS,因为我最开始使用的就是.net技术,我第一次使用asp写学生成绩管理系统后,很茫然如何让别人都能看到或者说使用这个系统呢?由此认识了IIS,它是一个web容器,天生的多线程,及时响应用户提交的请求返回html页面,这就是我了解的最初的web容器的功能,由此我们来认识tomcat也并不困难,可以的话,在了解完tomcat后我们可以继续了解jboss.jetty等,好我们进入主题. 我们在平时开发的过程中是在

[Erlang之旅 0009] socket 通讯

前面学习完了gen_server .gen_tcp 现在做一个简易的socket通讯,服务端将接收到的信息返回给客户端,具体代码如下: 服务端: 1 -module(tcp_socket3). 2 -behaviour(gen_server). 3 4 -export([start/0, login/2, stop/0]). 5 -export([init/1, handle_call/3, handle_cast/2, handle_info/2, terminate/2, code_chan

c# TCP Socket通讯基础

在做网络通讯方面的程序时,必不可少的是Socket通讯. 那么我们需要有一套既定的,简易的通讯流程. 如下: <pre name="code" class="csharp">public class PublicSocket { public const string DOWNLOAD_STATUS_WAIT = "1"; public const string DOWNLOAD_STATUS_PAUSE = "2"

windows 与 Linux SOCKET通讯

? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 windows client 端口 // Def_win_client_socket_test.cpp :

mac下升级ruby(已验证)

在lion下安装rails会提示你的ruby版本为1.8.7,而新版本的rails3.x需要1.9.x的ruby支持. 所以,必须对ruby进行升级,经过各种凌乱和不成功终于摸索出经验.现在记录一下. 通过app store安装xcode xcode安装好后,打开xcode 选择preferences 选择downloads选项卡 安装command line tools(因为终端里没有gcc的编译环境) 打开终端输入下面两条命令(安装rvm,ruby多版本控制器,通过rvm安装最新版本的rub