JavaWeb学习-MVC基础开发系列-2-用户注册功能

2024-06-11 10:58

本文主要是介绍JavaWeb学习-MVC基础开发系列-2-用户注册功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前面一篇,我们把开发练习的环境和代码都准备好了,这篇我们直接来写用户注册的代码。先来分析一下用户注册的页面,我们需要给用户提供一个页面,点击注册链接,进入到注册表单页面。用户输入用户名和密码,点击注册,提示用户是否完成注册。

 

1.在service层写一个注册接口

接着前面一篇代码,前面我们写完了dao层的接口和实现类。这里我们在service下新建一个接口,里面就一个注册方法。

package com.anthony.service;import com.anthony.domain.User;public interface UserService {/*** 用户注册* @param user* @throws Exception*/public void register(User user) throws Exception;}

2.写注册接口实现类

package com.anthony.service.impl;import com.anthony.dao.UserDao;
import com.anthony.dao.impl.UserDaoImpl;
import com.anthony.domain.User;
import com.anthony.service.UserService;public class UserServiceImpl implements UserService {public void register(User user) throws Exception {//业务层掉DAOUserDao userDao = new UserDaoImpl();userDao.addUser(user);}}

接下来本来是写web层servlet如何调用UserDao,但是我们没有表单数据,所以接下来我们先写表单数据

 

3.首页添加登录和注册入口

我们创建一个index.jsp,里面提供两个链接,登录和注册,点击分别跳转login.jsp和regist.jsp

index.jsp代码

<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>网站首页</title>
</head>
<body><a href="">登录</a><a href="register.jsp">注册</a></body>
</html>

这里我们登录先不管,本篇就完成注册。部署到tomcat,浏览器打开,效果是这样的。

4. 写注册表单

<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>注册</title>
</head>
<body><form action="${pageContext.request.contextPath}/servlet/regServlet" method="post">用户名:<input type="text" name="username"/><br/>密码:<input type="password" name="password"/><br/>确认密码:<input type="password" name="repassword"/><br/>邮箱:<input type="text" name="email"/><br/>生日:<input type="text" name="birthday"/><br/><input type="submit" value="注册"></form>
</body>
</html>

表单效果是这样的

5.写一个servlet类

上面我们在register这个表单中设置了跳转到/servlet/regServlet这个Controller处理,所以接下来就来写这个servlet.

在web.servlet包下新建一个RegServlet.java

package com.anthony.web.servlet;import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;import org.apache.commons.beanutils.BeanUtils;import com.anthony.domain.User;
import com.anthony.service.UserService;
import com.anthony.service.impl.UserServiceImpl;public class RegServlet extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {req.setCharacterEncoding("UTF-8");resp.setContentType("text/html;charset=UTF-8");//获取表单数据User user = new User();try {BeanUtils.populate(user, req.getParameterMap());//调用业务层方法/逻辑UserService us = new UserServiceImpl();us.register(user);} catch (Exception e) {e.printStackTrace();}//分发转向resp.getWriter().write("注册成功,2秒之后跳转到主页");resp.setHeader("refresh", "2;url="+req.getContextPath()+"/index.jsp");}@Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {doGet(req,resp);}}

web.xml配置如下

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1"><display-name>J2EE_Demo</display-name><servlet><servlet-name>regServlet</servlet-name><servlet-class>com.anthony.web.servlet.RegServlet</servlet-class></servlet><servlet-mapping><servlet-name>regServlet</servlet-name><url-pattern>/servlet/regServlet</url-pattern></servlet-mapping><welcome-file-list><welcome-file>index.html</welcome-file><welcome-file>index.htm</welcome-file><welcome-file>index.jsp</welcome-file><welcome-file>default.html</welcome-file><welcome-file>default.htm</welcome-file><welcome-file>default.jsp</welcome-file></welcome-file-list>
</web-app>

部署之后,访问index.jsp然后点击注册

点击注册之后发现报500错误,指向了这行代码错误。

BeanUtils.populate(user, req.getParameterMap());

网上查询得到commons-beanutils-1.9.3.jar,使用这个1.9.3版本的jar就会出这个异常,换成低版本就没有问题

重启tomcat服务器,然后重新打开浏览器,走注册流程就可以成功注册。为了验证注册成功,我本地查询下MySQL表看看用户是否真的添加进来了。

发现网页提示注册成功,但是数据库表没有数据,而且后台报错了,出了一个异常。

五月 29, 2019 4:11:46 下午 org.apache.commons.beanutils.converters.DateConverter toDate
警告:     (N.B. Re-configure Converter or use alternative implementation)
org.apache.commons.beanutils.ConversionException: DateConverter does not support default String to 'Date' conversion.

修改RegServlet.java代码如下

package com.anthony.web.servlet;import java.io.IOException;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;import org.apache.commons.beanutils.BeanUtils;
import org.apache.commons.beanutils.ConvertUtils;
import org.apache.commons.beanutils.Converter;import com.anthony.domain.User;
import com.anthony.service.UserService;
import com.anthony.service.impl.UserServiceImpl;public class RegServlet extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {req.setCharacterEncoding("UTF-8");resp.setContentType("text/html;charset=UTF-8");//获取表单数据User user = new User();try {//解决日期是字符串的异常ConvertUtils.register(new Converter() {public Object convert(Class type, Object value) {Date date1 = null;if(value instanceof String) {String date = (String)value;SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");try {date1 = sdf.parse(date);} catch (ParseException e) {e.printStackTrace();}}return date1;}}, Date.class);BeanUtils.populate(user, req.getParameterMap());//调用业务层方法/逻辑UserService us = new UserServiceImpl();us.register(user);} catch (Exception e) {e.printStackTrace();}//分发转向resp.getWriter().write("注册成功,2秒之后跳转到主页");resp.setHeader("refresh", "2;url="+req.getContextPath()+"/index.jsp");}@Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {doGet(req,resp);}}

上面解决date日期和字符串转换的异常,利用下面代码一行搞定,已经帮我们封装好了这个代码。

package com.anthony.web.servlet;import java.io.IOException;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;import org.apache.commons.beanutils.BeanUtils;
import org.apache.commons.beanutils.ConvertUtils;
import org.apache.commons.beanutils.Converter;
import org.apache.commons.beanutils.locale.converters.DateLocaleConverter;import com.anthony.domain.User;
import com.anthony.service.UserService;
import com.anthony.service.impl.UserServiceImpl;public class RegServlet extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {req.setCharacterEncoding("UTF-8");resp.setContentType("text/html;charset=UTF-8");//获取表单数据User user = new User();try {//解决日期是字符串的异常ConvertUtils.register(new DateLocaleConverter(), Date.class);BeanUtils.populate(user, req.getParameterMap());//调用业务层方法/逻辑UserService us = new UserServiceImpl();us.register(user);} catch (Exception e) {e.printStackTrace();}//分发转向resp.getWriter().write("注册成功,2秒之后跳转到主页");resp.setHeader("refresh", "2;url="+req.getContextPath()+"/index.jsp");}@Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {doGet(req,resp);}}

再次注册就可以成功,查询数据库就插入数据进来了。本篇先不管两个密码输入不一致的校验。

这篇关于JavaWeb学习-MVC基础开发系列-2-用户注册功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

51单片机学习记录———定时器

文章目录 前言一、定时器介绍二、STC89C52定时器资源三、定时器框图四、定时器模式五、定时器相关寄存器六、定时器练习 前言 一个学习嵌入式的小白~ 有问题评论区或私信指出~ 提示:以下是本篇文章正文内容,下面案例可供参考 一、定时器介绍 定时器介绍:51单片机的定时器属于单片机的内部资源,其电路的连接和运转均在单片机内部完成。 定时器作用: 1.用于计数系统,可

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

Java五子棋之坐标校正

上篇针对了Java项目中的解构思维,在这篇内容中我们不妨从整体项目中拆解拿出一个非常重要的五子棋逻辑实现:坐标校正,我们如何使漫无目的鼠标点击变得有序化和可控化呢? 目录 一、从鼠标监听到获取坐标 1.MouseListener和MouseAdapter 2.mousePressed方法 二、坐标校正的具体实现方法 1.关于fillOval方法 2.坐标获取 3.坐标转换 4.坐

Spring Cloud:构建分布式系统的利器

引言 在当今的云计算和微服务架构时代,构建高效、可靠的分布式系统成为软件开发的重要任务。Spring Cloud 提供了一套完整的解决方案,帮助开发者快速构建分布式系统中的一些常见模式(例如配置管理、服务发现、断路器等)。本文将探讨 Spring Cloud 的定义、核心组件、应用场景以及未来的发展趋势。 什么是 Spring Cloud Spring Cloud 是一个基于 Spring

[word] word设置上标快捷键 #学习方法#其他#媒体

word设置上标快捷键 办公中,少不了使用word,这个是大家必备的软件,今天给大家分享word设置上标快捷键,希望在办公中能帮到您! 1、添加上标 在录入一些公式,或者是化学产品时,需要添加上标内容,按下快捷键Ctrl+shift++就能将需要的内容设置为上标符号。 word设置上标快捷键的方法就是以上内容了,需要的小伙伴都可以试一试呢!

AssetBundle学习笔记

AssetBundle是unity自定义的资源格式,通过调用引擎的资源打包接口对资源进行打包成.assetbundle格式的资源包。本文介绍了AssetBundle的生成,使用,加载,卸载以及Unity资源更新的一个基本步骤。 目录 1.定义: 2.AssetBundle的生成: 1)设置AssetBundle包的属性——通过编辑器界面 补充:分组策略 2)调用引擎接口API

RedHat运维-Linux文本操作基础-AWK进阶

你不用整理,跟着敲一遍,有个印象,然后把它保存到本地,以后要用再去看,如果有了新东西,你自个再添加。这是我参考牛客上的shell编程专项题,只不过换成了问答的方式而已。不用背,就算是我自己亲自敲,我现在好多也记不住。 1. 输出nowcoder.txt文件第5行的内容 2. 输出nowcoder.txt文件第6行的内容 3. 输出nowcoder.txt文件第7行的内容 4. 输出nowcode

Javascript高级程序设计(第四版)--学习记录之变量、内存

原始值与引用值 原始值:简单的数据即基础数据类型,按值访问。 引用值:由多个值构成的对象即复杂数据类型,按引用访问。 动态属性 对于引用值而言,可以随时添加、修改和删除其属性和方法。 let person = new Object();person.name = 'Jason';person.age = 42;console.log(person.name,person.age);//'J

java8的新特性之一(Java Lambda表达式)

1:Java8的新特性 Lambda 表达式: 允许以更简洁的方式表示匿名函数(或称为闭包)。可以将Lambda表达式作为参数传递给方法或赋值给函数式接口类型的变量。 Stream API: 提供了一种处理集合数据的流式处理方式,支持函数式编程风格。 允许以声明性方式处理数据集合(如List、Set等)。提供了一系列操作,如map、filter、reduce等,以支持复杂的查询和转

大学湖北中医药大学法医学试题及答案,分享几个实用搜题和学习工具 #微信#学习方法#职场发展

今天分享拥有拍照搜题、文字搜题、语音搜题、多重搜题等搜题模式,可以快速查找问题解析,加深对题目答案的理解。 1.快练题 这是一个网站 找题的网站海量题库,在线搜题,快速刷题~为您提供百万优质题库,直接搜索题库名称,支持多种刷题模式:顺序练习、语音听题、本地搜题、顺序阅读、模拟考试、组卷考试、赶快下载吧! 2.彩虹搜题 这是个老公众号了 支持手写输入,截图搜题,详细步骤,解题必备