• 单一职责原则实例——登录模块


    今天主要完成了软件设计实验一中的编程问题

    [实验任务二]:单一职责原则

    登录模块在实际项目开发中很常见,请按照教材28页利用单一职责原则重构后的类图实现这一模块。

    1、新建 java project 

    2、导入jar包

    mysql-connector-java-8.0.22.jar

            * 此处注意jar包的版本不能过低,否则数据库连接失败

    3、创建数据库和表

    4、DBUtil.java

    package Test;
    
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    public class DBUtil {
    
    	public static String db_url = "jdbc:mysql://localhost:3306/first?serverTimezone=GMT%2B8&useSSL=false";
    	public static String db_user = "root";
    	public static String db_pass = "liutianwen0613";
    
    	public static Connection getConn () {
    		Connection conn = null;
    
    		try {
    			Class.forName("com.mysql.cj.jdbc.Driver");
    			conn = DriverManager.getConnection(db_url, db_user, db_pass);
    		} catch (Exception e) {
    			e.printStackTrace();
    		}
    
    		return conn;
    	}//end getConn
    
    	public static void close (Statement state, Connection conn) {
    		if (state != null) {
    			try {
    				state.close();
    			} catch (SQLException e) {
    				e.printStackTrace();
    			}
    		}
    
    		if (conn != null) {
    			try {
    				conn.close();
    			} catch (SQLException e) {
    				e.printStackTrace();
    			}
    		}
    	}
    
    	public static void close (ResultSet rs, Statement state, Connection conn) {
    		if (rs != null) {
    			try {
    				rs.close();
    			} catch (SQLException e) {
    				e.printStackTrace();
    			}
    		}
    
    		if (state != null) {
    			try {
    				state.close();
    			} catch (SQLException e) {
    				e.printStackTrace();
    			}
    		}
    
    		if (conn != null) {
    			try {
    				conn.close();
    			} catch (SQLException e) {
    				e.printStackTrace();
    			}
    		}
    	}
    
    	public static void main(String[] args) throws SQLException {
    		Connection conn = getConn();
    		PreparedStatement pstmt = null;
    		ResultSet rs = null;
    		String sql ="select * from user";
    		pstmt = conn.prepareStatement(sql);
    		rs = pstmt.executeQuery();
    		if(rs.next()){
    			System.out.println("连接成功");
    		}else{
    			System.out.println("连接失败");
    		}
    	}
    }

    5、UserDao.java

    package Test;
    
    import java.sql.Connection;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    
    public class UserDao {
    	public boolean findUser(String username, String password) {
    		//准备SQL语句
    		String sql = "select * from user where username ='" + username + "'";
    		Connection conn= DBUtil.getConn();
    		//创建语句传输对象
    		Statement state = null;
    		ResultSet rs= null;
    		int flag=0;
    		String c_password=null;
    		try {
    			state = conn.createStatement();
    			rs = state.executeQuery(sql);
    			while(rs.next()) {
    				++flag;
    			    c_password=rs.getString("password");
    			}	if (flag == 0) {
    				return false;
    			}
    			if (!password.equals(c_password)) {   //判断密码
    				return false;
    			}
    	}catch (SQLException e) {
    		// TODO Auto-generated catch block
    		e.printStackTrace();
    	}finally {
    		 DBUtil.close(rs, state, conn);
    	}
    	return true;
    		}
    }
    
    

    6、LoginForm.java

    package Test;
    
    import java.awt.*;
    import java.awt.event.*;
    import javax.swing.*;
    
    public class LoginForm extends JFrame {
    	
    	private static final long serialVersionUID = 1L;
    	private  UserDao dao = new UserDao();
    	//设置按钮组件
        
        private  JButton jb=new JButton("登录");	//添加一个登录按钮
        private JButton button=new JButton("重置");	//添加一个确定按钮
        //设置文本框组件
        private JTextField username = new JTextField();//用户名框
        private JPasswordField password = new JPasswordField();//密码框:为加密的***
        
        JLabel user_name=new JLabel("账号:");//设置左侧用户名文字
        JLabel pass_word=new JLabel("密码:");//设置左侧密码文字
        
        public void init()
        {
    	/* 组件绝对位置  */
    	user_name.setBounds(50, 70, 300, 25);
    	pass_word.setBounds(50, 130, 200, 25);
    		
    	username.setBounds(110, 70, 300, 25);//设置用户名框的宽,高,x值,y值
    	password.setBounds(110, 130, 300, 25);//设置密码框的宽,高,x值,y值
    		
    	button.setBounds(315, 225, 90, 20);//设置确定按钮的宽,高,x值,y值
    	jb.setBounds(95, 225, 90, 20);//设置确定按钮的宽,高,x值,y值
    		
    		
    	/* 组件透明化*/
    	user_name.setOpaque(false);
    	pass_word.setOpaque(false);
    		
    		
    	 //监听事件
    	jb.addActionListener(new ActionListener(){		//为确定按钮添加监听事件
    				
    		@SuppressWarnings("deprecation")
    		public void actionPerformed(ActionEvent arg0) {
    		    validate(username.getText().trim(),password.getText().trim());
    		}
    	});
    		
    			
    	//重置按钮
    	button.addActionListener(new ActionListener(){		//为重置按钮添加监听事件
    		//同时清空name、password的数据
    		public void actionPerformed(ActionEvent arg0) {
    			// TODO 自动生成方法存根
    			username.setText("");
    			password.setText("");
    		}
    	});
    		
        }
    	
        public void display()
         {
    	JFrame f =new JFrame();
    	f.setTitle("登录页面");
            //窗口退出行为
            f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
            //设置窗口大小不可变
            f.setResizable(false);
            //设置窗口打开居中
            f.setLocationRelativeTo(null);
            //窗口大小
            f.setSize(500, 300);
           
            init();
            
            //添加组件
            Container contentPanel= new Container();//添加一个contentPanel容器
    		 contentPanel.setLayout(null);//设置添加的contentPanel容器为流布局管理器
    		 contentPanel.add(user_name);
    		 contentPanel.add(pass_word);
    		 contentPanel.add(username);
    		 contentPanel.add(password);
    		 contentPanel.add(jb);
    		 contentPanel.add(button);
    		
    			f.add(contentPanel); 
    			 //展示窗口
    	        f.setVisible(true);
    	}
    	
    
       public  void  validate(String username,String password)
    	 {
    		
               if(username.trim().length()==0||password.trim().length()==0){
    	   JOptionPane.showMessageDialog(null, "用户名,密码不允许为空");
    				
    		return;
    	     }
    		 
    	   if(dao.findUser(username, password))
    	    {
    			  
    		JOptionPane.showMessageDialog(null, "登录成功!");
    			  
    			 
    		  }else {
    			  JOptionPane.showMessageDialog(null, "用户名或密码错误");
    			 
    		  }
    		 
    	   }	
    	
    }

    7、MainClass.java

    package Test;
    
    public class MainClass {
    	 
    	 public static void main(String[] args)
    	 {
    			LoginForm loginForm=new LoginForm() ;	//调用
    			loginForm.display();
    			   
    	 }
    
    }
    

    效果截图:

  • 相关阅读:
    TCP发送数据分包的问题
    利尔达NT90无法烧录固件的问题
    position:fixed 相对于父元素定位
    PHP上传图片到阿里云OSS(图片文件或base64数据)
    python动态加载类并调用
    python 图片验证码识别
    解决python logging 中文乱码问题
    系统中断,电脑卡顿的解决办法
    清理WSL2的磁盘占用
    jqGrid--设置单元格字体颜色
  • 原文地址:https://www.cnblogs.com/ltw222/p/15259551.html
Copyright © 2020-2023  润新知