欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java簡易登錄注冊小程序

 更新時間:2022年04月25日 09:26:54   作者:溫柔狠角色  
這篇文章主要為大家詳細介紹了Java圖形界面開發(fā),簡易登錄注冊小程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

登錄注冊小代碼,將學過的一些小知識融合在一起進行了使用,加深印象。本例中如果有注釋不詳細的地方,詳見其它博客。

功能介紹:簡單的登錄注冊系統(tǒng),使用了數(shù)據(jù)庫sqlserver、單例模式、正則表達式以及圖形化開發(fā)等知識。

1、在登錄界面,可以登錄或者注冊用戶。 注冊用戶界面,按照正則表達式規(guī)定的格式要求來輸入信息,若有誤,則重新輸入。
2、點擊注冊,首先連接SQLserver數(shù)據(jù)庫,連接成功則會判斷該用戶名是否已經(jīng)存在,若存在,則給出提示。反之則進行注冊。
3、登錄界面,點擊登錄按鈕時,首先與數(shù)據(jù)庫建立連接。按照用戶名和密碼來向數(shù)據(jù)庫中查找,若有,則登錄成功。反之給出提示。
4、利用單例模式,實現(xiàn)了只創(chuàng)建類SQLserver的一個對象,大大節(jié)省了內(nèi)存開銷 。
程序完整代碼見:https://github.com/chaohuangtianjie994/A-login-register-System
5、基于此,可以進行大量的拓展功能。 

代碼如下:

UserRegister.java 登錄界面。

package package1; 
/* 
 * 功能:登錄界面帶著注冊功能,彈出注冊界面。 
 * 將注冊的信息保存在數(shù)據(jù)庫中,并且可以進行登錄操作。 
 * author:ywq 
 */ 
import javax.swing.*; 
 
import java.awt.*; 
import java.awt.event.*; 
import java.sql.*; 
 
public class UserRegister extends JFrame implements ActionListener{ 
  
 //定義登錄界面的組件 
  JButton jb1,jb2,jb3=null; 
  JRadioButton jrb1,jrb2=null; 
  JPanel jp1,jp2,jp3=null; 
  JTextField jtf=null; 
  JLabel jlb1,jlb2=null; 
  JPasswordField jpf=null; 
    
  
 public static void main(String[] args) 
 { 
  UserRegister ur=new UserRegister(); 
 } 
  
 public UserRegister() 
 { 
  //創(chuàng)建組件 
   //創(chuàng)建組件 
  jb1=new JButton("登錄"); 
  jb2=new JButton("注冊"); 
  jb3=new JButton("退出"); 
  //設置監(jiān)聽 
  jb1.addActionListener(this); 
  jb2.addActionListener(this); 
  jb3.addActionListener(this); 
   
  jlb1=new JLabel("用戶名:"); 
  jlb2=new JLabel("密 碼:"); 
   
  jtf=new JTextField(10); 
  jpf=new JPasswordField(10); 
   
  jp1=new JPanel(); 
  jp2=new JPanel(); 
  jp3=new JPanel(); 
   
  jp1.add(jlb1); 
  jp1.add(jtf); 
   
  jp2.add(jlb2); 
  jp2.add(jpf); 
   
  jp3.add(jb1); 
  jp3.add(jb2); 
  jp3.add(jb3); 
  this.add(jp1); 
  this.add(jp2); 
  this.add(jp3); 
   
  this.setVisible(true); 
  this.setResizable(false); 
  this.setTitle("注冊登錄界面"); 
  this.setLayout(new GridLayout(3,1)); 
  this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 
  this.setBounds(300, 200, 300, 180); 
   
   
 } 
 
 @Override 
 public void actionPerformed(ActionEvent e) { 
   
  //監(jiān)聽各個按鈕 
  if(e.getActionCommand()=="退出") 
  { 
   System.exit(0); 
  }else if(e.getActionCommand()=="登錄") 
  { 
   //調(diào)用登錄方法 
   this.login(); 
  }else if(e.getActionCommand()=="注冊") 
  { 
   //調(diào)用注冊方法 
   this.Regis(); 
  } 
   
 } 
  
 //注冊方法 
  public void Regis() { 
   
   
   this.dispose(); //關閉當前界面 
   new UI(); //打開新界面 

 } 
 
 //登錄方法 
 public void login() { 
   
  SQLserver s=new SQLserver(); 
  s.ConnectSQL(); 
  s.SQLverify(jtf.getText(), jpf.getText()); 
   
  this.jtf.setText(""); 
  this.jpf.setText(""); 
   
 } 
 
} 

UI.java 用于注冊的頁面顯示。使用了正則表達式來規(guī)定輸入的內(nèi)容。注冊時候,需要首先判斷用戶名是否存在,若存在,則給出提示,反之進行注冊。

package package1; 
 
import java.awt.event.*; 
import java.awt.*; 
 
import javax.swing.*; 
 
/* 
 * 注冊界面。 
 */ 
class UI extends JFrame implements ActionListener{ 
 
 //定義組件 
 JFrame jf; 
 JPanel jp; 
 JLabel jl1,jl2,jl3,jl4; 
 JTextField jtf1,jtf2,jtf3,jtf4; 
 JButton jb1,jb2; 
  
 public UI() 
 { 
  //初始化組件 
  jf=new JFrame(); 
  jp=new JPanel(); 
  jl1=new JLabel("請輸入用戶名:"); 
  jtf1=new JTextField(10); 
  jtf1.setToolTipText("用戶名必須為3-6位字母_或者數(shù)字"); 
  jl2=new JLabel("請輸入密碼:"); 
  jtf2=new JTextField(10); 
  jtf2.setToolTipText("密碼必須為6位字母_或者數(shù)字"); 
  jl3=new JLabel("請輸入姓名:"); 
  jtf3=new JTextField(10); 
  jtf3.setToolTipText("姓名必須漢字2-4位"); 
  jl4=new JLabel("請輸入學號:"); 
  jtf4=new JTextField(10); 
  jtf4.setToolTipText("學號必須為3-6位數(shù)字"); 
   
  jb1=new JButton("返回"); 
  jb1.setToolTipText("點我返回登錄界面哦"); 
  jb2=new JButton("注冊"); 
  jb1.addActionListener(this); 
  jb2.addActionListener(this); 
   
  jp.setLayout(new GridLayout(5,2)); 
   
  jp.add(jl1); 
  jp.add(jtf1); 
   
  jp.add(jl2); 
  jp.add(jtf2); 
   
  jp.add(jl3); 
  jp.add(jtf3); 
   
  jp.add(jl4); 
  jp.add(jtf4); 
   
  jp.add(jb1); 
  jp.add(jb2); 
   
  this.add(jp); 
  this.setTitle("注冊界面"); 
  this.setBounds(200, 100, 250, 150); 
  this.setVisible(true); 
  this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 
//  this.setResizable(false); 
   

 } 

 public void actionPerformed(ActionEvent e) { 
  
  if(e.getActionCommand()=="返回") 
  { 
   this.dispose(); 
   new UserRegister(); 
//   System.out.println("-------"); 
    
  }else if(e.getActionCommand()=="注冊") 
  { 
    //調(diào)用注冊方法 
   this.zhuce(); 
    
  } 
   
 } 
 public void zhuce() 
 { 
  String regex1="\\w{3,6}"; //用戶名必須是3-6位 
  boolean flag1=jtf1.getText().matches(regex1); 
   
  String regex2="\\w{6}"; //密碼必須是6位 
  boolean flag2=jtf2.getText().matches(regex2); 
   
  String regex3="[\\u4e00-\\u9fa5]{2,4}"; //姓名必須是漢字2-4個字 
  boolean flag3=jtf3.getText().matches(regex3); 
   
  String regex4="\\d{3,6}"; //學號必須是3-6位 
  boolean flag4=jtf4.getText().matches(regex4); 
   
//  if(jtf1.getText()==null||jtf2.getText()==null||jtf3.getText()==null||jtf4.getText()==null) 
  if(flag1==false) 
  { 
   JOptionPane.showMessageDialog(null, "用戶名填寫錯誤,必須為3-6位字母_或者數(shù)字", "提示信息", JOptionPane.WARNING_MESSAGE); 
   jtf1.setText(""); 
  }else if(flag2==false) 
  { 
   JOptionPane.showMessageDialog(null, "密碼填寫錯誤,必須為6位字母_或者數(shù)字", "提示信息", JOptionPane.WARNING_MESSAGE); 
   jtf2.setText(""); 
  }else if(flag3==false) 
  { 
   JOptionPane.showMessageDialog(null, "姓名填寫錯誤,必須漢字2-4位", "提示信息", JOptionPane.WARNING_MESSAGE); 
   jtf3.setText(""); 
  }else if(flag4==false) 
  { 
   JOptionPane.showMessageDialog(null, "學號填寫錯誤,必須為3-6位數(shù)字", "提示信息", JOptionPane.WARNING_MESSAGE); 
   jtf4.setText(""); 
  }else 
  {    
   //調(diào)用注冊方法/先檢查要注冊的用戶名是否存在 
    SQLserver ss=new SQLserver(); 
    ss.ConnectSQL(); 
    ss.ZhuceVerify(jtf1.getText()); 
    
//   ss.UserRegis(jtf1.getText(),jtf2.getText(),jtf3.getText(), jtf4.getText()); 
   this.jtf1.setText(""); 
   this.jtf2.setText(""); 
   this.jtf3.setText(""); 
   this.jtf4.setText(""); 
    
  } 
 } 
  
} 

SQLserver.java實現(xiàn)了與數(shù)據(jù)庫的連接以及查詢驗證等各個功能。

package package1; 
 
import java.sql.*; 
 
import javax.swing.JOptionPane; 
/* 
 * 與數(shù)據(jù)庫相關的操作,單獨封裝成類 
 */ 
 
class SQLserver { 
 
 Connection ct; 
 PreparedStatement ps; 
 ResultSet rs; 
 String user,pwd; 
  
 //將連接數(shù)據(jù)庫的方法封裝為一個方法 
 public void ConnectSQL() 
 { 
  try { 
   Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); //加載驅(qū)動 
    
   ct=DriverManager.getConnection("jdbc:odbc:ywq"); //得到連接 
    
   System.out.println("已成功連接數(shù)據(jù)庫..."); 
    
  } catch (Exception e) { 
   // TODO Auto-generated catch block 
   e.printStackTrace(); 
  } 
 } 
  
 //注冊用戶的方法 
 public void UserRegis(String a,String b,String c,String d) 
 { 
  //創(chuàng)建火箭車 
  try { 
   ps=ct.prepareStatement("insert into users values(?,?,?,?)"); 
   ps.setString(1,a); 
   ps.setString(2,b); 
   ps.setString(3,c); 
   ps.setString(4,d); 
    
   //執(zhí)行 
   int i=ps.executeUpdate(); 
   if(i==1) 
   { 
    JOptionPane.showMessageDialog(null, "注冊成功","提示消息",JOptionPane.WARNING_MESSAGE); 
     
   }else 
   { 
    JOptionPane.showMessageDialog(null, "注冊失敗","提示消息",JOptionPane.ERROR_MESSAGE); 
   } 
    
    
  } catch (SQLException e) { 
   // TODO Auto-generated catch block 
   e.printStackTrace(); 
  } 
 } 
  
// 登錄驗證方法 
 public void SQLverify(String a,String b) 
 { 
  try { 
   ps=ct.prepareStatement("select * from users where 用戶名=? and 密碼=? "); 
   ps.setString(1, a); 
   ps.setString(2, b); 
    
   // ResultSet結(jié)果集,大家可以把ResultSet理解成返回一張表行的結(jié)果集 
   rs = ps.executeQuery(); 
    
   if(rs.next()) 
   { 
    user = rs.getString(1); 
    pwd = rs.getString(2); 
    JOptionPane.showMessageDialog(null, "登錄成功?。?!", "提示消息", JOptionPane.WARNING_MESSAGE); 
    System.out.println("成功獲取到密碼和用戶名from數(shù)據(jù)庫"); 
    System.out.println(user + "\t" + pwd + "\t"); 
   }else 
   { 
    JOptionPane.showMessageDialog(null, "用戶名或者密碼錯誤,請重新輸入!", "提示消息", JOptionPane.ERROR_MESSAGE); 
     
   } 
    
  } catch (SQLException e) { 
    
   e.printStackTrace(); 
  } 
 } 
  
 //注冊驗證方法,判斷用戶名是否已經(jīng)存在 
 public void ZhuceVerify(String a) 
 { 
  try { 
   ps=ct.prepareStatement("select * from users where 用戶名=?"); 
//   System.out.println(ps); 
   ps.setString(1, a); 
    
   rs=ps.executeQuery(); 
   if(rs.next()) 
   { 
    JOptionPane.showMessageDialog(null, "該用戶名已經(jīng)存在", "提示信息", JOptionPane.WARNING_MESSAGE); 
   }else 
   { 
//    進行注冊 
    UI ui=new UI(); 
    this.UserRegis(ui.jtf1.getText(),ui.jtf2.getText(),ui.jtf3.getText(),ui.jtf4.getText()); 
   } 
    
  } catch (SQLException e) { 
    
   e.printStackTrace(); 
  } 
 } 

} 

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Java設計模式之觀察者模式

    Java設計模式之觀察者模式

    這篇文章主要為大家介紹了Java觀察者模式,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • Java構(gòu)造方法實例詳解(動力節(jié)點java學院整理)

    Java構(gòu)造方法實例詳解(動力節(jié)點java學院整理)

    其實java構(gòu)造方法很簡單,下面通過示例給大家分享java構(gòu)造方法,非常不錯,具有參考借鑒價值,需要的朋友參考下
    2017-04-04
  • Java設計模式之java備忘錄模式詳解

    Java設計模式之java備忘錄模式詳解

    這篇文章主要介紹了JAVA設計模式之備忘錄模式,簡單說明了備忘錄模式的概念、原理并結(jié)合實例形式分析了java備忘錄模式的具體定義及使用方法,需要的朋友可以參考下
    2021-09-09
  • Springboot項目中使用redis的配置詳解

    Springboot項目中使用redis的配置詳解

    這篇文章主要介紹了Springboot項目中使用redis的配置詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • java中JDBC實現(xiàn)往MySQL插入百萬級數(shù)據(jù)的實例代碼

    java中JDBC實現(xiàn)往MySQL插入百萬級數(shù)據(jù)的實例代碼

    這篇文章主要介紹了java中JDBC實現(xiàn)往MySQL插入百萬級數(shù)據(jù)的實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-01-01
  • 聊一聊new對象與Spring對bean的初始化的差別

    聊一聊new對象與Spring對bean的初始化的差別

    這篇文章主要介紹了聊一聊new對象與Spring對bean的初始化的差別,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • SpringBoot集成Redisson實現(xiàn)延遲隊列的場景分析

    SpringBoot集成Redisson實現(xiàn)延遲隊列的場景分析

    這篇文章主要介紹了SpringBoot集成Redisson實現(xiàn)延遲隊列,本文通過場景分析實例代碼相結(jié)合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-04-04
  • SpringCloud中的Hystrix保護機制詳解

    SpringCloud中的Hystrix保護機制詳解

    這篇文章主要介紹了SpringCloud中的Hystrix保護機制詳解,Hystrix,英文意思是豪豬,全身是刺,看起來就不好惹,是一種保護機制,Hystrix也是Netflix公司的一款組件,需要的朋友可以參考下
    2023-12-12
  • java實現(xiàn)python session功能代碼實例

    java實現(xiàn)python session功能代碼實例

    這篇文章主要介紹了java實現(xiàn)python session功能代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-11-11
  • JPA如何使用findBy方法自定義查詢

    JPA如何使用findBy方法自定義查詢

    這篇文章主要介紹了JPA如何使用findBy方法自定義查詢,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11

最新評論