学习目标:
运用Servlet+JSP+MySQL+JDBCTempleat+Duird+BeanUtilS+tomcat技术。实现用户信息的增删改查操作(登录功能及界面实现)。
步骤:
1.根据login.jsp界面的表单提交到的action值写对应的loginServlet的实现
2.保证数据库中有用于登录的username和password对应的列,并更新到对应的entity/domain中的实体类中,添加对应的get和set方法.
package com.fjut.webCRUD.web.servlet;
import com.fjut.webCRUD.entity.User;
import com.fjut.webCRUD.service.IUserService;
import com.fjut.webCRUD.service.impl.UserServiceImpl;
import org.apache.commons.beanutils.BeanUtils;
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 javax.servlet.http.HttpSession;
import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.util.Map;
@WebServlet("/loginServlet")
public class LoginServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//1.设置编码
request.setCharacterEncoding("utf-8");
//2.获取数据
//2.1获取用户填写验证码
String verifycode = request.getParameter("verifycode"); //用的是<input type="text" name="verifycode" class="form-control" id="verifycode" placeholder="请输入验证码" style="width: 120px;"/>中的name属性的值
//3.验证码校验
HttpSession session = request.getSession();
String checkcode_server = (String) session.getAttribute("CHECKCODE_SERVER");
session.removeAttribute("CHECKCODE_SERVER");//确保验证码一次性
if(!checkcode_server.equalsIgnoreCase(verifycode)){ //判断验证码信息不区分大小写
//验证码不正确
//提示信息
request.setAttribute("login_msg","验证码错误!");
//跳转登录页面
request.getRequestDispatcher("/login.jsp").forward(request,response);
return;
}
Map<String, String[]> map = request.getParameterMap();
//4.封装User对象
User user = new User();
try {
BeanUtils.populate(user,map); //将获取到的username和password封装到对象里面
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
//5.调用Service查询
IUserService service = new UserServiceImpl();
User loginUser = service.login(user);
//6.判断是否登录成功
if(loginUser != null){
//登录成功
//将用户存入session
session.setAttribute("user",loginUser);
//跳转页面
response.sendRedirect(request.getContextPath()+"/index.jsp");
}else{
//登录失败
//提示信息
request.setAttribute("login_msg","用户名或密码错误!");
//跳转登录页面
request.getRequestDispatcher("/login.jsp").forward(request,response);
}
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request, response);
}
}
小总结:
LoginServlet编写的逻辑:
1.设置编码(防止乱码)
2.获取login.jsp界面的数据(小细节:先获取验证码,判断验证码是否正确,如果验证码不正确,就不需要去到数据库中查询对应的登录数据.可以很大节省时间).
3.如果验证码正确, 将login.jsp界面的用户名和密码信息封装进用户类中.
4.用封装的信息去service层中调用查询登录信息是否存在(只需要返回是否存在即可).具体查询过程调用dao层的查询方法.
5.为了登录进去后显示(“xxx,欢迎您”)的相关显示需要,(一次会话的多次请求)我们将查询到的用户数据存入session中传到对应界面,
6.中login.jsp中若需要展示(验证码错误/用户名或密码错误的相关信息)则需要设置login.jsp中对应的值.
6.1用户名或密码错误.
6.2验证码错误
总结:
web项目实现登录的过程: