javaweb之添加学生信息
1登录账号:要求由6到12位字母、数字、下划线组成,只有字母可以开头;(1分)
2登录密码:要求显示“• ”或“*”表示输入位数,密码要求八位以上字母、数字组成。(1分)
3性别:要求用单选框或下拉框实现,选项只有“男”或“女”;(1分)
4学号:要求八位数字组成,前四位为“2018”开头,输入自己学号;(1分)
5姓名:输入自己的姓名;
5电子邮箱:要求判断正确格式xxxx@xxxx.xxxx;(1分)
6点击“添加”按钮,将学生个人信息存储到数据库中。(3分)
7可以演示连接上数据库。(2分)
add.jsp页面
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%> <script type="text/javascript">
function checkid(form1) {
var userid = form1.userid.value; if (userid == "" || !isUsername(userid)) {
alert("用户名要求由6到12位字母、数字、下划线组成,只有字母可以开头!");
form1.userid.value="";
form1.userid.focus();
return false;
}
}
function checkpsw(form1)
{
var userpsw = form1.userpsw.value;
if(userpsw=="")
return true;
if (!isUserpsw(userpsw)) {
alert("密码要求八位以上字母、数字组成。");
form1.userpsw.value="";
form1.userpsw.focus();
return false;
}
}
function checknum(form1)
{
var usernum = form1.usernum.value;
if (!usernum.substring(0, 4) == "2018" || usernum.length != 8) {
alert("学号要求八位数字组成,前四位为“2018”开头");
form1.usernum.value="";
form1.usernum.focus();
return false;
}
return true;
} function isUsername(userid) { if (!((userid.charAt(0) >= 'a' && userid.charAt(0) <= 'z') || (userid
.charAt(0) >= 'A' && userid.charAt(0) <= 'Z'))) {
return false;
}
for (var i = 1; i < userid.length; i++) {
if (((userid.charAt(i) >= 'a' && userid.charAt(i) <= 'z') || (userid
.charAt(i) >= 'A' && userid.charAt(i) <= 'Z'))
|| (userid.charAt(i) >= '0' && userid.charAt(i) <= '9')) {
continue;
}
else
return false;
}
return true;
}
function isUserpsw(str) {
if (str.length < 8){ return false;
}
for (var i = 0; i < str.length; i++) {
if ((str.charAt(i) >= '0' && str.charAt(i)<= '9')
|| (str.charAt(i) >= 'a' && str.charAt(i) <= 'z')
|| (str.charAt(i) >= 'A' && str.charAt(i) <= 'Z')){
continue;
}
else
return false;
}
return true;
}
</script>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Insert title here</title>
</head>
<body>
<form name="form1" action="UserServlet?method=add" method="post"
onsubmit="return check(form1);">
<%
Object message = request.getAttribute("message");//放置一个字符串,并取出
if (message != null && !"".equals(message)) {
%>
<script type="text/javascript">
alert("<%=request.getAttribute("message")%>");
</script>
<%
}
%>
<h2 align="center">请注册</h2>
<table align="center">
<tr>
<td>登录账号:</td>
<td><input type="text" id="userid" name="userid" onchange="checkid(form1)"
placeholder="请输入账号" /></td>
</tr>
<tr>
<td>登录密码:</td>
<td><input type="password" id="userpsw" name="userpsw" onchange="checkpsw(form1)"
placeholder="请输入密码" /></td>
</tr>
<tr>
<td>性别:</td>
<td><select id="usersex" name="usersex">
<option>男</option>
<option>女</option>
</select></td>
</tr>
<tr>
<td>姓名:</td>
<td><input type="text" id="username" name="username"
placeholder="请输入姓名" /></td>
</tr>
<tr>
<td>学号:</td>
<td><input type="text" id="usernum" name="usernum" onchange="checknum(form1)"
placeholder="请输入学号" /></td>
</tr>
<tr>
<td>电子邮件:</td>
<td><input type="email" id="useremail" name="useremail"
placeholder="请输入邮箱" /></td>
</tr>
<tr>
<td>所在学院:</td>
<td><input type="text" id="userxy" name="userxy"
placeholder="请输入学院" /></td>
</tr>
<tr>
<td>所在系:</td>
<td><input type="text" id="userxi" name="userxi"
placeholder="请输入系" /></td>
</tr>
<tr>
<td>所在班级:</td>
<td><input type="text" id="userclass" name="userclass"
placeholder="请输入班级" /></td>
</tr>
<tr>
<td>入学年份(届):</td>
<td><select id="useryear" name="useryear">
<option>2017</option>
<option>2018</option>
<option>2019</option>
</select>届</td>
</tr>
<tr>
<td>生源地:</td>
<td><input type="text" id="userdizhi" name="userdizhi"
placeholder="请输入生源地" /></td>
</tr>
<tr>
<td>备注:</td>
<td><textarea rows="8" id="userbeizhu" name="userbeizhu"
cols="40">备注</textarea></td>
</tr>
<tr>
<td><input type="submit" value="添加"></td>
</tr>
</table> </form>
</body>
</html>
user.java
package com.Studentweb; public class User {
private int id;
private String userid;
private String userpsw;
private String usersex;
private String username;
private String usernum;
private String useremail;
private String userxy;
private String userxi;
private String userclass;
private String useryear;
private String uesrdizhi;
private String uesrbeizhu;
public String getUserid() {
return userid;
}
public void setUserid(String userid) {
this.userid = userid;
}
public String getUserpsw() {
return userpsw;
}
public void setUserpsw(String userpsw) {
this.userpsw = userpsw;
}
public String getUsersex() {
return usersex;
}
public void setUsersex(String usersex) {
this.usersex = usersex;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getUsernum() {
return usernum;
}
public void setUsernum(String usernum) {
this.usernum = usernum;
}
public String getUseremail() {
return useremail;
}
public void setUseremail(String useremail) {
this.useremail = useremail;
}
public String getUserxy() {
return userxy;
}
public void setUserxy(String userxy) {
this.userxy = userxy;
}
public String getUserxi() {
return userxi;
}
public void setUserxi(String userxi) {
this.userxi = userxi;
}
public String getUserclass() {
return userclass;
}
public void setUserclass(String userclass) {
this.userclass = userclass;
}
public String getUseryear() {
return useryear;
}
public void setUseryear(String useryear) {
this.useryear = useryear;
}
public String getUesrdizhi() {
return uesrdizhi;
}
public void setUesrdizhi(String uesrdizhi) {
this.uesrdizhi = uesrdizhi;
}
public String getUesrbeizhu() {
return uesrbeizhu;
}
public void setUesrbeizhu(String uesrbeizhu) {
this.uesrbeizhu = uesrbeizhu;
}
public User(String userid, String userpsw, String usersex, String username, String usernum, String useremail,
String userxy, String userxi, String userclass, String useryear, String uesrdizhi, String uesrbeizhu) {
super();
this.userid = userid;
this.userpsw = userpsw;
this.usersex = usersex;
this.username = username;
this.usernum = usernum;
this.useremail = useremail;
this.userxy = userxy;
this.userxi = userxi;
this.userclass = userclass;
this.useryear = useryear;
this.uesrdizhi = uesrdizhi;
this.uesrbeizhu = uesrbeizhu;
} }
userdao.java
package Dao;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import util.DBUtil;
import com.Studentweb.User; public class userdao {
public boolean add(User user) {
String sql = "insert into text(userid,userpsw,usersex,username,usernum,useremail,userxy,userxi,userclass,useryear,userdizhi,userbeizhu)"
+ "values('" + user.getUserid() + "','" + user.getUserpsw()+ "','" + user.getUsersex() + "','" + user.getUsername()+ "','" + user.getUsernum()+ "','" + user.getUseremail()+ "','" + user.getUserxy()+ "','" + user.getUserxi()+ "','" + user.getUserclass()+ "','" + user.getUseryear()+ "','" + user.getUesrdizhi()+ "','" + user.getUesrbeizhu()+ "')";
Connection conn = DBUtil.getConn();//调用方法连接数据库
Statement state = null;
boolean f = false;
int a = 0 ; try { //监视大括号内的代码
state = conn.createStatement();
a = state.executeUpdate(sql);
} catch (Exception e) { //捕获错误
e.printStackTrace();
} finally {
//关闭z 连接
DBUtil.close(state, conn);
} if (a > 0) {
f = true;
}
return f;
} }
DBUtil.java
package util; //数据库连接
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; /**
* 数据库连接工具
* @author Zheng
*
*/
public class DBUtil { public static String db_url = "jdbc:mysql://localhost:3306/text?useSSL=false";
public static String db_user = "root";
public static String db_pass = "fengge666"; 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();
}
}
} }
userservlet.java
package servlet; import java.io.IOException; import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import com.Studentweb.User;
import Dao.userdao; /**
* Servlet implementation class UserServlet
*/
@WebServlet("/UserServlet")
public class UserServlet extends HttpServlet {
private static final long serialVersionUID = 1L; /**
* @see HttpServlet#HttpServlet()
*/
public UserServlet() {
super();
// TODO Auto-generated constructor stub
}
userdao dao = new userdao(); 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);
}
} private void add(HttpServletRequest req, HttpServletResponse resp) throws IOException, ServletException {
// TODO Auto-generated method stub
String userid = req.getParameter("userid");
String userpsw = req.getParameter("userpsw");
String username=req.getParameter("username");
String usersex=req.getParameter("usersex");
String usernum=req.getParameter("usernum");
String useremail=req.getParameter("useremail");
String userxy=req.getParameter("userxy");
String userxi=req.getParameter("userxi");
String userclass=req.getParameter("userclass");
String useryear=req.getParameter("useryear");
String userdizhi=req.getParameter("userdizhi");
String userbeizhu=req.getParameter("userbeizhu"); User user= new User(userid,userpsw,username,usersex,usernum,useremail,userxy,userxi,userclass,useryear,userdizhi,userbeizhu);
dao.add(user);
req.setAttribute("message", "添加成功!");
req.getRequestDispatcher("add.jsp").forward(req, resp);
} }
最终界面:
输入完相应对话框,会自动判断是否满足要求,并给出提示信息
个人总结:在做极限测试,出现了几个问题,第一个对判断的语句没有弄清楚,课下对javascript里的字符串语句进行了学习,掌握了基本的判断字符串的信息,第二个问题是:onblur对浏览器一直保持定位和刷新,导致无法添加信息,最终改为onchange的方法,成功在浏览器上运行。
javaweb之添加学生信息的更多相关文章
- 从C#中通过Windows窗体添加信息到数据库 (添加学生信息)
如上图所示界面,当我们点击保存按钮时将会将表格中的数据保存到数据库中去,与数据库进行一个交互 第一步我们就是要获取到表格中的数据 string pwd = textpwd.Text; //获得第一次输 ...
- MVC学生管理系统-阶段II(添加学生信息)
项目源码 :https://download.csdn.net/download/weixin_44718300/11091042 前期准备,主体框架,学生列表显示 请看上一篇文章 本文是对阶段 ...
- 添加学生信息(Javaweb)
add.jsp <%@ page language="java" import="java.util.*" pageEncoding="UTF- ...
- javaweb添加学生信息
连接数据库已经进行判断 要求: 1登录账号:要求由6到12位字母.数字.下划线组成,只有字母可以开头:(1分) 2登录密码:要求显示“• ”或“*”表示输入位数,密码要求八位以上字母.数字组成.(1分 ...
- java7连接数据库 网页 添加学生信息测试
石家庄铁道大学2019年秋季 2018 级课堂测试试卷(六)(10分) 课程名称: JAVA语言程序设计 任课教师: 王建民 考试时间: 150 分钟 一. 考试要求: 1登录账号 ...
- 添加学生信息(java wb)
要求: 1.登录账号:要求由6到12位字母.数字.下划线组成,只有字母可以开头: 2.登录密码:要求显示“• ”或“*”表示输入位数,密码要求八位以上字母.数字组成: 3.性别:要求用单选框或下拉框实 ...
- web添加学生信息(首发web)
程序思路,先在JSP上画好页面,然后再创建一Servlet文件用于判断在网页上操作是否正确,还需要与数据库相连接,用DBUtile文件连接数据库,用Dao层来实现数据的增加,用Service来服务于D ...
- javaweb简单的学生信息录入系统
讲一下思路,主界面的设计就是用html表单元素,百度查找各个元素的用法,按照自己的想法摆放即可,表单提交后会把数据交给serverlet去处理,在那里定义几个字符串变量来储存获取到的数据,然后按照项目 ...
- 向数据库添加学生信息。存放在REQUEST对象里
代码前几天已经发过了,但是程序一直还没运行出来,今天重新建立了一个数据库,才可以,下面补充上数据截图
随机推荐
- System.NotSupportedException:“No data is available for encoding 1252. For information on defining a custom encoding
最近搞 .net项目,Dapper连接Mysql时,运行报错: System.NotSupportedException:“No data is available for encoding 1252 ...
- jQuery获取各种标签的文本和value值
<select id="test"> <option value ="volvo">Volvo</option> <o ...
- Java动态代理实现方式一
Java代理设计模式(Proxy)的四种具体实现:静态代理和动态代理 实现方式一:静态代理 静态代理方式的优点 静态代理方式的缺点 Java动态代理实现方式一:InvocationHandler Ja ...
- shell expect的简单实用
一.在shell脚本中嵌入expect来实现密码输入 expect是一个自动交互功能的工具.expect是开了一个子进程,通过spawn来执行shell脚本,监测到脚本的返回结果,通过expect判断 ...
- 二分法递归版本(c++)
利用二分法求解在区间[0,π/2]上的根 #include<iostream> #include <cmath> using namespace std; double dic ...
- 如何新建WebAPI,生成注释,TestAPI的项目
一.新建WebAPI的项目 1. 在Web下,ASP.NET Web 应用程序,点击确定 2. 点击确定 3. 如图所示, 新建Controller 4 . 运行项目 二.注释 1. 在生成中,勾选x ...
- docker-Harbor仓库映像
部署环境: centos-7.2 docker-engine-1.12.5 docker-compose-1.9.0 harbor-0.5.0 1.下载所需的软件包(以下需要-翻-墙-下载的地方你们自 ...
- Inno setup 判断系统32位还是64位
[Files] ; Install MyProg-x64.exe -bit mode (x64; see above), ; Check: Is64BitInstallMode 表示是64位windo ...
- windows环境下mongodb下权限设置
1.创建超级用户 超级用户位于admin集合下. use admin db.createUser({ user:'admin', pwd:'123456', roles:[{role:'root',d ...
- 考勤打卡机导出的excel考勤时间表如何生成实用的考勤表
该excel表有如下结构 姓名\日期 周1 周2 周3 周4 周5 张三 7:3518:02 7:3518:02 7:46 17:56 李四 7:3518:02 7:02 18:00 18:02 ...