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

打印 上一主题 下一主题

主题 1045|帖子 1045|积分 3135

一、实验目的 

1.掌握JSP表单的开辟方法。
2.认识JDBC技术和利用JDBC连接各种数据库。
二、实验性质

综合性实验
三、实验内容

实现注册与登录功能:
1.创建一个数据库,在数据库创建用户表。(5分)
2.制作一个注册表单,可以输入账户和暗码并提交(在数据提交之前用JS对表单数据举行有用性验证),将表单提交的数据写入数据库。(30分)

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

4.从数据库中读取全部的用户数据,并在页面中显示。(25分)
login.jsp
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2.     pageEncoding="UTF-8"%>
  3. <!DOCTYPE html>
  4. <html>
  5. <head>
  6. <meta charset="UTF-8">
  7. <title>Insert title here</title>
  8. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  9. <link rel="stylesheet" href="./登录注册.css">
  10. </head>
  11. <body>
  12.     <div class="box">
  13.         <h2>Login</h2>
  14.         <form action="login_result.jsp" method="post" name="loginForm"
  15.              onsubmit="return check()">
  16.              <div class="input-box">
  17.                  <label>账号</label> <input type="text" name="username"
  18.                      placeholder="请输入用户名">
  19.              </div>
  20.              <div class="input-box">
  21.                  <label>密码</label> <input type="password" name="password"
  22.                      placeholder="请输入密码">
  23.              </div>
  24.              <div class="btn-box">
  25.                  <div>
  26.                      <button>登录</button>
  27.                  </div>
  28.              </div>
  29.         </form>
  30.     </div>
  31. </body>
  32. </html>
复制代码
login_result.jsp
  1. <%@page import="java.sql.*"%>
  2. <%@ page language="java" contentType="text/html; charset=UTF-8"
  3.     pageEncoding="UTF-8"%>
  4. <!DOCTYPE html>
  5. <html>
  6. <head>
  7. <meta charset="UTF-8">
  8. <title>Insert title here</title>
  9. </head>
  10. <body>
  11.     <%
  12.         request.setCharacterEncoding("UTF-8");
  13.         String username = request.getParameter("username");
  14.         String password = request.getParameter("password");
  15.         //1.导入包
  16.         //将jar包粘贴到WEB_INF中的lib文件夹下
  17.         //2.加载驱动
  18.         String driver = "com.mysql.cj.jdbc.Driver";
  19.         Class.forName(driver);
  20.         //3.创建链接Connection
  21.         String url = "jdbc:mysql://localhost:3306/javaweb?characterEncoding=UTF-8&serverTimezone=Asia/Shanghai";
  22.         Connection conn = DriverManager.getConnection(url, "root", "g1234");
  23.         Statement stat = conn.createStatement();
  24.         String sql = "SELECT * FROM s WHERE stuname=? and password=?";
  25.         PreparedStatement pstat = conn.prepareStatement(sql);
  26.         pstat.setString(1,username);
  27.         pstat.setString(2,password);
  28.         ResultSet rs = pstat.executeQuery();
  29.        
  30.         if(rs.next()){
  31.              out.print("登录成功,欢迎您:");
  32.              out.println(username);
  33.         }else{
  34.              out.print("登录失败!!!");
  35.         }
  36.         stat.close();
  37.         pstat.close();
  38.         conn.close();
  39.     %>
  40. </body>
  41. </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 注入攻击。
提供了根本的前端验证,提拔了用户体验。
可改进之处:
安全性:暗码处理方面可以更安全,建议利用加盐哈希等技术来存储暗码。
错误处理:在异常情况下,可以提供更友爱的错误提示,而不光仅是打印错误信息。
用户体验:可以增加更多的交互性和反馈,比方注册成功后跳转到登录页面等。
可维护性:代码中的数据库连接信息硬编码在页面中,可以将其抽取到设置文件中,便于维护和管理。


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

杀鸡焉用牛刀

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表