JAVA网络编程

1.Server端代码

package TCP;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.ServerSocket;
import java.net.Socket;
import java.net.SocketTimeoutException;

public class Server {
	
	private Socket socket;
	private ServerSocket server;
	private BufferedReader reader;
	
	public static void main(String[] args) {
		new Server().getServer();
	}
	
	void getServer(){
		try{
			server = new ServerSocket(8888);
			server.setSoTimeout(1000*1000);
			
			System.out.println("服务器套接字创建成功...");
			while(true){
				System.out.println("等待客户端连接...");
				socket = server.accept();
				reader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
				getClientMessage();
			}
			
		}catch(SocketTimeoutException e){
			System.out.println("超时啦!!!");
		}catch(Exception e){
			System.out.println("创建套接字失败...");
			e.printStackTrace();
		}
	}

	private void getClientMessage() {
		 try{
			 while(true){
				 System.out.println("客户机:"+reader.readLine());
			 }
		 }catch(Exception e){
			 	e.printStackTrace();
		 }
		
		 try{
			 if(reader != null){
				 reader.close();
			 }
			 if(socket != null){
				 socket.close();
			 }
		 }catch(Exception e){
			 e.printStackTrace();
		 }
	}
	
}



2.Client端代码

package TCP;

import java.awt.Container;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.PrintWriter;
import java.net.InetAddress;
import java.net.Socket;

import javax.swing.JFrame;
import javax.swing.JTextArea;
import javax.swing.JTextField;

public class Client extends JFrame{
	private PrintWriter writer;
	Socket socket;
	private JTextArea ta = new JTextArea();
	private JTextField tf = new JTextField();
	Container cc;
	
	public static void main(String[] args) {
		Client c = new Client("向服务器发送数据");
		c.setBounds(300,300,300,300);
		
		c.setVisible(true);
		c.connect();
	}
	
	public Client(String s) {
			super(s);
			cc = this.getContentPane();
			cc.add(ta, "North");
			cc.add(tf, "South");
			tf.addActionListener(new ActionListener() {
				
				@Override
				public void actionPerformed(ActionEvent e) {
						writer.println(tf.getText());
						ta.append(tf.getText()+'\n');
						tf.setText(" ");
				}
			});
	}
			
			private void connect(){
				ta.append("尝试连接\n");
				try{
					socket = new Socket("192.168.21.1",8888);
					writer = new PrintWriter(socket.getOutputStream(),true);
					ta.append("完成连接\n");
					
					InetAddress netAddress = socket.getInetAddress();
					System.out.println(netAddress.getHostAddress());
					System.out.println(socket.getPort());
					
				}catch(Exception e){
					e.printStackTrace();
				}
			}
	 
	
}

一、TCP部分

1)核心类

2)核心API

二、UDP部分

1)核心类

2)核心API

三、

资源下载链接为: https://pan.quark.cn/s/3d8e22c21839 随着 Web UI 框架(如 EasyUI、JqueryUI、Ext、DWZ 等)的不断发展与成熟,系统界面的统一化设计逐渐成为可能,同时代码生成器也能够生成符合统一规范的界面。在这种背景下,“代码生成 + 手工合并”的半智能开发模式正逐渐成为新的开发趋势。通过代码生成器,单表数据模型以及一对多数据模型的增删改查功能可以被直接生成并投入使用,这能够有效节省大约 80% 的开发工作量,从而显著提升开发效率。 JEECG(J2EE Code Generation)是一款基于代码生成器的智能开发平台。它引领了一种全新的开发模式,即从在线编码(Online Coding)到代码生成器生成代码,再到手工合并(Merge)的智能开发流程。该平台能够帮助开发者解决 Java 项目中大约 90% 的重复性工作,让开发者可以将更多的精力集中在业务逻辑的实现上。它不仅能够快速提高开发效率,帮助公司节省大量的人力成本,同时也保持了开发的灵活性。 JEECG 的核心宗旨是:对于简单的功能,可以通过在线编码配置来实现;对于复杂的功能,则利用代码生成器生成代码后,再进行手工合并;对于复杂的流程业务,采用表单自定义的方式进行处理,而业务流程则通过工作流来实现,并且可以扩展出任务接口,供开发者编写具体的业务逻辑。通过这种方式,JEECG 实现了流程任务节点和任务接口的灵活配置,既保证了开发的高效性,又兼顾了项目的灵活性和可扩展性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值