1、servlet實現登陸。
我們先來看一下servlet實現註冊登陸。html
- <servlet>
- <servlet-name>LoginServlet</servlet-name> 3
- <servlet-class>demo.servlet.LoginServlet</servlet-class> 4
- </servlet>
- <servlet-mapping>
- <servlet-name>LoginServlet</servlet-name> 2
- <url-pattern>login</url-pattern> 1
- </servlet-mapping>
訪問順序爲1—>2—>3—>4,其中2和3的值必須相同。前端
url-pattern 標籤中的值是要在瀏覽器地址欄中輸入的 url,能夠本身命名,這個 url 訪問名爲 servlet-name 中值的 servlet,兩個 servlet-name 標籤的值必須相同,由於經過 servlet 標籤中的 servlet-name 標籤映射到 servlet-class 標籤中的值,最終訪問 servlet-class 標籤中的 class。java
還有,web.xml 的 / 表示的是http://localhost:8080/ + 工程名。轉自(點擊打開連接)web
一、jsp頁面spring
<form action="login" method = "post"> 用戶名:<input type="text"name = "userName"><br> 密 碼:<input type="password"name = "password"><br> <input type="submit" value="登陸">
二、點擊登陸按鈕後,提交表單,首先匹配web.xml中的路徑,找到<url-pattern>值是login的sevlet,而後根據name去匹配servlet類,找到LoginServlet。數據庫
public class LoginServlet extends HttpServlet implements Servlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doPost(request, response); } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String result = ""; // 獲取用戶名 String userName = request.getParameter("userName"); // 獲取密碼 String passwd = request.getParameter("password"); UserDao.SelectForLogin(userName, password); //數據中查找此人
request.getSession().setAttribute("userName", userName); response.sendRedirect("login_success.jsp");
}
}
三、而後再跳轉到登錄成功頁面瀏覽器
<body> <div align=center> ${userName } 歡迎您,登陸成功! </div> </body>
可是老是須要手寫跳轉servlet,開發效率比較低,因此就涌現除了不少框架,好比struct2,spring等等。cookie
2、springMVC
因爲SpringMVC是方法級別的攔截,SpringMVC的方法之間基本上獨立的,獨享request response數據。它還能夠和不少框架進行無縫集成,開發效率和性能高。如今不少公司都採用springMVC來進行開發,我們公司也是採用springMVC來進行。下面我介紹一下springMVC如何實現註冊登陸。session
一、jsp頁面(登陸)mvc
<div class="content"> <form action="login.do" method="post"> 用戶名:<input type="text" name="userName"> <p> 密 碼:<input type="password" name="password"> <p> <input class="submit" type="submit" value="登陸"> </form> </div>
二、而後一樣是匹配web.xml
<servlet> <servlet-name>spmvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>spmvc</servlet-name> <url-pattern>*.do</url-pattern> </servlet-mapping>
上面這段xml的意思就是,全部的以.do結尾的action都讓org.springframework.web.servlet.DispatcherServlet這個類來處理。load-on-startup元素標記容器是否在啓動的時候就加載這個servlet(實例化並調用其init()方法)。這時servlet不用初始化,而是交給容器去處理。
Spring主要也是經過DispatcherServlet實現了Servlet這個接口,又叫前端控制器,來自前端的請求會先到達這裏,它負責到後臺去匹配合適的handler。DispatcherServlet的主要工做流程以下:
前端請求到達DispatcherServlet。
前端控制器請求HandlerMappering 查找Handler。
若是查找到存在的處理器,進一步去調用service和dao層
返回結果再到controller層,渲染具體的視圖,返回結果給頁面。
三、而後加載sringMVC-servlet.xml配置文件。
<!-- 能夠掃描controller、service、... 這裏讓掃描controller,指定controller的包 --> <context:annotation-config></context:annotation-config> <context:component-scan base-package="com.qunar.fresh2017.controller"></context:component-scan>
四、而後開始掃描controller這個類,找到login.do。這時是經過註解來找到本身所須要的方法。
/** * 用戶登陸時,檢查數據庫中是否存在此人 * * @param userName 輸入的用戶名 * @param password 輸入的用戶密碼 * @param httpSession 設置session * @return 登錄成功返回登陸成功,不然返回登陸失敗 */ @RequestMapping("login.do") public String login(String userName, String password, HttpSession httpSession, HttpServletRequest request,HttpServletResponse resp) throws UnsupportedEncodingException { User user = UserDao.SelectForLogin(userName, password); //數據中查找此人 Optional<User> userPresent = Optional.of(user); if (userPresent.isPresent()) { Cookie cookie = new Cookie("nickName", URLEncoder.encode(user.getNickName(), "utf-8")); cookie.setMaxAge(24 * 60 * 60 * 7); resp.addCookie(cookie); request.setAttribute("nickName",user.getNickName()); resp.setCharacterEncoding("utf-8"); LOGGER.info("數據庫裏有這我的"); return "welcome"; } else { LOGGER.info("數據庫裏沒有這我的"); } return "loginerror"; }
@RequestMapping("login.do") 這個註解是SpringMVC中的一個註解,該註解說明的是,對於login.do的請求, 經過註解標籤下面的方法進行響應。至關於方法的一個URL。
五、最後在返回登陸成功界面
這時須要spring-servlet.xml裏的視圖解析器。
<!-- 視圖解析器 解析jsp解析,默認使用jstl標籤,classpath下的得有jstl的包 --> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <!-- 配置jsp路徑的前綴 --> <property name="prefix" value="/"/> <!-- 配置jsp路徑的後綴 --> <property name="suffix" value=".jsp"/> </bean>
上面這段代碼的意思是解析controller中方法返回的jsp頁面,前綴加「/」表示webapp根目錄,配置後綴「.jsp」表示自動在返回值後加.jsp後綴,這樣就找到了webapp下的wecome.jsp。
<div class="welcomediv">
歡迎:${nickName} </div>
經過EL表達式顯示登陸用戶暱稱。
至此springMVC登陸功能就實現完成了。
spring框架已是java web開發很主流的框架,這個框架有不少優勢固然也有它的不足之處,比於以前的servlet,它必定程度上簡化了開發人員的工做,使用servlet的話須要每一個請求都去在web.xml中配置一個servlet節點,而Spring 中的DispatcherServlet他會攔截全部的請求,進一步去查找有沒有合適的處理器,一個前端控制器就能夠。
下面在介紹一下session和cookie的使用方法。
一、session
新建session,並添加參數。
HttpSession session = request.getSession(); session.setAttribute("nickName", value);
jsp頁面獲取session
${nickName}
過濾器獲取session
String nickName = (String) session.getAttribute("nickName");