设计模式的学习-登录的重构

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

 

 

 

java代码的实现

Customer

public class Customer {
    private String uname;
    private String pas;
    public String getUname() {
        return uname;
    }
    public void setUname(String uname) {
        this.uname = uname;
    }
    public String getPas() {
        return pas;
    }
    public void setPas(String pas) {
        this.pas = pas;
    }
    
    public Customer(String uname, String pas) {
        super();
        this.uname = uname;
        this.pas = pas;
    }
    public Customer() {
        // TODO Auto-generated constructor stub
    }

}

CustomerDao

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;


public class CustomerDao {
    private DBUtil util;
    private Connection conn;
    private Statement st;
    private PreparedStatement prs;
    private ResultSet rs;
    public boolean findCustomers(String uname,String pas){
        boolean flag=false;
        try {
            conn=DBUtil.getConnection();
            String sql="select *from tbl_cus where uname = ? and pas = ?";
            prs = conn.prepareStatement(sql);
            prs.setString(1, uname);
            prs.setString(2, pas);
            rs = prs.executeQuery();
             while(rs.next()) {
                Customer cus1=new Customer();
                cus1.setUname(rs.getString("uname"));
                cus1.setPas(rs.getString("pas"));
                if(cus1.getPas()!=null&&cus1.getPas().equals(pas)) {
                    flag=true;
                }
             }
             
        }catch(SQLException e) {
            e.printStackTrace();
        }finally {
            util.close(st, conn, rs,prs);
        }
        return flag;
                    
            
        }
    
    public CustomerDao() {
        // TODO Auto-generated constructor stub
    }

}

DBUtil

import java.io.FileReader;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;

public class DBUtil {
    private static String url;
    private static String password;
    private static String user;
    private static String driver;
    
    static {
    	
    	try {
    	//读取资源文件,获取值
    	//1.创建properties集合类
    	Properties pro=new Properties();
    	//2.加载文件
    	//获取src路径下文件的方式--》classLoader类加载器
    	ClassLoader classloader=DBUtil.class.getClassLoader();
    	java.net.URL res=classloader.getResource("jdbc.properties");
    	String path=res.getPath();
    	pro.load(new FileReader(path));
    	
    	//3.获取数据并且赋值
    	url=pro.getProperty("url");
    	password=pro.getProperty("password");
    	user=pro.getProperty("user");
    	driver=pro.getProperty("driver");
    	
    	//4.注册驱动
    	Class.forName(driver);
    }catch(IOException exception) {
    	exception.printStackTrace();
    	
    }catch(ClassNotFoundException e) {
    	e.printStackTrace();
    }
}
    /*
    
    获取连接,连接对象
 */
public static Connection getConnection() throws SQLException{
	   return DriverManager.getConnection(url,user,password);
}

/*
 * 
       * 释放资源
 */
public static void close(Statement st,Connection conn) {
	  if(st!=null) {
		  try {
			  st.close();
		  }catch(SQLException e) {
			  e.printStackTrace();;
		  }
	  }
	  if(conn!=null) {
		  try {
			  conn.close();
		  }catch(SQLException e) {
			  e.printStackTrace();
		  }
	  }
}
/*
 * 重载close
 */
/*
* 正着开,倒着关。所以先关Statement,后关Connection
* 
*/
public static void close(Statement st,Connection conn,ResultSet rs) {
	  if(rs!=null) {
		  try {
			  rs.close();
		  }catch(SQLException e) {
			  e.printStackTrace();
		  }
	  }
	  if(st!=null) {
		  try {
			  st.close();
		  }catch(SQLException e) {
			  e.printStackTrace();;
		  }
	  }
	  if(conn!=null) {
		  try {
			  conn.close();
		  }catch(SQLException e) {
			  e.printStackTrace();
		  }
	  }

}
public static void close(Statement st,Connection conn,ResultSet rs,PreparedStatement prs) {
	  if(rs!=null) {
		  try {
			  rs.close();
		  }catch(SQLException e) {
			  e.printStackTrace();
		  }
	  }
	  if(prs!=null) {
		  try {
			  prs.close();
		  }catch(SQLException e) {
			  e.printStackTrace();
		  }
	  }
	  if(st!=null) {
		  try {
			  st.close();
		  }catch(SQLException e) {
			  e.printStackTrace();;
		  }
	  }
	  if(conn!=null) {
		  try {
			  conn.close();
		  }catch(SQLException e) {
			  e.printStackTrace();
		  }
	  }

}
}

 LoginForm

import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
public class LoginForm extends JFrame {
    
    private static final long serialVersionUID = 1L;
    
    
    private  CustomerDao dao = new CustomerDao();
    //设置按钮组件
    
    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.findCustomers(username, password))
        {
              
        JOptionPane.showMessageDialog(null, "登录成功!");
              
             
          }else {
              JOptionPane.showMessageDialog(null, "用户名或密码错误");
             
          }
         
       }    
    
}

MainClass

public class MainClass {

    public MainClass() {
        // TODO Auto-generated constructor stub
    }
    public static void main(String[]args) {

        LoginForm loginForm=new LoginForm() ;    //调用
        loginForm.display();
           
    }

}

 

 

posted @ 2021-09-07 21:01  好吗,好  阅读(93)  评论(0)    收藏  举报