好看的登陆界面java_简单又美观的登录界面

蓝桥杯昨天结束了,小编发挥的很不好,不开心~

所以,今天就不讲算法,讲一下看的见的jsp登录界面吧。

6144b40e9c0efd52e8370bdfb8434239.png

李春波 - 岁月(管弦乐版)

04:13来自浪潮之巅的小萝卜头

登录界面效果图:

87d9e43d6c4c8193fb8a0fd3c3cbbf82.png

是不是简洁又美观呢,其实前端代码实现比较的容易,后端代码的实现有一定的难度哦~

涉及到验证码的实现,用户名和密码的校验等等。

实现步骤:

1.login.jsp中form表单的完成

需要四个文本框,三个输入框,一个图片和一个按钮控件~

下面是form表单的代码实现(为了样式的好看,引入了CSS)

462d86fe3e01c60676ef8f46919754aa.png

2.对用户名和密码的验证:

这里用到了javascript,因为怕小伙伴们弄不太懂,就先用javascript,没有用到ajax表单验证等等

e0e29dff3da6605e18b6e26cd72c87f3.png

3.验证码的随机生成和验证码图片和数字的更换

这就要用到javascript和java类来实现

显示script用于验证码的更换

function changeValidateCode() { document.getElementById("validateCode").src = "ValidateCodeServlet?rand=" + Math.random(); }

接着就是如何实现这个验证码生成的函数

package servlet;import java.awt.Color;import java.awt.Font;import java.awt.Graphics2D;import java.awt.image.BufferedImage;import java.io.IOException;import java.util.Random;import javax.imageio.ImageIO;import javax.servlet.ServletException;import javax.servlet.ServletOutputStream;import javax.servlet.annotation.WebServlet;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;/** * 验证码图像生成 * * @author QST青软实训 * */@WebServlet("/ValidateCodeServlet")public class ValidateCodeServlet extends HttpServlet { private static final long serialVersionUID = 1L; public ValidateCodeServlet() { super(); } protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 设置响应头 Content-type类型 response.setContentType("image/jpeg"); // 获取二进制数据输出流对象 ServletOutputStream out = response.getOutputStream(); // 创建缓冲图象 int width = 60; int height = 20; BufferedImage imgbuf = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); Graphics2D g = imgbuf.createGraphics(); // 设定背景色 g.setColor(getRandColor(200, 250)); // 设定图像形状及宽高 g.fillRect(0, 0, width, height); // 随机产生100条干扰线,使图象中的认证码不易被其它程序探测到 Random r = new Random(); g.setColor(getRandColor(160, 200)); for (int i = 0; i < 100; i++) { int x = r.nextInt(width); int y = r.nextInt(height); int xl = r.nextInt(12); int yl = r.nextInt(12); g.drawLine(x, y, x + xl, y + yl); } // 随机产生100个干扰点,使图像中的验证码不易被其他分析程序探测到 g.setColor(getRandColor(120, 240)); for (int i = 0; i < 100; i++) { int x = r.nextInt(width); int y = r.nextInt(height); g.drawOval(x, y, 0, 0); } // 随机产生0-9之间的4位数字验证码 g.setFont(new Font("Times New Roman", Font.PLAIN, 18)); String code = ""; for (int i = 0; i < 4; i++) { String rand = String.valueOf(r.nextInt(10)); code += rand; g.setColor(new Color(20 + r.nextInt(110), 20 + r.nextInt(110), 20 + r.nextInt(110))); g.drawString(rand, 13 * i + 6, 16); } System.out.println("yanzheng:"+code); // 将验证码保存到session中 request.getSession().setAttribute("SESSION_VALIDATECODE", code); // 输出图像 ImageIO.write(imgbuf, "JPEG", out); out.close(); } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { } // 获取指定范围的随机颜色 private Color getRandColor(int fc, int bc) { Random random = new Random(); if (fc > 255) fc = 255; if (fc < 0) fc = 0; if (bc > 255) bc = 255; if (bc < 0) bc = 0; int r = fc + random.nextInt(bc - fc); int g = fc + random.nextInt(bc - fc); int b = fc + random.nextInt(bc - fc); return new Color(r, g, b); }}

e67ba7eedb93b00238d4434ff82ce3b7.png

4.验证码的校验

同样验证码的校验也需要java来进行实现。

这里还用到了Session,Session的作用先来简介一下:

Session:在计算机中,尤其是在网络应用中,称为“会话控制”。Session 对象存储特定用户会话所需的属性及配置信息。这样,当用户在应用程序 的 Web 页之间跳转时,存储在 Session 对象中的变量将不会丢失,而是在整个用户会话中一直存在下去。当用户请求来自应用程序的 Web 页时,如果该用户还没有会话,则 Web 服务器将自动创建一个 Session 对象。当会话过期或被放弃后,服务器将终止该会话。Session 对象最常见的一个用法就是存储用户的首选项。例如,如果用户指明不喜欢查看图形,就可以将该信息存储在 Session 对象中。有关使用 Session 对象的详细信息,请参阅“ASP 应用程序”部分的“管理会话”。注意 会话状态仅在支持 cookie 的浏览器中保留。

下面是相当的代码:

写在继承了HttpServlet的类中doPost重写方法中。

下面是这部分代码的实现:

// 判断验证码是否正确 String sessionValidateCode = (String)req.getSession().getAttribute("SESSION_VALIDATECODE"); System.out.println(sessionValidateCode); if(!sessionValidateCode.equals(verifyCode)){ out.print(""); }

3c98d3fa22da285091734eddd1d97e53.png

这样通过这简单的四步就完成了,小伙伴们学会了吗?,不会的可以在评论区留言哦~

结语:

昨天小编因为时间原因发了个图集,还因为图片原因,没被推荐,很伤心,嘤嘤嘤~~~

6271ab34ead4d3fe94cf7410e5bdab6b.png

成功的路上并不拥挤,因为懂得坚持的人不多~ 爱编程的小萝卜头~

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,以下是一个简单Java用户登录界面的例子代码: ```java import javax.swing.*; import java.awt.*; import java.awt.event.*; public class Login implements ActionListener { JFrame frame; JLabel userLabel, passwordLabel, messageLabel; JTextField textField; JPasswordField passwordField; JButton submitButton, resetButton; Login() { // 创建 JFrame 实例 frame = new JFrame("用户登陆"); // 创建组件 userLabel = new JLabel("用户名:"); passwordLabel = new JLabel("密码:"); textField = new JTextField(); passwordField = new JPasswordField(); submitButton = new JButton("登录"); resetButton = new JButton("重置"); messageLabel = new JLabel(); // 设置组件位置和大小 userLabel.setBounds(50, 150, 100, 30); passwordLabel.setBounds(50, 220, 100, 30); textField.setBounds(150, 150, 150, 30); passwordField.setBounds(150, 220, 150, 30); submitButton.setBounds(50, 300, 100, 30); resetButton.setBounds(200, 300, 100, 30); messageLabel.setBounds(50, 380, 250, 30); // 添加组件到容器中 frame.add(userLabel); frame.add(passwordLabel); frame.add(textField); frame.add(passwordField); frame.add(submitButton); frame.add(resetButton); frame.add(messageLabel); // 设置容器的属性 frame.setSize(400, 500); frame.setLayout(null); frame.setVisible(true); frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); // 添加事件监听器 submitButton.addActionListener(this); resetButton.addActionListener(this); } // 实现 ActionListener 接口的 actionPerformed 方法 public void actionPerformed(ActionEvent e) { if (e.getSource() == submitButton) { String userText; String passwordText; // 获取输入框的值 userText = textField.getText(); passwordText = new String(passwordField.getPassword()); if (userText.equals("admin") && passwordText.equals("123456")) { messageLabel.setText("登录成功"); messageLabel.setForeground(Color.GREEN); } else { messageLabel.setText("登录失败,用户名或密码错误"); messageLabel.setForeground(Color.RED); } } else if (e.getSource() == resetButton) { textField.setText(""); passwordField.setText(""); messageLabel.setText(""); } } public static void main(String[] args) { new Login(); } } ``` 这个例子使用了 Swing 组件来构建用户登录界面,当用户点击“登录”按钮时,程序会检查输入的用户名和密码是否正确并给出相应的提示。 ### 回答2: Java用户登陆界面例子代码如下: ``` import javax.swing.*; import java.awt.*; import java.awt.event.*; public class Login extends JFrame { private JLabel labelUsername, labelPassword; private JTextField fieldUsername; private JPasswordField fieldPassword; private JButton buttonLogin; public Login() { setTitle("用户登录"); setSize(300, 200); setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); setLayout(new GridLayout(3, 2)); labelUsername = new JLabel("用户名:"); fieldUsername = new JTextField(); labelPassword = new JLabel("密码:"); fieldPassword = new JPasswordField(); buttonLogin = new JButton("登录"); buttonLogin.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { String username = fieldUsername.getText(); String password = new String(fieldPassword.getPassword()); if (username.equals("admin") && password.equals("password")) { JOptionPane.showMessageDialog(null, "登录成功"); dispose(); // 关闭登录窗口 } else { JOptionPane.showMessageDialog(null, "用户名或密码错误"); } } }); add(labelUsername); add(fieldUsername); add(labelPassword); add(fieldPassword); add(new JLabel()); // 预留空白 add(buttonLogin); setVisible(true); } public static void main(String[] args) { new Login(); } } ``` 以上代码实现了一个简单的用户登录界面,使用Swing组件创建了一个窗口,并添加了用户名和密码的输入框,以及一个登录按钮。当用户点击登录按钮时,程序会获取输入的用户名和密码,然后与设定的正确值进行比较。如果用户名和密码正确,弹出登录成功的提示框并关闭登录窗口;如果不正确,弹出用户名或密码错误的提示框。 ### 回答3: 下面是一个简单Java用户登录界面的例子代码: ```java import java.util.Scanner; public class UserLogin { public static void main(String[] args) { String username = "admin"; String password = "admin123"; Scanner scanner = new Scanner(System.in); System.out.print("请输入用户名:"); String inputUsername = scanner.next(); System.out.print("请输入密码:"); String inputPassword = scanner.next(); if (inputUsername.equals(username) && inputPassword.equals(password)) { System.out.println("登录成功!"); } else { System.out.println("用户名或密码错误!"); } } } ``` 这个代码中,用户名和密码被硬编码为"admin"和"admin123",你可以根据自己的需求修改。 首先,我们使用`Scanner`来接收用户输入的用户名和密码。然后,我们将输入的用户名和密码分别与预设的用户名和密码进行比较,如果匹配,则打印"登录成功!",否则打印"用户名或密码错误!"。 这只是一个简单的例子,实际的用户登录系统可能涉及更多的验证和处理逻辑,比如数据库查询和加密等。但是希望这个例子可以帮助你了解Java用户登录界面的实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值