过滤器实现登录

过滤器实现登录(源码待上传)

1.项目思路分析:

      首先创建一个项目---->login.jsp,sucess.jsp,fail.jsp---->login.jsp提交用户名和密码到LoginServlet.java-

                                   处理业务逻辑--->在web.xml建立过滤器--->

2.代码分析

login.jsp

<body>
<form action="<%=request.getContextPath() %>/servlet/LoginServlet" method="post">
用户名:<input type="text" name="username">
密码:<input type="password" name="password">
<input type="submit" value="提交">
</form>
</body>

web.xml

<filter>
<filter-name>LoginFilter</filter-name>
<filter-class>com.imooc.LoginFilter.LoginFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>LoginFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

fail.jsp

<body>
登录失败
</body>

sucess.jsp

<body>
登录成功${name }
</body>

LoginServlet.jsva

public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String username = request.getParameter("username");
String password = request.getParameter("password");

System.out.println(username);

if("admin".equals(username) && "admin".equals(password)){

HttpSession session = request.getSession();
session.setAttribute("username", username);
response.sendRedirect(request.getContextPath()+"/sucess.jsp");
}else{

response.sendRedirect(request.getContextPath()+"/fail.jsp");
}

}

 

LoginFilter.java

public class LoginFilter implements Filter {

private FilterConfig config;

@Override
public void destroy() {

}

@Override
public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2) throws IOException, ServletException {

HttpServletRequest request = (HttpServletRequest) arg0;
HttpServletResponse response = (HttpServletResponse) arg1;
HttpSession session = request.getSession();

String noLoginPaths = config.getInitParameter("noLoginPaths");

String charset = config.getInitParameter("charset");
if(charset==null){
charset = "UTF-8";
}
request.setCharacterEncoding(charset);

if(noLoginPaths!=null){
String[] strArray = noLoginPaths.split(";");
for (int i = 0; i < strArray.length; i++) {

if(strArray[i]==null || "".equals(strArray[i]))continue;

if(request.getRequestURI().indexOf(strArray[i])!=-1 ){
arg2.doFilter(arg0, arg1);
return;
}
}

}

if(session.getAttribute("username")!=null){
arg2.doFilter(arg0, arg1);
}else{
response.sendRedirect("login.jsp");
}

}

@Override
public void init(FilterConfig arg0) throws ServletException {
config = arg0;
}

}

 

转载于:https://www.cnblogs.com/5scxy/articles/5800585.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值