登录功能

  • 登陆界面


    登陆界面
  • 代码
    GUI界面
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.sql.Connection;

import javax.imageio.ImageIO;
import javax.security.auth.login.LoginContext;
import javax.swing.*;

import com.mysql.jdbc.PreparedStatement;

import UserMysql.connectLog_Mysql;

public class userLog_Window extends connectLog_Mysql {      //此类中只调用WindowLog里面的方法
    public static void main(String args[]){
        //调用WindowLogin里面的方法
        WindowLogin win = new WindowLogin();
       }

}

class WindowLogin extends JFrame implements ActionListener{     //JFrame的子类
    
    //声明组件
    JLabel jlpic = new JLabel();
    JFrame jf ;
    
    JLabel Title = new JLabel("用户管理系统");
    JLabel Name = new JLabel("账号:");
    JTextField textName = new JTextField(10);
    JLabel Passwd = new JLabel("密码:");
    JTextField textPasswd = new JTextField(10);
    JButton btnLog = new JButton("登录");
    
    public WindowLogin(){       //主要设置窗口属性,调用函数实现组件
    
        //基本设置:
        //1.窗口声明 
        jf = new JFrame("用户登录");
        jf.setVisible(true);
        jf.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
        jf.setSize(1000,800);
        jf.setLocation(500,200);
        //2.面板声明
        JPanel panel = new JPanel();
        //设置面板透明
        panel.setOpaque(false);
        //3.窗口中添加面板
        jf.add(panel);
        //4.添加组件到面板
        placeComponents(panel);
        //调用函数
        initFrame();
    }
    
    private void placeComponents(JPanel panel) {        //对组件的具体操作

        
        //设置为布局为null,这样才可以给他绝对定位组件
        panel.setLayout(null);
        //add添加功能组件进去
        Title.setBounds(250, 130, 300, 35);
        Title.setForeground(Color.pink);
        Title.setFont(new Font("楷体",1,30));
        panel.add(Title);
        Name.setBounds(200,200,120,25);     //一定要先设置他的位置,否则一直都不会显示噢
        Name.setFont(new Font("楷体",NORMAL,25));
        panel.add(Name);
        textName.setBounds(280,200,165,30);
        panel.add(textName);
        Passwd.setBounds(200,250,80,25);
        Passwd.setFont(new Font("楷体",NORMAL,25));
        panel.add(Passwd);
        textPasswd.setBounds(280,250,165,30);
        panel.add(textPasswd);
        btnLog.setBounds(320,300,70,30);
        btnLog.setBackground(Color.pink);
        btnLog.setFont(new Font("楷体",NORMAL,18));
        panel.add(btnLog);
        //给按钮添加监听器
        btnLog.addActionListener(this); 
    }

    public void initFrame() {
        ImageIcon icon = new ImageIcon("src\\pink.jpg");
        icon.setImage(icon.getImage().getScaledInstance(900,
                500, Image.SCALE_DEFAULT));
        System.out.println(icon.getIconHeight() + "" + icon.getIconWidth());
        jlpic.setHorizontalAlignment(0);
        jlpic.setIcon(icon);
        jf.add(jlpic);
        jf.pack();
 
    }
    @Override
    public void actionPerformed(ActionEvent e) {
        
        //点击登录后,调用login方法将用户输入的内容与mysql中存储的内容
        if(e.getSource() == btnLog) {
            login();
        }   
    }

    //和Mysql数据库中的数据进行联系
    private void login() {
        
        connectLog_Mysql connect = new connectLog_Mysql();
        //获取用户输入的用户名和密码
        String username = textName.getText();
        String password = textPasswd.getText();
        System.out.println("用户输入的:"+username + ","+ password);
        //在mysql中搜索这个用户名,不存在则输出用户不存在
        //若用户名存在,对照密码,密码正确则登录ok,不正确则输出密码不对
        if (connect.compare(username, password)) {
            JOptionPane.showMessageDialog(null, "登录成功!");
//            super.setVisible(false);
            jf.dispose();
            new WindowChoose();
        }
    }
    
}
  • 连接MySQL
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import javax.swing.JOptionPane;

import com.mysql.jdbc.PreparedStatement;

public class connectLog_Mysql {
    
    //对应Window窗口中调用的数据库操作方法
    public Boolean compare(String username, String password) {
        boolean m = false;
        try {
            //要去掉mysql和jdbc之间的cj!!!
            Class.forName("com.mysql.jdbc.Driver");//根据报错信息修改
            String url = "jdbc:mysql://localhost:3307/users?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8&useSSL=false";//链接的mysql
            String user = "root";
            String passwd = "123456";
            Connection con = DriverManager.getConnection(url,user,passwd);//处理异常
            System.out.println("Mysql连接成功" + con.toString());//测试是否连接成功
            
            
            //执行sql语句
            Statement sql;
            ResultSet rs;
            try {
                //此方法创建用于执行静态SQL 语句并返回它所生成结果的对象
                sql = con.createStatement();
                //定义所有查询的语句
                String searchALL = "select * from admininfo";
                //执行要查询的语句
                rs = sql.executeQuery(searchALL);
                while(rs.next()) {
                    String username2 = rs.getString(2);
                    String password3 = rs.getString(3);
                    System.out.println("数据库中"+username2 + ":" + password3);
                    if (password.equals(password3) && username.equals(username2)) {
                        m = true;
                        break;
                    } else if(rs.isLast()){
                        JOptionPane.showMessageDialog(null, "用户名或密码错误!");
                        break;
                    }
                }
                
                con.close();
            } catch (SQLException e) {
                
                e.printStackTrace();
            }
            
        } catch (Exception e) {
            e.printStackTrace();
            System.out.println("error:数据库连接出错");
        }
        return m;
        
    }
    
    
    public static void main(String args[]){
        
        connectSearchInfo_Mysql con = new connectSearchInfo_Mysql();
       }

}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351