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

相关文章

Java实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

SpringBoot全局域名替换的实现

《SpringBoot全局域名替换的实现》本文主要介绍了SpringBoot全局域名替换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录 项目结构⚙️ 配置文件application.yml️ 配置类AppProperties.Ja

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志