`
pute
  • 浏览: 30331 次
  • 性别: Icon_minigender_1
  • 来自: 上海
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

身份认证狗,在B/S结构系统中的使用

阅读更多

最近在根据客户的需要,对一个系统进行使用身份认证狗,在B/S结构系统中的进行身份认证。

 

要求描述:

1、登陆系统时,在USB接口上插上,身份认证狗,登陆时,使用双重身份认证。

2、登陆进,系统后,要求用户不得拔下加密狗,一旦拔下,系统将摧毁当前会话,强制退出系统。

 

下面就是我的客户端,服务器端的实现,

 

客户端JSF视图,登陆页面:

 

 

<%@page contentType="text/html"%>
<%@page pageEncoding="UTF-8"%>

<%@taglib prefix="f" uri="http://java.sun.com/jsf/core"%>
<%@taglib prefix="h" uri="http://java.sun.com/jsf/html"%>
<%@taglib prefix="h5" uri="http://putesoft.com/jsf_html5"%>



<f:view>
    <h5:doctype/>
    <html>
        <head>
            <meta content="WEB文件管理系统,互联文件管理系统,网络文件管理系统,企业文件管理专家,文件管理大管家" name="keywords"/>
            <meta content="专为中小企业服务的企业文件管理大管家" name="description"/>
            <link rel="icon" href="${pageContext.servletContext.contextPath}/resources/img/site_icon.png" type="image/png" />
            <link rel="stylesheet" href="${pageContext.servletContext.contextPath}/resources/css/login/style.css" type="text/css"/>
            <script src="${pageContext.servletContext.contextPath}/resources/js/common.js" type="text/javascript"></script>
            <title><h:outputText value="#{msgs.威博文件管理系统}"/></title>
        </head>
        <body>


            <div id="logo">
                <!--  -->
            </div>
            <!-- end #header -->


            <div id="page">

                <!-- start sidebar1 -->
                <div class="sidebar" id="sidebar1">
                    <h:panelGroup rendered="#{page$FacesApplicationBean.softExposure>page$FacesApplicationBean.softBusiness}">
                        <ul>
                            <li>
                                <h2><h:outputText value="#{msgs.关于本软件}"/></h2>
                                <ul>
                                    <!--<li>本软件系统是WEB应用软件,需网络部署后使用。</li>-->
                                    <li>客户端支持chrome3+、ie7+、firefox3+、opera10+等浏览器。</li>
                                    <li>服务器端支持winows、Linux、Unix等系列操作系统。</li>
                                    <li>数据库端支持SqlServer2000+、Oracle10+、MySql5+等数据库。</li>
                                    <li><b>2008-10-05,开始开发。</b></li>
                                    <li><b>2010-04-01,发布3.1版。</b></li>
                                    <li><a href="http://www.putesoft.com" target="blank"><b>[<h:outputText value="#{msgs.获取新版}"/>]</b></a></li>
                                </ul>
                            </li>
                        </ul>
                    </h:panelGroup>
                </div>
                <!-- end sidebar1 -->

                <!-- start content -->
                <div id="content">
                    <div class="bgtop">
                        <div class="bgbtm">
                            <h1 style="text-align:center;padding-top:50px;padding-left:0px;color:#80c0ff;font-size:48px;font-weight:bold;">
                                <h:outputText value="#{msgs.威博文件管理系统}"/>
                            </h1>
                            <div style="padding:40px 40px 40px 40px">

                                <h:form id="formLogin">
                                    <h:panelGrid border="0" cellpadding="8" cellspacing="8" columns="2" style="margin:auto;">
                                        <h:outputLabel value="#{msgs.用户}"/>
                                        <h:inputText
                                            label="#{msgs.用户}"
                                            required="true"
                                            requiredMessage="用户不能为空"
                                            style="width:150px;"
                                            value="#{page$Login.userName}"/>

                                        <h:outputLabel value="#{msgs.密码}"/>
                                        <h:inputSecret
                                            label="#{msgs.密码}"
                                            required="true"
                                            requiredMessage="密码不能为空"
                                            style="width:150px;"
                                            value="#{page$Login.userPassword}"/>

                                        <h:outputLabel
                                            rendered="#{page$FacesApplicationBean.iaWebUsed==false}"
                                            value="#{msgs.验证}"/>
                                        <h:panelGroup rendered="#{page$FacesApplicationBean.iaWebUsed==false}">
                                            <h:outputText value="#{page$Login.startPlus}+#{page$Login.endPlus}=" />
                                            <h:inputHidden value="#{page$Login.startPlus}"/>
                                            <h:inputHidden value="#{page$Login.endPlus}"/>
                                            <h:inputText required="true" size="4" value="#{page$Login.caculateResult}"/>
                                        </h:panelGroup>

                                        <h:outputLabel
                                            rendered="#{page$FacesApplicationBean.iaWebUsed==true}"
                                            value="狗号"/>
                                        <h:panelGroup rendered="#{page$FacesApplicationBean.iaWebUsed==true}">
                                            <object
                                                classid=clsid:B6BE32E6-5B1B-4A44-BA6C-FB24016CF9A7
                                                id = "IAWebClient"
                                                name = "IAWebClient"
                                                style="left:0px;top:0px;width:1px;height:1px;">
                                            </object>
                                            <!--随机字符串:-->
                                            <h:inputHidden id="randomInput" value="#{page$Login.randomInput}" />
                                            <!--客户端摘要:-->
                                            <h:inputHidden id="digestInput" value="#{page$Login.digestInput}"/>
                                            <!--硬件序列:-->
                                            <h:inputHidden id="iaGuidInput" value="#{page$Login.iaGuidInput}"/>
                                            <!--IAWeb状态:-->
                                            <h:inputHidden id="iaStatusInput" value="#{page$Login.iaStatusInput}"/>
                                            <!--加密狗密码:-->
                                            <h:inputSecret
                                                label="狗号"
                                                id="iaWebInput"
                                                required="true"
                                                requiredMessage="狗号不能为空"
                                                style="width:150px;"
                                                value="#{page$Login.iaWebInput}"/>
                                        </h:panelGroup>

                                        <h:graphicImage
                                            rendered="#{page$FacesApplicationBean.iaWebUsed==false}"
                                            url="/resources/img/space.gif"
                                            width="20" height="1"/>
                                        <h:commandButton 
                                            rendered="#{page$FacesApplicationBean.iaWebUsed==false}"
                                            style="width:150px;height:28px;"
                                            action="#{page$Login.login}"
                                            value="#{msgs.登录使用}"/>

                                        <h:graphicImage
                                            rendered="#{page$FacesApplicationBean.iaWebUsed==true}"
                                            url="/resources/img/space.gif"
                                            width="20" height="1"/>
                                        <h:panelGroup rendered="#{page$FacesApplicationBean.iaWebUsed==true}">
                                            <h:commandButton
                                                style="width:80px;height:28px;"
                                                onclick="javascript:var iaWebClientStatus ='true';if(IAWebClient.IAWebFind()!=0){iaWebClientStatus = '错误码(18没有找到IAWeb):'+IAWebClient.IAWebGetLastError();alert(iaWebClientStatus);return;}var sIAPWD=document.getElementById('formLogin:iaWebInput').value;if(IAWebClient.IAWebOpen(sIAPWD)!=0){iaWebClientStatus='错误码(63狗号出错、65错误超3次、27密狗已死锁):'+IAWebClient.IAWebGetLastError();alert(iaWebClientStatus);return;}var IAguid=IAWebClient.IAWebGetGUID();if(IAguid==''){iaWebClientStatus ='错误码(获的加密狗序列错误):'+IAWebClient.IAWebGetLastError();alert(iaWebClientStatus);return;}var Digest='';try{Digest=IAWebClient.IAWebMD5('#{page$Login.randomInput}');}catch(ex){iaWebClientStatus = '进行MD5运算发生异常';alert(iaWebClientStatus);return;}if(iaWebClientStatus=='true'){var digestInput=document.getElementById('formLogin:digestInput');digestInput.value=Digest;var iaGuidInput=document.getElementById('formLogin:iaGuidInput');iaGuidInput.value=IAguid;var iaStatusInput=document.getElementById('formLogin:iaStatusInput');iaStatusInput.value='#{page$Login.randomInput}';}else{var iaStatusInput=document.getElementById('formLogin:iaStatusInput');iaStatusInput.value=iaWebClientStatus;}"
                                                action="#{page$Login.loginIaWeb}"
                                                value="#{msgs.登录使用}"/>
                                            &nbsp;
                                            <h:commandLink
                                                id="page_Login_reSetPinIaWeb"
                                                target="page_Login_reSetPinIaWeb"
                                                onclick="doPopup('page_Login_reSetPinIaWeb',400,300)"
                                                style="width:50px;height:28px;"
                                                action="#{page$Login.reSetPinIaWeb}"
                                                immediate="true"
                                                value="重设狗号"/>
                                        </h:panelGroup>


                                    </h:panelGrid>
                                </h:form>

                                <br/>
                                <h:messages showSummary="true"/>
                                <%@include file="/page/include/AdvertiseLogin.jspf" %>
                                <br/>

                                <h:form>
                                    <table width="85%" border="0" cellpadding="8" cellspacing="8" style="margin:auto;">
                                        <tr>
                                            <td align="left">
                                                <h:graphicImage url="/resources/img/software_version.png"/>
                                            </td>
                                            <td align="right">
                                                <h:panelGrid border="0" columns="3" cellspacing="8">
                                                    <h:outputLabel value="Language"/>
                                                    <h:selectOneMenu value="#{page$FacesSessionBean.locale}">
                                                        <f:selectItem itemLabel="#{msgs.中文}" itemValue="cn"/>
                                                        <f:selectItem itemLabel="#{msgs.英文}" itemValue="en"/>
                                                    </h:selectOneMenu>
                                                    <h:commandButton image="/resources/img/refresh_24.gif" action="#{page$Login.changeLanguage}"/>
                                                </h:panelGrid>
                                            </td>
                                        </tr>
                                    </table>
                                </h:form>
                            </div>
                        </div>
                    </div>
                </div>
                <!-- end content -->

                <!-- start sidebar2 -->
                <h:panelGroup rendered="#{page$FacesApplicationBean.softExposure>page$FacesApplicationBean.softBusiness}">
                    <div class="sidebar" id="sidebar2">
                        <ul>
                            <li>
                                <h2><h:outputText value="#{msgs.关于普特软件}"/></h2>
                                <ul>
                                    <li><b>普特软件工作室</b>专业从事互联网软件和应用系统的开发。</li>
                                    <li>独创的<span style="color:#ff0000">汉字单码</span>软件开发体系,系国内独创,它灵活多变。</li>
                                    <li><b>业务范围</b>:软件产品、云网计算、应用开发、网站建设、网媒聚合、互联私网。</li>
                                    <li><b>它创始于1995年。</b></li>
                                    <li><a href="http://www.putesoft.com" target="blank"><b>[<h:outputText value="#{msgs.了解更多}"/>]</b></a></li>
                                </ul>
                            </li>
                        </ul>
                    </div>
                </h:panelGroup>
                <!-- end sidebar2 -->

                <div style="clear: both;">&nbsp;</div>


            </div>
            <!-- end page -->

            <div id="footer">
                <p class="legal">
                    &copy;<h:outputText value="2008-2018 #{msgs.权利保留}。"/>
                    <h:panelGroup rendered="#{page$FacesApplicationBean.softExposure>page$FacesApplicationBean.softBusiness}">
                        <h:outputText value="#{msgs.开发}:"/>
                        <a href="http://www.putesoft.com/" target="blank">
                            <b><h:outputText value="#{msgs.普特软件工作室}"/></b>
                        </a>
                    </h:panelGroup>
                    <h:outputText value="#{msgs.电话}:13162544156"/>
                </p>
            </div>



        </body>
    </html>
</f:view>
 

 

其中,入下代码段,为加密狗,自身要求的客户端ActiveX控件

                                            <object

                                                classid=clsid:B6BE32E6-5B1B-4A44-BA6C-FB24016CF9A7

                                                id = "IAWebClient"

                                                name = "IAWebClient"

                                                style="left:0px;top:0px;width:1px;height:1px;">

                                            </object>


 

 

入下代码段,为客户端,当点击提交按钮时,执行相应的javascript代码,设值相关JSF表单中,各字段的值

                                            <h:commandButton

                                                style="width:80px;height:28px;"

                                                onclick="javascript:var iaWebClientStatus ='true';if(IAWebClient.IAWebFind()!=0){iaWebClientStatus = '错误码(18没有找到IAWeb):'+IAWebClient.IAWebGetLastError();alert(iaWebClientStatus);return;}var sIAPWD=document.getElementById('formLogin:iaWebInput').value;if(IAWebClient.IAWebOpen(sIAPWD)!=0){iaWebClientStatus='错误码(63狗号出错、65错误超3次、27密狗已死锁):'+IAWebClient.IAWebGetLastError();alert(iaWebClientStatus);return;}var IAguid=IAWebClient.IAWebGetGUID();if(IAguid==''){iaWebClientStatus ='错误码(获的加密狗序列错误):'+IAWebClient.IAWebGetLastError();alert(iaWebClientStatus);return;}var Digest='';try{Digest=IAWebClient.IAWebMD5('#{page$Login.randomInput}');}catch(ex){iaWebClientStatus = '进行MD5运算发生异常';alert(iaWebClientStatus);return;}if(iaWebClientStatus=='true'){var digestInput=document.getElementById('formLogin:digestInput');digestInput.value=Digest;var iaGuidInput=document.getElementById('formLogin:iaGuidInput');iaGuidInput.value=IAguid;var iaStatusInput=document.getElementById('formLogin:iaStatusInput');iaStatusInput.value='#{page$Login.randomInput}';}else{var iaStatusInput=document.getElementById('formLogin:iaStatusInput');iaStatusInput.value=iaWebClientStatus;}"

                                                action="#{page$Login.loginIaWeb}"

                                                value="#{msgs.登录使用}"/>


 

因为JSF特有的页面驻留,使用身份认证狗的JSF表单与普通的JSP表单有所不同,点击“登陆按钮”时,设值的隐藏域比平常多一个。

 

 

客户端,MD5摘要生成原理,

当点击客户端提交按钮时,身份认证狗,利用客户端ActiveX控件,生成客户端MD5摘要,并由javascript代码,把相应的值置入JSF表单的隐藏域中,随其它信息发送到服务器端。

 

 

服务器端收到相关信息后,进行服务器端摘要计算与验证,具体代码如下:

 

    /**
     * 使用加密狗验证登陆
     * @return
     */
    public String loginIaWeb() {
        String result = SystemConstant.JSF_OUTCOME_NULL;
        try {

            //根据获得的随机字符串、客户端摘要、硬件序列码
            if (!this.iaStatusInput.equals(this.randomInput)) {
                facesInfo("出现错误,请重来一遍" + this.iaStatusInput);
            } else {
                //根据用户名和密码获得
                TwoTupleDTO<UserModel, List<ActorModel>> dto = ServiceFactory.newLoginService().loginProcess(userName, userPassword);

                //获得用户对象
                UserModel user = dto.getFirst();
                //获得用户密钥
                String userKey = user.getIaWebKey();
                String iaWebId = user.getIaWebId();
                //计算服务器端摘要
                String serverDigest = SecurityUtil.md5MessageDigest(this.randomInput, userKey);

                //如果加密狗硬件Id和MD5摘要全部对应相等
                boolean checkStatus = this.iaGuidInput.equals(iaWebId) & this.digestInput.equals(serverDigest);
                if (!checkStatus) {
                    facesInfo("服务器端,加密狗验证不能通过,系统阻止登陆");
                } else {
                    List<ActorModel> actorList = dto.getSecond();
                    //
                    FacesSessionBean fsb = FacesBeanFactory.getFacesSessionBean();
                    //设置会话bean的user对象
                    fsb.setUser(user);
                    //设置会话bean的当前用户对应的角色列表
                    fsb.setCurrentUserDeActorList(actorList);
                    //如果有效,则返回成功标志
                    result = SystemConstant.JSF_OUTCOME_SUCCESS;
                }

            }
            //重新设置初始化
            this.init();
        } catch (Exception e) {
            contextLog("登录验证发生异常,原因入下:" + e.getMessage());
            facesInfo("登录验证发生异常,原因入下:" + e.getMessage());
        }
        return result;
    }
 

服务器端MD5摘要计算

 

    /**
     * 使用给定的种子和密钥,计算获得MD5消息摘要
     * @return
     */
    public static String md5MessageDigest(String seed, String key) {
        //摘要字符串
        String digestStr = null;

        try {
            //进行MD5运算
            String MSG = (seed + key);
            MessageDigest MD = MessageDigest.getInstance("MD5");
            MD.update(MSG.getBytes("UTF-8"));
            byte b[] = MD.digest();
            int i;
            StringBuffer buf = new StringBuffer("");
            for (int offset = 0; offset < b.length; offset++) {
                i = b[offset];
                if (i < 0) {
                    i += 256;
                }
                if (i < 16) {
                    buf.append("0");
                }
                buf.append(Integer.toHexString(i));
            }
            //获得服务器端摘要
            digestStr = buf.toString();
        } catch (Exception e) {
            //返回非受检异常
            throw new BusinessException("MD5消息摘要,计算中发生异常");
        }

        //
        return digestStr;
    }
 

 

服务器端身份认证过程,文字描述如下:

 

在收到客户端发来的MD5摘要,用户名、密码、身份认证狗硬件ID后,获取事先存储在数据表中的对应信息,在服务器端计算MD5摘要,如果能够匹配,则通过身份认证,用户可以正常使用系统。

 

 

 

 

 

登陆进,系统后,要求用户不得拔下加密狗,一旦拔下,系统将摧毁当前会话,强制退出系统。

这个就是在每个JSF视图文件的插入一个include文件,当视图渲染到客户端浏览器时,都检测一下,当前客户端中,

是否插有身份认证狗,如果没有,则转到错误视图,强制销毁会话,具体代码如下:

 

<%@ page pageEncoding="UTF-8" %>

<%@taglib prefix="f" uri="http://java.sun.com/jsf/core"%>
<%@taglib prefix="h" uri="http://java.sun.com/jsf/html"%>



<div>
    <f:subview
        rendered="#{page$FacesApplicationBean.iaWebUsed==true}"
        id="page_include_IaWebCheck">
            <object
                classid=clsid:B6BE32E6-5B1B-4A44-BA6C-FB24016CF9A7
                id = "IAWebClient"
                name = "IAWebClient"
                style="left:0px;top:0px;width:1px;height:1px;">
            </object>
            <script type="text/javascript">
                //查找IAWeb锁,使用控件函数
                if(IAWebClient.IAWebFind()!=0){
                    this.location.href="${pageContext.servletContext.contextPath}/page/IaWebError.jsp"
                }
            </script>
    </f:subview>
</div>
 

 

 

 

 

 

 

 

 

 

 

 

0
0
分享到:
评论

相关推荐

    基于B/S结构的高校图书馆管理系统的开发与应用

    ### 基于B/S结构的高校图书馆管理系统...综上所述,基于B/S结构的高校图书馆管理系统的开发与应用,不仅解决了传统图书馆管理中的诸多难题,还开创了图书馆服务的新纪元,对于推动高校图书馆的现代化建设具有重要意义。

    B/S网盘系统

    在B/S网盘系统中,主要有以下几个关键组成部分: 1. **前端界面**:用户与系统交互的界面通常由HTML、CSS和JavaScript构建。HTML负责页面结构,CSS处理样式,JavaScript则提供了动态交互功能,如文件上传、下载、...

    基于B/S的在线考试系统的设计与实现论文

    系统采用B/S架构,即浏览器/服务器模式,这种架构使得用户无需在本地计算机上安装额外的客户端软件,只需通过浏览器即可访问系统,大大降低了用户的使用门槛,同时也减轻了系统的维护负担。C#.Net作为开发语言,是...

    基于JSP构建的B/S图书管理系统

    ### 基于JSP构建的B/S图书管理系统的关键知识点 #### 1.1 课题背景及意义 本课题旨在探讨如何运用Java Server Pages (JSP) 技术结合 SQL Server 2005 数据库来开发一个高效的图书馆管理系统。随着信息技术的发展,...

    B/S 文档管理系统

    在这个B/S文档管理系统中,用户可能通过这个页面访问和交互系统。 3. **Web.Config**:这是一个XML文件,包含了ASP.NET应用程序的配置信息,如数据库连接字符串、身份验证模式、错误处理等。在B/S文档管理系统中,...

    基于B/S的网上银行系统的设计与开发.pdf

    在此背景下,开发基于B/S(Browser/Server,浏览器/服务器)架构的网上银行系统,成为了提高银行服务质量、降低运营成本的有效手段。 #### 2. 系统概述 **2.1 目标设计** 本系统旨在为银行内部员工和用户提供一个...

    asp.net基于B/S结构的做的调查问卷

    在本项目“asp.net基于B/S结构的做的调查问卷”中,我们将探讨如何使用ASP.NET技术实现一个在线的、用户友好的调查问卷系统。 首先,B/S架构是目前广泛采用的互联网应用模式,用户通过浏览器访问服务器上的应用,...

    基于B/S结构的实验中心管理平台设计

    根据B/S体系结构的特点,将计算机网络技术和数据库技术相结合,提出了一种基于B/S结构的实验中心管理平台的设计方法,给出了方案中具体的模块组成,并对所需的关键技术进行了深入研究,该平台功能齐全、操作简便,...

    一组16x16的icon 小图标 适合作为B/S系统 菜单标志 或 各模块的小图标

    在IT行业中,用户界面设计是至关重要的,尤其是对于B/S(Browser/Server)系统而言,一个清晰、直观的界面能够极大地提升用户体验。本资源提供了一组16x16像素的icon小图标,这些图标是专门设计用于B/S系统的菜单...

    asp.net 基于B/S的学籍管理系统 源码

    在这个特定的场景中,我们讨论的是一个基于B/S(Browser/Server,浏览器/服务器)架构的学籍管理系统源码,这意味着用户通过浏览器进行交互,而服务器端处理业务逻辑和数据存储。 在ASP.NET中,开发人员可以使用C#...

    LDAP的研究及其在统一身份认证系统中的应用

    ### LDAP的研究及其在统一身份认证系统中的应用 #### 引言 随着信息技术的快速发展和互联网应用的广泛普及,网络环境下的各种服务系统如雨后春笋般涌现出来。这些服务系统大多数采用B/S(浏览器/服务器)架构,各自...

    电子商务系统源码(C# B_S结构)

    【电子商务系统源码(C# B/S结构)】是一种基于C#编程语言开发的Web应用程序,设计用于实现在线商业交易和管理。B/S(Browser/Server)结构,也称为浏览器/服务器模式,是互联网应用程序的常见架构,用户通过浏览器...

    基于BS的用户认证系统实验报告

    实验报告涵盖了基于浏览器-服务器(B/S)架构的用户认证系统的开发,旨在让学生深入理解软件体系结构的核心思想,掌握B/S架构的原理及其在JSP/Java应用中的实现。实验的目标是创建一个能够进行远程用户认证的系统,这...

    图书管理系统是用b/s形式编写的

    在这个系统中,“B/S形式编写”指的是用户界面和数据库之间的交互是通过互联网进行的,用户无需安装任何客户端软件,只需要在浏览器中输入网址就能访问系统。 ASP.NET技术是微软开发的一种用于构建Web应用程序的...

    2017218007文华_《网络工程师综合训练》报告1

    - **资源消耗**:C/S结构中,客户端需要占用较多资源,而B/S结构资源主要集中在服务器端。 - **安全性**:C/S结构由于数据处理在本地,可能更安全,但B/S结构可通过加密等手段提高安全性。 ### 4.1.1 至 4.1.4(未...

    基于B_S与C_S协同架构的智能校园卡系统设计.pdf

    系统模块设计包括芯片卡载体、前端物理设备、个人信息管理、财务管理、交易记录等模块,实现了校园内的消费、身份认证、查询和充值等多种功能。这种混合架构不仅简化了操作流程,提升了用户体验,还降低了学校在管理...

    档案管理系统解决方案.doc.pdf

    在基于B/S结构的解决方案中,用户通过浏览器向档案管理系统发出登录请求,档案管理系统通过TrustLink Agent向指纹识别平台中的TrustLink Server发出身份认证请求,TrustLink Server与TrustLink Agent达成握手协议。...

    北京时代亿信科技有限公司统一身份管理系统

    - **B/S 和 C/S 结构的应用系统接入**:支持多种类型的应用系统接入统一身份管理平台。 - **统一用户管理**:集中管理用户的个人信息,包括基本信息的同步。 - **授权管理**:管理用户对各个应用系统的访问权限。 - ...

Global site tag (gtag.js) - Google Analytics