题目要求:

1登录账号:要求由6到12位字母、数字、下划线组成,只有字母可以开头;(1分)

2登录密码:要求显示“• ”或“*”表示输入位数,密码要求八位以上字母、数字组成。(1分)

3性别:要求用单选框或下拉框实现,选项只有“男”或“女”;(1分)

4学号:要求八位数字组成,前四位为“2018”开头,输入自己学号;(1分)

5姓名:输入自己的姓名;

5电子邮箱:要求判断正确格式xxxx@xxxx.xxxx;(1分)

6点击“添加”按钮,将学生个人信息存储到数据库中。(3分)

7可以演示连接上数据库。(2分)

代码:

1连接数据库

import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
/**
 * 数据库连接工具
 * @author Hu
 *
 */
public class DBUtil {
 
 public static String db_url = "jdbc:mysql://localhost:3306/zzm?useSSL=false";
 public static String db_user = "root";
 public static String db_pass = "123456";
 
 public static Connection getConn () {
  Connection conn = null;
  
  try {
   Class.forName("com.mysql.jdbc.Driver");//加载驱动
   conn = DriverManager.getConnection(db_url, db_user, db_pass);
  } catch (Exception e) {
   e.printStackTrace();
  }
  
  return conn;
 }
 
 /**
  * 关闭连接
  * @param state
  * @param conn
  */
 public static void close (Statement state, Connection conn) {
  if (state != null) {
   try {
    state.close();
   } catch (SQLException e) {
    e.printStackTrace();
   }
  }
  
  if (conn != null) {
   try {
    conn.close();
   } catch (SQLException e) {
    e.printStackTrace();
   }
  }
 }
 
 public static void close (ResultSet rs, Statement state, Connection conn) {
  if (rs != null) {
   try {
    rs.close();
   } catch (SQLException e) {
    e.printStackTrace();
   }
  }
  
  if (state != null) {
   try {
    state.close();
   } catch (SQLException e) {
    e.printStackTrace();
   }
  }
  
  if (conn != null) {
   try {
    conn.close();
   } catch (SQLException e) {
    e.printStackTrace();
   }
  }
 }
}
2创建变量
package lzx;
public class Lzx {
 private int id;
 private String zhanghao;
 private String password;
 private String sex;
 private String number;
 private String name;
 private String mail;
 private String xueyuan;
 private String zhuanye;
 private String banji;
 private String year;
 private String shengyuandi;
 private String beizhu;
 public int getId()
 {
  return id;
 }
 public void setId()
 {
  this.id=id;
 }
 public String getZhanghao()
 {
  return zhanghao;
 }
 public void setZhanghao()
 {
  this.zhanghao=zhanghao;
 }
 public String getPassword()
 {
  return password;
 }
 public void setPassword()
 {
  this.password=password;
 }
 public String getSex()
 {
  return sex;
 }
 public void setSex()
 {
  this.sex=sex;
 }
 public String getName()
 {
  return name;
 }
 public void setName()
 {
  this.name=name;
 }
 public String getMail()
 {
  return mail;
 }
 public void setMail()
 {
  this.mail=mail;
 }
 public String getNumber()
 {
  return number;
 }
 public void setNumber()
 {
  this.number=number;
 }
 public String getXueyuan()
 {
  return xueyuan;
 }
 public void setXueyuan()
 {
  this.xueyuan=xueyuan;
 }
 public String getZhuanye()
 {
  return zhuanye;
 }
 public void setZhuanye()
 {
  this.zhuanye=zhuanye;
 }
 public String getBanji()
 {
  return banji;
 }
 public void setBanji()
 {
  this.banji=banji;
 }
 public String getYear()
 {
  return year;
 }
 public void setYear()
 {
  this.year=year;
 }
 public String getShengyuandi()
 {
  return shengyuandi;
 }
 public void setShengyuandi()
 {
  this.shengyuandi=shengyuandi;
 }
 public String getBeizhu()
 {
  return beizhu;
 }
 public void setBeizhu()
 {
  this.beizhu=beizhu;
 }
 public Lzx() {}
 public Lzx(int id,String zhanghao,String password,String sex,String name,String number,String mail,String xueyuan,String zhuanye,String banji,String year,String shengyuandi,String beizhu)
 {
  this.id=id;
  this.zhanghao = zhanghao;
  this.password = password;
  this.name = name;
  this.sex = sex;
  this.number =number;
  this.name = name;
  this.mail = mail;
  this.xueyuan = xueyuan;
  this.zhuanye = zhuanye;
  this.banji = banji;
  this.year = year;
  this.shengyuandi = shengyuandi;
  this.beizhu = beizhu;
 }
 public Lzx(String zhanghao, String password,String sex, String name,String number,String mail,String xueyuan,String zhuanye,String banji,String year,String shengyuandi,String beizhu)
 {
  this.zhanghao = zhanghao;
  this.password = password;
  this.name = name;
  this.sex = sex;
  this.number = number;
  this.mail = mail;
  this.xueyuan = xueyuan;
  this.zhuanye = zhuanye;
  this.banji = banji;
  this.year = year;
  this.shengyuandi = shengyuandi;
  this.beizhu = beizhu;
 }
}
3

package lzx;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
/**
 *
 * Dao层操作数据
 * @author Zhao
 *
 */
public class lzxDao {
 /**
  * 添加
  * @param zzm
  * @return
  */
 public boolean add(Lzx zzm) {
  String sql = "insert into zzm(zhanghao,password,sex,name,number,mail,xueyuan,zhuanye,banji,year,shengyuandi,beizhu) values('" + zzm.getZhanghao() + "','" + zzm.getPassword() + "','" + zzm.getSex() + "','"+zzm.getName()+"','" + zzm.getNumber() + "','" + zzm.getMail()+"','"+zzm.getXueyuan()+"','"+zzm.getZhuanye()+"','"+zzm.getBanji() +"','"+zzm.getYear()+"','"+zzm.getShengyuandi()+"','"+zzm.getBeizhu() +"')";
  Connection conn = DBUtil.getConn();
  Statement state = null;
  boolean f = false;
  int a = 0;
  
  try {
   state = conn.createStatement();
   state.executeUpdate(sql);
  } catch (Exception e) {
   e.printStackTrace();
  } finally {
   DBUtil.close(state, conn);
  }
  
  if (a > 0) {
   f = true;
  }
  return f;
 }
 public boolean zhanghao(String zhanghao) {
  // TODO Auto-generated method stub
  return false;
 }
 
}
4

package lzx;
import java.util.List;
/**
 * ZzmService
 * 服务层
 * @author Zhao
 *
 */
public class LzxService {
 lzxDao cDao = new lzxDao();
 
 /**
  * 添加
  * @param Zzm
  * @return
  */
 public boolean add(Lzx zzm) {
  boolean f = false;
  if(!cDao.zhanghao(zzm.getZhanghao())) {
   cDao.add(zzm);
   f = true;
  }
  return f;
 }
 
 
}
5

package lzx;
import java.io.IOException;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet("/LzxServlet")
public class LzxServlet extends HttpServlet {
 
 private static final long serialVersionUID = 1L;
 LzxService service = new LzxService();
 
 protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
  req.setCharacterEncoding("utf-8");
  String method = req.getParameter("method");
  if ("add".equals(method)) {
   add(req, resp);
  }
 }
 /**
  * 添加
  * @param req
  * @param resp
  * @throws IOException
  * @throws ServletException
  */
 private void add(HttpServletRequest req, HttpServletResponse resp) throws IOException, ServletException {
  req.setCharacterEncoding("utf-8");
  String zhanghao = req.getParameter("zhanghao");
  String password = req.getParameter("password");
  String sex = req.getParameter("sex");
  String number = req.getParameter("number");
  String name = req.getParameter("name");
  String mail = req.getParameter("mail");
  String xueyuan = req.getParameter("xueyuan");
  String zhuanye = req.getParameter("zhuanye");
  String banji = req.getParameter("banji");
  String year = req.getParameter("year");
  String shengyuandi = req.getParameter("shengyuandi");
  String beizhu = req.getParameter("beizhu");
  Lzx zzm= new Lzx(zhanghao,password,sex,name,number,mail,xueyuan,zhuanye,banji,year,shengyuandi,beizhu);
  
  //添加后消息显示
  if(service.add(zzm)) {
   req.setAttribute("message", "添加成功");
   req.getRequestDispatcher("zzm.jsp").forward(req,resp);
  } else {
   req.setAttribute("message", "用户名重复,请重新输入");
   req.getRequestDispatcher("zzm.jsp").forward(req,resp);
  }
 }
 
 
}
6写页面
<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
 
<link rel="stylesheet" type="text/css" href="css/nav.css">
<link rel="stylesheet" type="text/css" href="font/iconfont.css">
<script type="text/javascript" src="js/jquery.min.js"></script>
<script type="text/javascript" src="js/nav.js"></script>
</head>
<body>
<%
      Object message = request.getAttribute("message");
      if(message!=null && !"".equals(message)){
 
 %>
      <script type="text/javascript">
           alert("<%=request.getAttribute("message")%>");
      </script>
 <%} %>
 <div align="center">
<form action="LzxServlet?method=add" method="post" onsubmit="return check()">
<table  width="500px" height="650px"border="1" style="text-align:center">
   <tr height="50px" align="center" bgcolor="#FFFFCC">
           <td width="100"><font color="black"style="font-family:宋体;">登录账号:</font></td>
   <td width="400"><input  id="zhanghao" name="zhanghao" placeholder="请输入账号"/></td>
   
  </tr>
  <tr height="50px" align="center" bgcolor="#FFFFCC">
           <td width="100"><font color="black"style="font-family:宋体;">登录密码:</font></td>
   <td width="400"><input  type="password" name="password" placeholder="请输入密码"/></td>
   
  </tr>
   <tr height="50" align="center" bgcolor="#FFFFCC">
           <td width="100"><font color="black"style="font-family:宋体;">性别:</font></td>
   <td><select id="sex" name="sex" >
    <option value="男">男</option>
    <option value="女">女</option>
    <select></td>
   </tr>
     <tr height="50px" align="center" bgcolor="#FFFFCC">
           <td width="100"><font color="black"style="font-family:宋体;">姓名:</font></td>
   <td width="400"><input  id="name" name="name" placeholder="请输入姓名"/></td>
  </tr>
   <tr height="50" align="center" bgcolor="#FFFFCC">
           <td width="100"><font color="black"style="font-family:宋体;">学号:</font></td>
   <td width="400"><input  id="number" name="number" placeholder="请输入学号"/></td>
   </tr>
   <tr height="50" align="center" bgcolor="#FFFFCC">
           <td width="100"><font color="black"style="font-family:宋体;">电子邮箱:</font></td>
   <td width="400"><input  id="mail" name="mail" placeholder="请输入邮箱" /></td>
   </tr>
   <tr height="50" align="center" bgcolor="#FFFFCC">
           <td width="100"><font color="black"style="font-family:宋体;">所在学院:</font></td>
   <td width="400"><input  id="xueyuan" name="xueyuan" placeholder="请输入学院名" /></td>
   </tr>
   <tr height="50" align="center" bgcolor="#FFFFCC">
           <td width="100"><font color="black"style="font-family:宋体;">所在专业:</font></td>
   <td width="400"><input  id="zhuanye" name="zhuanye" placeholder="请输入专业" /></td>
   </tr>
   <tr height="50" align="center" bgcolor="#FFFFCC">
           <td width="100"><font color="black"style="font-family:宋体;">所在班级:</font></td>
   <td width="400"><input  id="banji" name="banji" placeholder="请输入班级" /></td>
   </tr>
   <tr height="50" align="center" bgcolor="#FFFFCC">
           <td width="100"><font color="black"style="font-family:宋体;">入学年份:</font></td>
   <td><select id="year" name="year" >
    <option value="2015">2015</option>
    <option value="2016">2016</option>
    <option value="2017">2017</option>
    <option value="2018">2018</option>
    <option value="2019">2019</option>
    <select></td>
   </tr>
   <tr height="50" align="center" bgcolor="#FFFFCC">
           <td width="100"><font color="black"style="font-family:宋体;">生源地:</font></td>
   <td width="400"><input  id="shengyuandi" name="shengyuandi" placeholder="请输入生源地" /></td>
   </tr>
   
   <tr height="100" align="center" bgcolor="#FFFFCC">
           <td width="100"><font color="black"style="font-family:宋体;">备注:</font></td>
   <td width="400"><input  id="beizhu" name="beizhu" placeholder="无" /></td>
   </tr>
   <tr height="50" align="center" bgcolor="#FFFFCC">
   <td width="400"><button type="submit" >添加<button></td>
   <td width="400"><input type="reset"  value="重新输入" /></td>
   </tr>
     
</form>
</div>
<script type="text/javascript"> 
function check() {
 var zhanghao = document.getElementById("zhanghao");
 var password = document.getElementById("password");
 var number = document.getElementById("number");
 var mail = document.getElementById("mail");
 
 if (!zhanghao.value.match(/^[a-zA-Z]\w{5,11}$/)) {
          
        alert("用户名由六到十二英文字符和数字组成,以英文字母开头");
       
        num.focus();
        return false;
}
 else if (!password.value.match(/^[A-Za-z0-9]\w{7,20}$/)) {
  
     alert(" 密码由八 位 以上英文 和数 字 组成");
 
     mima.focus();
     return false;
}
 else if(number.value<"20180000"|| number.value>"20189999")
  {
   alert(" 学号由2018开头的八位组成");
         number.focus();
         return false;
  }
 else if (!mail.value.match(/^[a-z0-9]+([._\\-]*[a-z0-9])*@([a-z0-9]+[-a-z0-9]*[a-z0-9]+.){1,63}[a-z0-9]+$/)) {
    
     alert(" 邮箱格式错误");
 
     mail.focus();
     return false;
}
}
</script>
</body>
</html>
 
 
 

javaweb 测试的更多相关文章

  1. Javaweb测试

    1.建立web 工程 输入Project name.然后点击finish. 2.右键点击WebContent-New-JSP File,新建jsp文件. 3.然后编写一个jsp登录的程序 <%@ ...

  2. IDEA新建javaWeb以及Servlet简单实现

    刚开始用IDEA开发,还不太熟悉,因此写一个教程,加深印象 1.新建一个Web项目 两种方法:java 和 Java Enterprise(推荐) 第一种)通过Java工程创建,这个方法需要手动导入T ...

  3. Intellij IDEA创建javaWeb以及Servlet简单实现

    1.创建web工程 File --> New --> Project...

  4. Intellij IDEA创建javaweb步骤详解

    一.创建并设置javaweb工程 1.创建javaweb工程File --> New --> Project... 设置工程名字: 创建完成后工程结构如下: 2. Web工程设置2.1 在 ...

  5. [转]Intellij idea创建javaWeb以及Servlet简单实现

    准备:1. 安装jdk1.72. 安装tomcat1.8 一.创建并设置javaweb工程 1.创建javaweb工程File --> New --> Project... 设置工程名字: ...

  6. Inellij idea创建javaWeb以及Servlet简单实现

    版权声明:本文为博主原创文章,未经博主允许不得转载. 准备:1. 安装jdk1.7 2. 安装tomcat1.8 一.创建并设置javaweb工程 1.创建javaweb工程File --> N ...

  7. Intellij idea创建javaWeb:实现JSP/Servlet(转)

    转自:https://www.jianshu.com/p/9684e90cf7b5 Intellij idea创建javaWeb:实现JSP/Servlet by_love唯念 关注 2016.12. ...

  8. IDEA下配置JavaWeb项目

    前提 已安装IDEA专业版 已安装Tomcat 已安装JDK 创建JavaWeb项目 File --> New --> Project... 设置工程名字: 创建完成后工程结构如下: 设置 ...

  9. WebSocket简单介绍

    Java后端WebSocket的Tomcat实现 一.WebSocket简单介绍 随着互联网的发展,传统的HTTP协议已经很难满足Web应用日益复杂的需求了.近年来,随着HTML5的诞生,WebSoc ...

随机推荐

  1. PHP create_function()代码注入

    查看代码 分析 变量$action要出现数字字母以外的字符,还要执行函数. /i不区分大小写 /s匹配任何不可见字符,包括空格.制表符.换页符等等 /D如果使用$限制结尾字符,则不允许结尾有换行 这里 ...

  2. 机器学习实战基础(十四):sklearn中的数据预处理和特征工程(七)特征选择 之 Filter过滤法(一) 方差过滤

    Filter过滤法 过滤方法通常用作预处理步骤,特征选择完全独立于任何机器学习算法.它是根据各种统计检验中的分数以及相关性的各项指标来选择特征 1 方差过滤 1.1 VarianceThreshold ...

  3. python 生成器(五):生成器实例(一)创建数据处理管道

    问题 你想以数据管道(类似Unix管道)的方式迭代处理数据. 比如,你有个大量的数据需要处理,但是不能将它们一次性放入内存中. 解决方案 生成器函数是一个实现管道机制的好办法. 为了演示,假定你要处理 ...

  4. 帮助你更好的理解Spring循环依赖

    网上关于Spring循环依赖的博客太多了,有很多都分析的很深入,写的很用心,甚至还画了时序图.流程图帮助读者理解,我看了后,感觉自己是懂了,但是闭上眼睛,总觉得还没有完全理解,总觉得还有一两个坎过不去 ...

  5. python基础算法

    一.简介 定义和特征 定义:算法(Algorithm)是指解题方案的准确而完整的描述,是一系列解决问题的清晰指令,算法代表着用系统的方法描述解决问题的策略机制.也就是说,能够对一定规范的输入,在有限时 ...

  6. 树形dp 之 小胖守皇宫

    题目描述 huyichen世子事件后,xuzhenyi成了皇上特聘的御前一品侍卫. 皇宫以午门为起点,直到后宫嫔妃们的寝宫,呈一棵树的形状:有边相连的宫殿间可以互相望见.大内保卫森严,三步一岗,五步一 ...

  7. PHP : CodeIgniter mysql_real_escape_string 警告

    版本 CodeIgniter 3 PHP 5.4 感谢万能的stackoverflow. 得修改CodeIgniter的源码. ./system/database/drivers/mysql/mysq ...

  8. mysqldump导出表结构及数据

    问题描述:有需要mysql某几张表的需求,某个数据库某几张表,导出先检查相应的数据库和表是否存在 数据泵用法:默认导出的是表结构以及表中的数据 mysqldump -uroot -p -S /data ...

  9. Email正则表达式验证

    在做邮箱验证的时候,进行简单的整理: string emailStr = @"/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((\.[a-zA-Z0-9_-]{2,3 ...

  10. 题解 洛谷 P3734 【[HAOI2017]方案数】

    可以先考虑没有障碍物的情况,设计状态\(f_{i,j,k}\),表示到达坐标 \((x,y,z)\)二进制下,\(x\)有\(i\)位,\(y\)有\(j\)位,\(z\)有\(k\)位的方案数. 得 ...