JavaWeb:实验二JSP表单开发及访问数据库

2024-09-02 00:36

本文主要是介绍JavaWeb:实验二JSP表单开发及访问数据库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、实验目的 

1.掌握JSP表单的开发方法。

2.熟悉JDBC技术和使用JDBC连接各种数据库。

二、实验性质

综合性实验

三、实验内容

实现注册与登录功能:

1.创建一个数据库,在数据库建立用户表。(5分)

2.制作一个注册表单,可以输入账户和密码并提交(在数据提交之前用JS对表单数据进行有效性验证),将表单提交的数据写入数据库。(30分)

3.制作一个登录表单,输入账号和密码,通过数据库进行验证,如果账号、密码验证通过,则显示“登录成功”,否则显示“登录失败”。(30分)

e4215c0d51904cee8245b8443418cb3c.jpeg4.从数据库中读取所有的用户数据,并在页面中显示。(25分)

134d399f3e584974a36d8864a8b3d349.jpeglogin.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%><!DOCTYPE html><html><head><meta charset="UTF-8"><title>Insert title here</title><meta name="viewport" content="width=device-width, initial-scale=1.0"><link rel="stylesheet" href="./登录注册.css"></head><body><div class="box"><h2>Login</h2><form action="login_result.jsp" method="post" name="loginForm"onsubmit="return check()"><div class="input-box"><label>账号</label> <input type="text" name="username"placeholder="请输入用户名"></div><div class="input-box"><label>密码</label> <input type="password" name="password"placeholder="请输入密码"></div><div class="btn-box"><div><button>登录</button></div></div></form></div></body></html>

login_result.jsp

<%@page import="java.sql.*"%><%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%><!DOCTYPE html><html><head><meta charset="UTF-8"><title>Insert title here</title></head><body><%request.setCharacterEncoding("UTF-8");String username = request.getParameter("username");String password = request.getParameter("password");//1.导入包//将jar包粘贴到WEB_INF中的lib文件夹下//2.加载驱动String driver = "com.mysql.cj.jdbc.Driver";Class.forName(driver);//3.创建链接ConnectionString url = "jdbc:mysql://localhost:3306/javaweb?characterEncoding=UTF-8&serverTimezone=Asia/Shanghai";Connection conn = DriverManager.getConnection(url, "root", "g1234");Statement stat = conn.createStatement();String sql = "SELECT * FROM s WHERE stuname=? and password=?";PreparedStatement pstat = conn.prepareStatement(sql);pstat.setString(1,username);pstat.setString(2,password);ResultSet rs = pstat.executeQuery();if(rs.next()){out.print("登录成功,欢迎您:");out.println(username);}else{out.print("登录失败!!!");}stat.close();pstat.close();conn.close();%></body></html>

四、实验总结

请书写你对本次实验有哪些实质性的收获和体会,以及对本次实验有何良好的建议?(10分)

login.jsp

这个页面包含一个登录表单,用户需要输入用户名和密码。

通过 JavaScript 对表单进行了基本的前端验证,确保用户输入不为空。

当用户点击登录按钮时,表单数据将被提交到 login_result.jsp 页面进行处理。

login_result.jsp

这个页面接收从登录表单提交的用户名和密码。

加载 MySQL 驱动,建立数据库连接。

使用 PreparedStatement 执行 SQL 查询,查询数据库中是否存在匹配的用户名和密码。

根据查询结果,输出相应的登录成功或失败信息。

优点:

实现了基本的用户登录功能,页面简洁明了,易于使用。

使用了预编译的 SQL 语句,有效防止了 SQL 注入攻击。

提供了基本的前端验证,提升了用户体验。

可改进之处:

安全性:密码处理方面可以更安全,建议使用加盐哈希等技术来存储密码。

错误处理:在异常情况下,可以提供更友好的错误提示,而不仅仅是打印错误信息。

用户体验:可以增加更多的交互性和反馈,例如登录成功后跳转到个人主页等。

可维护性:代码中的数据库连接信息硬编码在页面中,可以将其抽取到配置文件中,便于维护和管理。
register.jsp

这个页面包含一个注册表单,用户需要输入用户名和密码。

通过 JavaScript 对表单进行了基本的前端验证,确保用户名和密码不为空。

当用户点击注册按钮时,表单数据将被提交到 register_result.jsp 页面进行处理。

register_result.jsp

这个页面接收从注册表单提交的用户名和密码。

将接收到的用户名和密码插入到数据库表中。

输出相应的注册成功或失败信息。

优点:

实现了基本的用户注册功能,页面简洁明了,易于使用。

使用了预编译的 SQL 语句,有效防止了 SQL 注入攻击。

提供了基本的前端验证,提升了用户体验。

可改进之处:

安全性:密码处理方面可以更安全,建议使用加盐哈希等技术来存储密码。

错误处理:在异常情况下,可以提供更友好的错误提示,而不仅仅是打印错误信息。

用户体验:可以增加更多的交互性和反馈,例如注册成功后跳转到登录页面等。

可维护性:代码中的数据库连接信息硬编码在页面中,可以将其抽取到配置文件中,便于维护和管理。

这篇关于JavaWeb:实验二JSP表单开发及访问数据库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1128495

相关文章

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Spring Cloud LoadBalancer 负载均衡详解

《SpringCloudLoadBalancer负载均衡详解》本文介绍了如何在SpringCloud中使用SpringCloudLoadBalancer实现客户端负载均衡,并详细讲解了轮询策略和... 目录1. 在 idea 上运行多个服务2. 问题引入3. 负载均衡4. Spring Cloud Load

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

在 Spring Boot 中使用 @Autowired和 @Bean注解的示例详解

《在SpringBoot中使用@Autowired和@Bean注解的示例详解》本文通过一个示例演示了如何在SpringBoot中使用@Autowired和@Bean注解进行依赖注入和Bean... 目录在 Spring Boot 中使用 @Autowired 和 @Bean 注解示例背景1. 定义 Stud

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

springboot将lib和jar分离的操作方法

《springboot将lib和jar分离的操作方法》本文介绍了如何通过优化pom.xml配置来减小SpringBoot项目的jar包大小,主要通过使用spring-boot-maven-plugin... 遇到一个问题,就是每次maven package或者maven install后target中的ja

Java中八大包装类举例详解(通俗易懂)

《Java中八大包装类举例详解(通俗易懂)》:本文主要介绍Java中的包装类,包括它们的作用、特点、用途以及如何进行装箱和拆箱,包装类还提供了许多实用方法,如转换、获取基本类型值、比较和类型检测,... 目录一、包装类(Wrapper Class)1、简要介绍2、包装类特点3、包装类用途二、装箱和拆箱1、装

如何利用Java获取当天的开始和结束时间

《如何利用Java获取当天的开始和结束时间》:本文主要介绍如何使用Java8的LocalDate和LocalDateTime类获取指定日期的开始和结束时间,展示了如何通过这些类进行日期和时间的处... 目录前言1. Java日期时间API概述2. 获取当天的开始和结束时间代码解析运行结果3. 总结前言在J