MVC+Servlet+JSP案例(下)

帶新手玩轉MVC——不講道理就是幹(下)

完整案例演示

 

案例代碼

LoginServlet

package servlet;

import domain.User;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.List;

/*
* 用戶登陸的Servlet
* */
@WebServlet("/login")
public class LoginServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        req.setCharacterEncoding("utf-8");
        resp.setCharacterEncoding("utf-8");

        //接收數據
        String username = req.getParameter("username");
        String password = req.getParameter("password");
        //從ServletContext域中得到保存用戶信息集合
        List<User> list = (List<User>) this.getServletContext().getAttribute("list");
        for (User user:list){
            //判斷用戶名是否正確
            if (username.equals(user.getUsername())){
                //判斷密碼是否正確
                if (password.equals(user.getPassword())){
                    //用戶名密碼都正確
                    //登陸成功
                    //判斷記住用戶名複選框是否勾選
                    String remember = req.getParameter("remember");
                    if ("true".equals(remember)){
                        //完成記住用戶名的功能
                        Cookie cookie = new Cookie("username",username);
                        //設置有效路徑
                        cookie.setPath("/login.jsp");
                        //設置有效時間
                        cookie.setMaxAge(60*60*24);
                        //將cookie回寫到瀏覽器
                        resp.addCookie(cookie);
                    }
                    //將用戶的信息保存到Session中
                    req.getSession().setAttribute("user",user);
                    resp.sendRedirect("/success.jsp");
                    return;
                }
            }
        }
        //登陸失敗
        req.setAttribute("msg","用戶名或密碼錯誤!");
        req.getRequestDispatcher("/login.jsp").forward(req,resp);

    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        doGet(req, resp);
    }
}

CookieUtils

package utils;



import javax.servlet.http.Cookie;



public class CookieUtils {

    public static Cookie findCookie(Cookie[] cookies,String name){

        if (cookies==null){

            //說明客戶端沒有攜帶Cookie

            return null;

        }else {

            //說明客戶端攜帶Cookie

            for (Cookie cookie:cookies){

                if (name.equals(cookie.getName())){

                    return cookie;

                }

            }

            return null;

        }

    }

}

success.jsp

<%@page import="domain.User"%>

<%@ 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" href="./css/login.css">

</head>

<body>

   <%

      if(session.getAttribute("user")!=null){

         User user = (User)session.getAttribute("user");

         System.out.println(user.getPath());

         // 得到絕對路徑最後一個\的位置

         int idx = user.getPath().lastIndexOf("\\");

         // 得到文件上傳的惟一文件名:

         String fileName = user.getPath().substring(idx+1);

   %>

   <div class="login">

      <div class="header">

         <h1>登陸成功</h1>

      </div>

      <div class="content">

         <table align="center">

            <tr>

               <td align="center"><img src="/img/<%= fileName %>" /></td>

            </tr>

            <tr>

               <td align="center">歡迎<%= user.getNickname() %>,登陸成功!</td>

            </tr>

         </table>



      </div>

   </div> 

   <%       

      }else{

   %>

   <div class="login">

      <div class="header">

         <h1>您尚未登陸!請先去<a href="/login.jsp">登陸</a>!</h1>

      </div>

   </div>

   <%    

      }

   %>





</body>

</html>

特別說明

若是有朋友是按照上篇的代碼一路敲過來的,這裏有個問題,就是啓動服務器後你必須先訪問/initServlet去執行init()方法,不然你註冊的信息將沒法存儲。css

 

在這再給你教另一種方法,就是在Web.xml中配置InitServlet,當服務器一啓動,init()方法就馬上被執行,不用你再去手動訪問了,操做過程以下:html

第一步:找到web.xml,配置以下圖所示的信息java

 

 

 

 

<!DOCTYPEweb-appPUBLIC

 "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"

 "http://java.sun.com/dtd/web-app_2_3.dtd" >



<web-app>

    <servlet>

        <servlet-name>initServlet</servlet-name>

        <servlet-class>servlet.InitServlet</servlet-class>

        <load-on-startup>2</load-on-startup>

    </servlet>

    <servlet-mapping>

        <servlet-name>initServlet</servlet-name>

        <url-pattern>/initServlet</url-pattern>

    </servlet-mapping>

</web-app> 

第二步:去掉@WebServlet(「/initServlet」)註解web

 

 

好了,這樣就完成了,如今已開啓服務器,就能夠直接訪問註冊頁面進行註冊了。 設計模式

案例總結

寫到這案例算是結束了,這裏面用了MVC的設計模式,運用了JSP,Servlet裏面的知識,有Web四大域對象的使用,參數的請求和接收,轉發和重定向,集合的使用,還有Cookie和Session的使用,表單數據的接收,文件的上傳,涉及的方面多,但不超綱,都是JavaSE中學過的部分,在這作個系統性的應用,我的認爲此案例適合於初學者練手,但願能幫助到一些真正須要的朋友。瀏覽器

*****************************************************************************************************服務器

個人博客園地址:https://www.cnblogs.com/zyx110/cookie

相關文章
相關標籤/搜索