
UserFilter.java
~~~
package zyw.filter;
import zyw.bean.User;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
@WebFilter(filterName = "UserFilter",urlPatterns = "/category")
public class UserFilter implements Filter {
public void destroy() {
}
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
req.setCharacterEncoding("utf-8");
resp.setContentType("text/html;charset=utf-8");
// 1 獲取serssion 校驗用戶信息
HttpServletRequest request= (HttpServletRequest) req;
HttpServletResponse response= (HttpServletResponse) resp;
HttpSession session = request.getSession();
User user = (User) session.getAttribute("user");
// 2 判斷user信息是否為空 ,空則跳轉登錄界面
if (user==null) {
response.sendRedirect(request.getContextPath()+"/login.jsp");
return;
}
// 3 user不為空 放行
chain.doFilter(req, resp);
}
public void init(FilterConfig config) throws ServletException {
}
}
~~~
UserServlet.java
~~~
package zyw.web;
import org.apache.commons.beanutils.BeanUtils;
import zyw.bean.User;
import zyw.service.UserService;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.sql.SQLException;
import java.util.Map;
@WebServlet(name = "UserServlet",urlPatterns = "/user")
public class UserServlet extends BaseServlet {
/* protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request,response);
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String method = request.getParameter("method");
if ("login".equals(method)){
login(request,response);
}else if("register".equals(method)){
register(request,response);
}
}*/
public void login(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String name = request.getParameter("name");
String password = request.getParameter("password");
UserService userService=new UserService();
User user=null;
try {
//調用service中登錄方法
user = userService.login(name, password);
} catch (SQLException e) {
e.printStackTrace();
}
if (user!=null){
//登錄成功后我們再獲取是否保存密碼的信息,如果失敗了保存密碼就沒有意義了
String remember = request.getParameter("remember");
if (remember.equals("yes")){
// 將用戶名和密碼加入到cookie中
Cookie nameCookie = new Cookie("name", name);
Cookie passwordCookie = new Cookie("password", password);
//設置cookie的有效期 防止銷毀
nameCookie.setMaxAge(60*10);//10分鐘
passwordCookie.setMaxAge(60*10);
//將cookie發送給客戶端保存
response.addCookie(nameCookie);
response.addCookie(passwordCookie);
}
//權限控制登錄
request.getSession().setAttribute("user",user);
//登錄成功跳轉生鮮種類列表界面
response.sendRedirect(request.getContextPath()+"/category?method=queryCategoryList¤tCount=0¤tPage=0");
}else {
//登錄失敗提示
response.setContentType("text/html;charset=utf-8");
response.getWriter().write("用戶登錄失敗");
}
}
public void register(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String name = request.getParameter("name");
String id = request.getParameter("id");
String password = request.getParameter("password");
String email = request.getParameter("email");
User user=new User();
Map<String,String[]> stringMap =request.getParameterMap();
try {
//分別將屬性設置到對象中
// BeanUtils.setProperty(user,name,name);
//將屬性的map集合封裝到對象中
BeanUtils.populate(user,stringMap);
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
UserService userService=new UserService();
// boolean register = userService.register(user);
boolean register = userService.register(user);
if (register) {
response.sendRedirect(request.getContextPath()+"login.jsp");
}else {
response.setContentType("text/html;charset=utf-8");
response.getWriter().write("注冊失敗");
}
}
}
~~~
主要在UserServlet.java中添加
~~~
//權限控制登錄
request.getSession().setAttribute("user",user);
~~~
本項目源碼,下載密碼:higj ,[點擊下載](https://pan.baidu.com/s/1sD701efqdonZ71efrMO2JQ)
- 學習心得
- 將jar包加入項目中
- Servlet
- 編寫第一個Servlet
- 使用Servlet3.0創建Servlet
- HttpServletRequest簡介-獲取請求行和請求頭
- HttpServletResponse獲取請求參數
- response對象發送響應行和響應頭
- HttpServletResponse發送請求體
- 【實例】驗證碼
- Servlet的生命周期
- ServletConfig對象
- ServletContext-獲取項目初始化參數
- ServletContext對象-在多個Servlet之間共享參數
- 請求轉發
- 【實例】登錄錯誤時顯示錯誤界面
- 重定向介紹
- 網頁的自動刷新
- Servlet線程安全
- 案例 文件下載
- Cookie與Session會話技術
- 會話技術概述
- Cookie的會話流程
- 獲取Cookie
- 【案例 】記錄網站上一次訪問時間
- Session的會話流程
- 使用Session域對象存取數據
- Session的生命周期和持久化
- 【實例】購物車的簡單使用
- JSP技術
- JSP指令
- JSP隱式對象
- JSP標簽
- JSTL標簽庫
- EL表達式
- EL的內置對象和執行表達式
- JSTL簡介
- JSTL-if標簽
- JSTL-forEach標簽
- 【案例】實現商品列表展示
- MySQL數據庫
- SQL語句
- 命名規則與數據類型
- SQL-增刪改查
- 設計數據庫
- JDBC的應用
- JDBC連接數據庫
- 查詢
- 插入.刪除.修改
- Junit單元測試
- 預防SQL注入
- JDBCutils工具類
- 監聽器Listener
- ServletContextListener
- HttpSessionListener和ServletRequestListener
- 域對象屬性監聽器
- 對象感知監聽器
- 【案例】商品促銷活動推廣
- 過濾器Filter
- 創建一個過濾器
- Filter生命周期和配置
- 【案例】解決中文輸出亂碼問題
- XML入門
- XML元素和解析方式
- XML約束
- 實戰-生鮮后臺管理系統
- MVC和三層架構
- 項目需求和項目搭建
- 數據庫設計
- 注冊功能
- 登錄功能
- 記住密碼
- BeanUtils的使用
- Servlet的抽取(上)
- Servlet的抽取(下)
- 增加生鮮種類
- 查詢生鮮列表
- 分頁功能
- 修改生鮮信息
- 刪除生鮮功能
- 權限控制Filter