功能:
  > 注册
  > 登录
 
---------------------------------
 
JSP:
  * login.jsp  --> 登录表单
  * regist.jsp --> 注册表单
  * index.jsp -->  主页(只有登录成功才能看到)
 
Servlet:
  * LoginServlet
  * RegistServlet
 
Service:
  * UserService --> 与用户相关的业务类
 
Dao:
  * UserDao --> 与用户相关的数据类
 
Domain:
  * User(对应数据库,还要对应所有表单)
    > username
    > password
    > verifyCode
 
---------------------------------
 
数据库设计
  * users.xml(注意表头)
    <users>
      <user username="xxx" password="xxx"/>
      <user username="xxx" password="xxx"/>
    </users>
 
---------------------------------
 
步骤:
 
1. 创建空项目
2. 导包:
  * CommonUtils
  * commons-beanutils.jar
  * commons-logging.jar
  * dom4j
  * jstl.jar
  * standard.jar
 
3. 建包
  * com.pwc.user.domain
    > User
  * com.pwc.user.dao
    > UserDao
  * com.pwc.user.service
    > UserService
  * com.pwc.user.web.servlet
    > LoginServlet
    > RegistServlet
 
4. jsp
  * login.jsp
  * regist.jsp
  * index.jsp
 
5. 在F盘下创建一个users.xml文件!
  * 添加根元素<users>
  * 保证文件为utf-8编码!!!
 
---------------------------------
 
注册功能
 
regist.jsp
  > 第一步:完成regist.jsp的基本功能!
RegistServlet
  > 封装表单数据,封装到User对象中。
  > 调用service的regist()方法
    * 如果这个方法没有出问题,输出“注册成功”
    * 如果这个方法抛出了异常,把错误信息保存到request域,转发到regist.jsp(显示错误信息)
UserService#regist()
  > 没有返回值,但注册失败抛出一个自定义的异常!可以在异常中添加异常信息!(自定义一个异常类)
  > 校验用户名是否已被注册(通过用户名查询用户),如果已被注册,抛出异常,异常信息为“用户名已被注册!”
  > 添加用户
UserDao:通过业务分析,得到结果:需要提供两个方法
  > 按用户名查询用户对象:User findByUsername(String username)
  > 插入一个用户到数据库中:void add(User user)
 
工作:
1. 在service层添加一个UserException
2. dao;
  * User findByUsername(String username)
  * void add(User user)
3. service
  * void regist() throws UserException
4. servlet
  1). 封装表单数据到User对象中
  2). 使用user调用service的regist()方法
  3). 如果得到UserException,那么把异常信息保存到request域中,转发回regist.jsp,(数据的回显)
  4). 输出“注册成功”
 
---------------------------------
 
给注册添加验证码
 
1. VerifyCode类
  * BufferedImage getImage() --> 获取随机的验证码图片
  * String getText() --> 获取图片上的文本
  * static output(BfferedImage, OutputStream) --> 把图片写入到指定的输出流中。
 
2. VerifyCodeServlet
  * 获取随机验证码图片
  * 把验证码图片上的文本保存到session中
  * 把图片响应到response的outputStream中
 
3. regist.jsp
  * 添加<img src="指向Servlet" />
  * 添加一个文本框,用来输入验证码
  * “看不清,换一张”,是一个超链接。把上面的<img>的src重新再次指向Servlet!为了处理浏览器的
 
缓存,需要使用时间来做参数!
 
4. 修改RegistServlet
  * 校验验证码!
  * 错误:保存表单数据到request域、保存错误信息到request域,转发回regist.jsp
  * 正确:什么都不做,向下执行原来代码!
 
---------------------------------
 
服务器端表单(输入)校验
 
我们把这段校验,放到获取表单数据之后,验证码校验之前!
 
1. 使用Map类型来装载错误信息!
  * key:表单项名称,例如:username、password、verifyCode
  * value:
    > 非空:用户名不能为空,或者是“密码不能为空”
    > 长度:用户名长度必须在3~20之间 密码长度必须在3~20之间
 
2. 在校验失败时,向map添加错误信息!那个字段出错,就给哪个字段添加错误信息!

3. 判断map是否为空(长度是否为0),如果不空,说明有错误存在,保存map到request域,保存form到request域(回显),转发回regist.jsp

4. 在regist.jsp页面中,显示map中的错误信息。${map.username}
 
=================================
 
登录功能
 
页面:login.jsp --> 登录表单!
 
LoginServlet --> 
  1. 获取表单数据,封装到User中
  2. 调用service的login()方法,传递form过去!
  3. 如果service的login()方法,没有抛出异常!返回一个User对象!
  4. 有异常:获取异常信息,保存到request域,保存form,转发到login.jsp
  5. 没异常:保存返回的user对象到session中!!!重定向到welcome.jsp(显示当前用户信息!)
 
UserService#login()
  public User login(User form) {...}
  1. 使用用户名查询数据库,得到返回的User
    > 返回为null,抛出异常,异常信息为(用户名不存在)
    > 返回不为null,获取查询出来的user的password与form的password进行比较!如果不同:抛出异常(密码错误!)
    > 如果相同,返回查询结果!
 
UserDao
  1. 通过用户名查询用户!(方法已经存在了!)

=================================

注册 流程
验证 流程

注册登录系统项目思路 -- javaweb的更多相关文章

  1. JavaWeb笔记——注册登录系统项目思路

    功能:   > 注册   > 登录 --------------------------------- JSP:   * login.jsp  --> 登录表单   * regist ...

  2. php注册登录系统(一)-极简

    序 登录注册系统是日常上网最普通的操作,我设了一个分类一步步完善注册登录系统,若有哪里错误请慧教 所用语言:php 数据库 :mysql 本次实现功能: 1.用户注册 2.用户登录 主要文件: 完整代 ...

  3. 一个基于Unix套接字的注册登录系统

    2016/5/5 今天,我参考<Unix网络编程-卷1>第5章的TCP回射客户/服务器程序写了一个简单的注册登录系统,其功能如下:(1)注册.客户端向服务器发送个人信息请求注册,服务器查询 ...

  4. 基于javaweb人脸识别注册登录系统

    ---恢复内容开始--- 现在是2019年,人脸识别技术已经相当成熟了,百度自2017年发布人脸识别技术,已经被广泛应用,不管从现在的iphoneX掀起的面部解锁到手机应用端的各种人脸认证,这一技术已 ...

  5. Django+bootstrap+注册登录系统

    转自:https://www.cnblogs.com/robindong/p/9610057.html Robin_D 博客园 首页 新随笔 联系 订阅 管理 随笔 - 10  文章 - 0  评论 ...

  6. vue2.0+koa2+mongodb实现注册登录

    前言 前段时间和公司一个由技术转产品的同事探讨他的职业道路,对我说了一句深以为然的话: "不要把自己禁锢在某一个领域,技术到产品的转变,首先就是思维上的转变.你一直做前端,数据的交互你只知道 ...

  7. crm 系统项目(一) 登录,注册,校验

    crm 系统项目(一) 登录,注册,校验 首先创建一个Django项目,关于配置信息不多说,前面有~ models.py文件下创建需要的表格信息,之后导入数据库 from django.db impo ...

  8. 单点登录系统(SSO)的开发思路

    单点登录并不是一个新鲜的玩意儿,比较官方的解释是企业业务整合的解决方案之一,通俗来讲SSO就是一个通用的用户中心,国内比较流行的UCenter就是一套单点登录解决方案.而近期以CSDN明文存储用户密码 ...

  9. 多平台的网站实现单点登录系统(SSO)的开发思路 让你的会员中心更加统一(参考资料)

    单点登录并不是一个新鲜的玩意儿,比较官方的解释是企业业务整合的解决方案之一,通俗来讲SSO就是一个通用的用户中心,国内比较流行的UCenter就是一套单点登录解决方案.而近期以CSDN明文存储用户密码 ...

随机推荐

  1. JSP page指令

    JSP page指令: JSP文件: <%@ page language="java"%> <%@ page import="java.util.*&q ...

  2. yum网络源配置

    [root@xuegod60 ~]# mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak[root@x ...

  3. Hadoop-2.x启动HDFS和YARN的方式

    逐一启动(实际生产环境中的启动方式) * sbin/hadoop-daemon.sh start|stop namenode|datanode|journalnode * sbin/yarn-daem ...

  4. 遍历ul下的li,点击弹出li的索引

    首先我们需要一个html结构 <div > <ul> <li>a</li> <li>a</li> <li>a< ...

  5. 部署LNMP架构Blog博客平台 ---惟净

    部署环境:VM虚拟机 操作系统:CentOS-6.8-x64 IP地址:192.168.31.91Mysql数据库版本:5.6.34 Cmake软件包版本:3.5.2Nginx软件包版本:1.10.2 ...

  6. 如何利用fis3来模拟后台返回数据

    Node 版本要求 0.8.x,0.10.x, 0.12.x,4.x,6.x,不在此列表中的版本不予支持.最新版本 node 支持会第一时间跟进,支持后更新支持列表 1.安装fis3 npm inst ...

  7. 代码审计中的XSS反射型漏洞

    XSS反射型漏洞 一 XSS漏洞总共分三总 XSS反射型漏洞,XSS保存型漏洞,基于DOM的XSS漏洞 这次主要分享XSS反射型漏洞 基本原理:就是通过给别人发送带有恶意脚本代码参数的URL,当URL ...

  8. 利用hexo+github+nodejs搭建自我博客的一天

    放一张比较喜欢的背景图镇楼,伪文艺一波.因为刚刚抱着四个快递从公司大门走到宿舍,快递都比我高,坐电梯的时候电梯里面的灯一闪一闪,电梯还摇晃,上演了一波鬼吹灯,惊魂未定... 说正题:我喜欢的博客应该是 ...

  9. 使用Jmeter3.1进行接口测试(包含需登录后测试的接口)

    Jmeter版本为3.1,以下只针对此版本进行测试说明: 1.打开Jmeter3.1: 启动命令路径:apache-jmeter-3.1\bin\jmeter.bat 2.测试步骤: 1.测试计划-- ...

  10. Animate自定义动画

    在jQuery中出了基本的动画之外,还有用户 可以自定义的函数,Animate() 用于创建自定义动画的函数. apI上指出: 这个函数的关键在于指定动画形式及结果样式属性对象.这个对象中每个属性都表 ...