`
zxmzxy
  • 浏览: 19927 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
社区版块
存档分类
最新评论

[原创]基于TOMCAT的安全认证

阅读更多

      做过WEB项目的都知道,一但涉及用户,我们不得不为用户登录写一堆繁杂的验证代码。当然Spring AOP的诞生为我们的权限管理提供了不少的便利。甚至你也以用自己写的Filter(过滤器)来对你的程序进行登录时的验证。今天在这里和大家分享一种更为简便的方法,它就是Java Web的安全验证机制。
      这种机制是对立地WEB的容器之上的,如Tomcat,JBoss等,你只须在你应用中的web.xml文件中做一定的配置就可以完成一个简单的登录验证的功能。确切地说WEB安全验证机制不仅可以让我们完成登录的功能,它更侧重于安全两字。你可以把受保护的资源全部定义在你的资源集里面,这样用户只有在取得了合法的身份验证之后才可以访问,它可以保护  WEB的整个应用、某个子文件夹、甚至于特定的一类文件,这将取决于你对资源集的定义。
      Tomcat容器支持以下四种认证方式:
     1. BASIC认证:这种方式被认为是最不安全的认证,因为它没有提供强烈的加密措施。
     <login-config>
          <auth-method>BASIC</auth-method>
    </login-config
    2. DIGEST认证:相比于BASIC认证,它是种比较安全的认证,它在认证时将请求数据 通过MD5的加密方式进行认证。
     <login-config>
         <auth-method>DIGEST</auth-method>
     </login-config>

     3.FORM认证:这是种基础自定义表单的认证,你可以指定登录时的验证表单。
      <login-config>
         <auth-method>FORM</auth-method>
         <form-login-config> 
             <!—创建登录表单 -->
             <form-login-pages>/login.htm</form-login-pages>
             <!—创建错误表单 -->
             <form-error-pages>/error.html</form-error-pages>
          </form-login-config>
       </login-config>
     

       以下是login.htm的内容:(注意form的action还有input元素的name,这些是固定的)

       <form action="j_security_check" method="post">
           Username<input type="text" name="j_username" /><br />
           Password<input type="password" name="j_password" /><br />
          <input type="submit" />
       </form>
    4.CLIENT-CERT认证:这是一种基于客户端证书的认证方式,比较安全。但缺陷是在没有安全证书的客户端无法使用。
     <login-config>
         <auth-method>CLIENT-CERT</auth-method>
    </login-config>

     下面介绍一下,配置认证的步骤:
     1.定义角色:这些角色可以是TOMCAT的tomcat-user.xml文件中定义的默认角色及用户,也可以是自己创建的数据库角色与用户表。以下分别介绍:
     1.1 基本TOMCAT已有用户及角色的认证配置:
     tomcat-users.xml中的role元素
    <tomcat-users>
      <role rolename=”Admin”/>
      <role rolename=”Manager”/>
      <user username=”admin”password=”admin” role=”Admin, Manager”/>
    </tomcat-users>
    web.xml文件中的security-role元素
    <security-role>
    <!—该角色须在tomcat-users.xml定义过-->
        <role-name>Admin</role-name>
    </security-role>

    1.2 基本自定义数据库用户表的认证配置:
     如果你想基于自己定义的数据表进行认证,那你得在META-INF文件夹下创建一个名为 context.xml文件,配置如下内容:
     <?xml version="1.0" encoding="UTF-8"?>
    <Context path="/mycms">
    <Realm className="org.apache.catalina.realm.JDBCRealm" 
                 connectionName="root" 
                 connectionPassword="123456"
                 connectionURL="jdbc:mysql://localhost:3306/mycms"
                 driverName="com.mysql.jdbc.Driver"
                 roleNameCol="rolename"
                 userCredCol="password"
                 userNameCol="username"
                 userRoleTable="mc_userroles"
                 userTable="mc_users"/>
      </Context>
     这里配置了数据库的连接信息以及指定了认证的用户表及角色表。
     2 定义资源/方法约束
     在web.xml文件中定义如元素:
     <security-constraint>
        <display-name>MyCMS</display-name>
        <web-resource-collection>
            <web-resource-name>Protected Area</web-resource-name>
            <!-- Define the context-relative URL(s) to be protected -->
            <url-pattern>/admin/*</url-pattern>
        </web-resource-collection>
        <auth-constraint>
            <!-- Anyone with one of the listed roles may access this area -->
            <role-name>Admin</role-name>
        </auth-constraint>
    </security-constraint>
    <!-- Login configuration uses form-based authentication -->
    <login-config>
        <auth-method>BASIC</auth-method>
        <realm-name>MyCMS</realm-name>
    </login-config>
   
    <!-- Security roles referenced by this web application -->
    <security-role>
        <description>
            The role that is required to log in to the Administration Application
        </description>
        <role-name>Admin</role-name>
    </security-role>
     至此我们基本TOMCAT的安全认证配置就完成了。至于其它三种方式,配置类似,可以参考2中定义的web.xml文件。
    

 

  • 描述: web.xml
  • 大小: 44.6 KB
  • 描述: context.xml
  • 大小: 32.4 KB
  • 描述: login.html
  • 大小: 20.3 KB
  • 描述: mc_users表
  • 大小: 14.6 KB
  • 描述: mc_roles表
  • 大小: 13.2 KB
  • 描述: mc_userroles表
  • 大小: 17.2 KB
1
0
分享到:
评论

相关推荐

    tomcat架构解析_刘光瑞(著) 人民邮电出版社_ 2017-05-01.7z

    《Tomcat架构解析》是刘光瑞撰写的一本专业书籍,由人民邮电出版社于2017年5月1日出版。这本书深入探讨了Apache ...通过阅读这本书,读者可以深入了解Tomcat的工作方式,从而更好地管理和维护基于Tomcat的Web应用。

    基于springboot原创歌曲分享平台.zip

    SpringBoot提供了丰富的安全组件Spring Security,可以实现用户认证、授权和会话管理,确保平台的数据安全。 在前端界面,可能采用了React或Vue.js等现代JavaScript框架,结合Bootstrap或其他UI库来构建响应式、...

    基于Springboot的原创歌曲分享平台(有报告) Javaee项目,springboot项目

    **基于Springboot的原创歌曲分享平台** 在当前的互联网时代,音乐分享平台已经成为了人们日常生活中不可或缺的一部分。本文将深入探讨一个使用Java EE技术栈,特别是Spring Boot框架构建的原创歌曲分享平台。这个...

    基于SSM的家政服务系统(含数据库文件).zip

    6. **安全控制**:在SSM项目中,Spring Security或Apache Shiro可以用来实现权限控制和认证功能,确保只有授权用户才能访问特定资源,提高系统的安全性。 7. **前端技术**:虽然没有明确提及,但一个完整的Web应用...

    【计算机专业Springboot2-毕业设计100套之】原创歌曲分享平台-论文等

    标题中的“Springboot2-毕业设计100套之原创歌曲分享平台-论文等”表明这是一个基于Spring Boot 2框架的毕业设计项目,主要功能是建立一个原创歌曲分享的在线平台,同时也包括了相关的论文资料。这个项目对于计算机...

    原创歌曲分享平台--论文.rar

    4. **安全控制**: Spring Security可能被用来处理用户认证和授权,了解OAuth2、JWT等安全机制也是必要的。 5. **文件上传与下载**: 对于音乐分享,文件存储和传输是关键,可能涉及到云存储服务(如阿里云OSS)和...

    精品--基于SSM的毕业设计论文题目审核及选题管理系统.zip

    8. **安全机制**:系统需包含用户认证和授权,防止未授权访问。Spring Security或Apache Shiro等安全框架可以用于实现这些功能。 9. **测试与部署**:项目开发完成后,需要进行单元测试、集成测试以确保功能的正确...

    基于Springboot和Vue框架的考试资源服务平台的设计与实现.docx

    本文主要探讨的是基于SpringBoot和Vue框架的考试资源服务平台的设计与实现,这是一篇原创的学士学位毕业论文,详细阐述了SpringBoot的核心概念、开发流程、配置管理、数据库操作以及安全性等方面,同时结合Vue.js...

    基于JavaWeb的编程技术论坛的设计与实现.docx

    然后,论文将讨论系统实现,包括后端业务逻辑的编写,数据的增删改查操作,以及用户认证和权限管理等安全机制。 最后,论文会涉及系统的测试与优化,涵盖单元测试、集成测试以及性能测试的方法,以及如何通过调整...

    原创 CloudStack+ESXi部署手册 136页

    文档首先简述了某保险行业现有的IT架构背景,其中包括使用VSphere套件管理不同架构主机的情况,指出仅依靠VSphere套件进行管理并不能全面满足安全认证、审计、账号和资源分配的需求,进而提出使用CloudStack云平台...

    超市后台管理系统.zip

    本文将深入探讨一个基于Spring Boot框架整合MyBatis和Shiro框架的超市后台管理系统,该系统旨在实现用户管理、员工管理、供应商管理以及账单管理等多种功能,是学生课设中的原创作品,旨在分享与学习。 首先,让...

    浪曦原创浪曦OA与工作流系统第1讲St.rar

    浪曦OA与工作流系统是基于Java企业级开发平台(J2EE)的一款高效、灵活的企业办公自动化系统,旨在提高企业的协同工作效率。本教程由浪曦网提供,它以其独特的教学方式,深入浅出地讲解了如何构建和使用工作流系统。...

    StudentManagement.zip

    《学生管理系统——基于JavaEE技术实现》 在IT行业中,JavaEE(Java Platform, Enterprise Edition)是一种广泛...8. **安全机制**:对于学生管理系统,权限控制和认证至关重要。JavaEE提供了多种安全机制,如角色基

    StuManageSys.zip

    本项目“StuManageSys”是一款基于JavaWeb的学生管理系统,由作者田超凡原创设计。下面将详细阐述该项目的核心知识点。 一、项目结构 StuManageSys项目可能包含以下几个主要部分: 1. 数据库设计:系统可能使用...

    jsp图书店销售管理系统

    9. **安全性**:考虑到图书销售涉及财务交易,系统必须具备一定的安全措施,如防止SQL注入、XSS攻击等,可能还需要实现用户认证和授权功能。 10. **部署和服务器环境**:该系统需要在Web服务器上运行,如Apache ...

    [影音娱乐]泉城JSP播客系统_video.rar

    5. **安全机制**:包括用户认证(登录验证)、授权(权限管理)以及防止SQL注入、跨站脚本攻击等,确保系统的安全性。 6. **文件上传与下载**:系统需支持用户上传音视频文件,这涉及到文件流的处理和存储管理。...

Global site tag (gtag.js) - Google Analytics