serverSocket编程DEMO

本文介绍了使用Java实现的TCP服务器端,通过ServerSocket监听客户端连接,SocketRunnable处理每个连接并执行SQL插入任务。还涉及了使用tomcatJdbcPool进行数据库连接的懒汉式初始化。客户端通过Socket发送数据并接收响应。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

0、jar包依赖

1、ServerSocket服务端主程序:

2、任务执行类

3、tomcatJdbcPool:

4、客户端:


0、jar包依赖

1、ServerSocket服务端主程序:

package socket;

import java.net.ServerSocket;
import java.net.Socket;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
/**
 * 服务端,主程序。
 * @author Administrator
 *
 */
public class M {

	public static void main(String[] args) throws Exception {
		
		@SuppressWarnings("resource")
		ServerSocket serverSocket = new ServerSocket(2001);
		ExecutorService pool = Executors.newFixedThreadPool(10);
		while(true) {
			Socket socket = serverSocket.accept();
			SocketRunnable socketRunnable = new SocketRunnable(socket);
			pool.submit(socketRunnable);
		}
		
	}

}

2、任务执行类

package socket;

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.Socket;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
/**
 * 任务执行类
 * @author Administrator
 *
 */
public class SocketRunnable implements Runnable {
	
	Socket socket;
	

	public SocketRunnable(Socket socket) {
		super();
		this.socket = socket;
	}


	@Override
	public void run() {
		InputStream inputStreamServer;
		try {
			//InputStream相当于从客户端获得数据,OutputStream相当于向客户端发送数据
			inputStreamServer = socket.getInputStream();
			byte[] data = new byte[1024];
			//将读取的内容存储到字节数组中,返回值是存储的字节数
			int length = inputStreamServer.read(data);
			String plcStr = new String(data, 0, length);
			System.out.println("Client:" + plcStr);
			// 添加数据入库的逻辑
			try {
				Connection connection = JdbcPool.getConnection();
				String sql = "insert into plc_source_string(str,createTime) values (?,now())";
				PreparedStatement statement = connection.prepareStatement(sql);
				statement.setString(1, plcStr);
				statement.execute();
				statement.close();
//				connection.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}
			socket.shutdownInput();
			OutputStream outputStream = socket.getOutputStream();
			outputStream.write("OK".getBytes());
			socket.shutdownOutput();
			socket.close();
		} catch (IOException e) {
			e.printStackTrace();
		}
		

	}

}

3、tomcatJdbcPool:

package socket;

import java.sql.Connection;
import java.sql.SQLException;

import org.apache.tomcat.jdbc.pool.DataSource;
/**
 * jdbc工具类
 * @author Administrator
 *
 */
public class JdbcPool {
	
	private static volatile DataSource dataSource;
	/**
	 * 懒汉式(双重检查)
	 * @return
	 * @throws SQLException
	 */
	public static Connection getConnection() throws SQLException {
		if(dataSource == null) {
			synchronized (DataSource.class) {
				if(dataSource == null) {
					dataSource = new DataSource();
					dataSource.setUrl("jdbc:mysql://127.0.0.1:3306/plc?characterEncoding=UTF8");
					dataSource.setUsername("root");
					dataSource.setPassword("111111");
					dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver");
				}
			}
		}
		return dataSource.getConnection();
	}
	
}

4、客户端:

package socket;

import java.io.InputStream;
import java.io.OutputStream;
import java.net.Socket;
/**
 * 客户端请求
 * @author Administrator
 *
 */
public class Client {

	public static void main(String[] args) throws Exception {
		String ip ="127.0.0.1";
		Socket client = new Socket(ip, 2001);
		OutputStream outputStream = client.getOutputStream();
		
		outputStream.write("347257538620230731103452|1|1,6,7,2|0|4.0|25|OK".getBytes());
		InputStream inputStream = client.getInputStream();
		byte[] b = new byte[1024];
		int read = inputStream.read(b);
		System.out.println(""+new String(b,0,read));
		outputStream.flush();
		client.shutdownOutput();
		client.close();
	}

}

参考文献:

Java — TCP & Socket - 知乎

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值