java-JDBC登錄注冊代碼


登錄:

public static void main(String[] args) throws Exception{
        Scanner sc = new Scanner(System.in);
        System.out.println("賬號:");
        String uid = sc.nextLine();
        System.out.println("密碼:");
        String pwd = sc.nextLine();
        
        Class.forName("com.mysql.jdbc.Driver");
        
        Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb","root","");
        String sql = "select * from users where user = ? and password = ?";
        PreparedStatement ps = conn.prepareStatement(sql);
        ps.setString(1, uid);
        ps.setString(2, pwd);
        ResultSet rs = ps.executeQuery();
        boolean ok = rs.next();
        if(ok){
            System.out.println("歡迎"+rs.getString(3)+"回來");
        }
        else
        {
            System.out.println("您輸入的賬號密碼有誤");
        }
        }

這是一個簡單的通過輸入數據跟數據庫的數據比較來完成登錄驗證。這里用的是PreparedStatement

PreparedStatement 與Statement 的區別

1  有安全性

    PreparedStatement 可以由於不是使用拼接,防止了sql注入,提高了安全性。

2  更方便

    PreparedStatement 可以自動對類型進行轉換,代碼可讀性,可維護性提高。

 

3  批處理

   PreparedStatement 有預編譯功能,大批量的處理sql效率更高。(MySQL 不明顯,Oracle 非常明顯)

 

注冊:

public static void main (String[] args) throws Exception{
        Scanner sc = new Scanner(System.in);
        System.out.println("請輸入賬號");
        String uid = sc.nextLine();
        System.out.println("請輸入密碼");
        String pwd = sc.nextLine();
        System.out.println("請輸入昵稱");
        String nc = sc.nextLine();
        
        Class.forName("com.mysql.jdbc.Driver");
        Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb?characterEncoding=GBK","root","");
        String sql =  "insert into users values (?,?,?)";
        
        PreparedStatement ps = conn.prepareStatement(sql);
        ps.setString(1, uid);
        ps.setString(2, pwd);
        ps.setString(3, nc);
        ps.executeUpdate();
        conn.close();
        
        
        
    }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM