Java的编程(socket和JDBC)

1.利用Socket编写一个服务器端程序和一个客户端程序,要求服务器端程序运行后监听指定端口,检测到客户端程序连接并发来数据后,服务器端对该数据进行处理并传回客户端一段信息。

2.安装并配置MySQL数据库,并准备好JDBC所需驱动。利用SQL语句创建“JDBCTest”库、“website”表。其中,要求“website”表至少含有如下字段:name(站点名称,字符型)、alexa(Alexa排名,整型)、country(所属国家字符型)。

3.利用JDBC编程,向website表中增添数据。利用JDBC编程,获取website表的所有数据并输出。

4.利用1-3题内容,将第1题的服务器改写升级,使之可以保存客户端的发来的数据。

求写法🥹

public class SocketService {
    public static void main(String[] args) throws IOException{
        SocketService socketService = new SocketService();
        socketService.oneServer();
    }
    
    public  void oneServer(){
        try{
            ServerSocket server=null;
            try{
                server=new ServerSocket(5200);
                System.out.println("server start is ok...");
                //创建一个ServerSocket在端口5200监听客户请求
            }catch(Exception e) {
                    System.out.println("can not listen to:"+e);
                    //出错,打印出错信息
            }
            Socket socket=null;
            try{
                socket=server.accept();
                //使用accept()阻塞等待客户请求,有客户
                //请求到来则产生一个Socket对象,并继续执行
            }catch(Exception e) {
                System.out.println("Error."+e);
                //出错,打印出错信息
            }
            String line;
            BufferedReader in=new BufferedReader(new InputStreamReader(socket.getInputStream()));
            //由Socket对象得到输入流,并构造相应的BufferedReader对象
            PrintWriter writer=new PrintWriter(socket.getOutputStream());
            //由Socket对象得到输出流,并构造PrintWriter对象
            BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
            //由系统标准输入设备构造BufferedReader对象
            System.out.println("Client:"+in.readLine());
            //在标准输出上打印从客户端读入的字符串
            line=br.readLine();
            //从标准输入读入一字符串
            while(!line.equals("end")){
            //如果该字符串为 "bye",则停止循环
                writer.println(line);
                //向客户端输出该字符串
                writer.flush();
                //刷新输出流,使Client马上收到该字符串
                System.out.println("Server:"+line);
                //在系统标准输出上打印读入的字符串
                System.out.println("Client:"+in.readLine());
                //从Client读入一字符串,并打印到标准输出上
                line=br.readLine();
                //从系统标准输入读入一字符串
            } //继续循环
            writer.close(); //关闭Socket输出流
            in.close(); //关闭Socket输入流
            socket.close(); //关闭Socket
            server.close(); //关闭ServerSocket
        }catch(Exception e) {//出错,打印出错信息
            System.out.println("Error."+e);
        }
    }
}

    
public class SocketClient {
    public static void main(String[] args) throws IOException{
 
    try{
            Socket socket=new Socket("127.0.0.1",5200);
            System.out.println("client start ...");
            //向本机的52000端口发出客户请求
            BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
            //由系统标准输入设备构造BufferedReader对象
            PrintWriter write=new PrintWriter(socket.getOutputStream());
            //由Socket对象得到输出流,并构造PrintWriter对象
            BufferedReader in=new BufferedReader(new InputStreamReader(socket.getInputStream()));
            //由Socket对象得到输入流,并构造相应的BufferedReader对象
            String readline;
            readline=br.readLine(); //从系统标准输入读入一字符串
            while(!readline.equals("end")){
                //若从标准输入读入的字符串为 "end"则停止循环
                write.println(readline);
                //将从系统标准输入读入的字符串输出到Server
                write.flush();
                //刷新输出流,使Server马上收到该字符串
                System.out.println("Client:"+readline);
                //在系统标准输出上打印读入的字符串
                System.out.println("Server:"+in.readLine());
                //从Server读入一字符串,并打印到标准输出上
                readline=br.readLine(); //从系统标准输入读入一字符串
            } //继续循环
            write.close(); //关闭Socket输出流
            in.close(); //关闭Socket输入流
            socket.close(); //关闭Socket                       
        }catch(Exception e) {
            System.out.println("can not listen to:"+e);//出错,打印出错信息
        }
    }
}
您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632