• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >JSP > JSP学习之Java Web中的安全控制实例详解

JSP学习之Java Web中的安全控制实例详解

作者:老李-大连 字体:[增加 减小] 来源:互联网 时间:2017-05-11

老李-大连通过本文主要向大家介绍了JSP学习之Java Web中的安全控制实例详解等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

本文实例讲述了JSP学习之Java Web中的安全控制。分享给大家供大家参考。具体如下:

一、目标:

① 掌握登录之后的一般处理过程;
② 能够为每个页面添加安全控制;
③ 能够共享验证代码;
④ 使用过滤器对权限进行验证;
⑤ 能够对文件的局部内容进行验证;
⑥ 掌握安全验证码的基本实现方式;
⑦ 通过异常处理增强安全性。

二、主要内容:

① 通过修改前面的登录功能,分别对管理员和普通用户的登录进行处理;
② 为管理员才能访问的页面添加控制;
③ 共享各个页面中的控制代码,使用专门的文件,然后在需要的时候调用;
④ 使用过滤器降低重复验证代码;
⑤ 通过标准标签库完成页面局部信息的安全控制;
⑥ 介绍安全验证码的基本实现方式;

1、完善登录功能

正常情况下,管理员登录成功之后跳转到管理员默认工作界面;普通用户登录之后跳转到普通用户默认工作界面;用户登录失败后跳转到登录界面重新登录。
为了完成这个功能,需要编写管理员界面和普通用户界面。
管理员界面对应的文件为manager.jsp,代码如下:

manager.jsp代码:
管理员操作界面

普通用户界面对应的文件为commonuser.jsp,代码如下:

commonuser.jsp代码:
普通用户界面

修改登录的Servlet,修改后的代码如下:

LoginProcess.java代码:

package servlet;
import javabean.User;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class LoginProcess extends HttpServlet {
    public void doGet(HttpServletRequest request, HttpServletResponse response)
           throws ServletException, IOException {
       doPost(request,response);
    }
    public void doPost(HttpServletRequest request, HttpServletResponse response)
           throws ServletException, IOException {
       // 获取信息
       String username = request.getParameter("username");
       String userpass = request.getParameter("userpass");
       // 调用JavaBean
       User user = new User();
       user = user.findUserByName(username);
       String forward;
       if(user==null){
           forward="failure.jsp";
       }else if(user.getUserpass().equals(userpass)){
           if(user.getUsertype().equals("1")){
              forward="manager.jsp";
           }
           else{
              forward="commonuser.jsp";
           }
       }else{
           forward="failure.jsp";
       }
       RequestDispatcher rd = request.getRequestDispatcher(forward);
       rd.forward(request,response);
    }
}

</div>

2、为每个界面添加安全控制

上面的实例中登录成功后会跳转到管理员界面或者普通用户界面,但是如果用户直接输入管理员界面,就会跳过登录界面。例如用户可以直接输入:http://127.0.0.1:8080/ch11/manager.jsp。

为了解决这个问题,在每个有安全限制的界面都应该增加安全控制。需要完成两项工作:

① 在登录之后把用户的信息写入到session中;
② 在每个页面中,从session中获取信息进行验证;

在登录之后把用户信息写入到session中,下面是修改后的LoginProcess.java代码:

LoginProcess.java代码:

package servlet;
import javabean.User;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class LoginProcess extends HttpServlet {
    public void doGet(HttpServletRequest request, HttpServletResponse response)
           throws ServletException, IOException {
       doPost(request,response);
    }
    public void doPost(HttpServletRequest request, HttpServletResponse response)
           throws ServletException, IOException {
       // 获取信息
       String username = request.getParameter("username");
       String userpass = request.getParameter("userpass");
       // 调用JavaBean
       User user = new User();
       user = user.findUserByName(username);
       // 得到session对象
       HttpSession session = request.getSession(true);
       String forward;
       if(user==null){
           forward="failure.jsp";
       }else if(user.getUserpass().equals(userpass)){
           if(user.getUsertype().equals("1")){
              // 在session对象中存储信息
              session.setAttribute("usertype","1");
              forward="manager.jsp";
           }
           else{
              session.setAttribute("usertype","0");
              forward="commonuser.jsp";
           }
       }else{
           forward="failure.jsp";
       }
       RequestDispatcher rd = request.getRequestDispatcher(forward);
       rd.forward(request,response);
    }
}

</div>

以commonuser.jsp为例介绍如何在每个文件中进行安全控制,下面是修改后的代码:

commonuser.jsp代码:

<%@ page contentType="text/html;charset=gb2312"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<c:if test="${usertype!=/"0/"}">
  <jsp:forward page="login.jsp"/>
</c:if>

</div>

普通用户界面

这样,如果不登录而直接访问commonuser.jsp就会跳转到登录界面。

3、采用专门的文件进行验证

因为很多页面都要编写验证的代码,所以可以把这些代码放在一个文件中进行共享,需要的使用调用共享文件。下面仍然以commonuser.jsp为例介绍如何实现验证代码的共享。

使用专门的文件存放共享代码:

check.jsp代码:

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<c:if test="${usertype!=/"0/"}">
  <jsp:forward page="login.jsp"/>
</c:if>

</div>

在需要验证的文件中导入这个专门的文件。以commonuser.jsp为例:

commonuser.jsp代码:

<%@ page contentType="text/html;charset=gb2312"%>
<%@ include file="check.jsp" %>

</div>

普通用户界面

使用include指令包含目标文件,在把JSP转换成Java文件的时候,会把目标文件的代码拷贝到当前文件。
再运行测试,结果是相同的。

4、使用过滤器对权限进行验证

把具有相同权限要求的文件放在相同的文件夹下,对文件夹的访问进行统一的过滤。

编写用于过滤的Servlet,代码如下:

CommonCheck.java代码:

package servlet;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpSession;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class CommonCheck extends HttpServlet implements Filter {
public void doFilter(ServletRequest arg0, ServletResponse arg1,
        FilterChain arg2) throws IOException, ServletException {
    // 得到session
    HttpSession 



 
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

相关文章

  • 2017-05-11访问JSP文件或者Servlet文件时提示下载的解决方法
  • 2017-05-11JSP实现网页访问统计
  • 2017-05-11jsp传参 servlet接收中文乱码问题的解决方法
  • 2017-05-11java Freemarker页面静态化实例详解
  • 2017-05-11jsp编程去除空白行的方法
  • 2017-05-11jsp+servlet+jdbc实现对数据库的增删改查
  • 2017-05-11JDK 1.5之Generics
  • 2017-05-11Spring组件自动扫描详解及实例代码
  • 2017-05-11几则JSP入门知识总结
  • 2017-05-11JSP输出HTML时产生的大量空格和换行的去除方法

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • Jsp连接Access数据库(不通过建立ODBC数据源的方法)
    • JSP自定义标签基础知识学习
    • 如何用Jsp读取Mysql数据库
    • 在JSTL EL中处理java.util.Map,及嵌套List的情况
    • jsp+servlet+javabean实现数据分页方法完整实例
    • jsp用过滤器解决中文乱码问题的方法
    • jsp+ajax实现无刷新(鼠标离开文本框即验证用户名)实现思路
    • Java中使用JCOM操作Office对象
    • JSP常见的三个编译指令page、include、taglib
    • jsp从数据库获取数据填充下拉框实现二级联动菜单的方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有