posts - 14, comments - 22, trackbacks - 0, articles - 4
  BlogJava :: 首页 ::  :: 联系 :: 聚合  :: 管理
看到题目,您一定觉得很土,Struts早已风靡,而关于Stuts的文章也早已遍地都是,如果你觉得土那你就别看了,我只是把我这段时间学到的一些比较肤浅知识在这里记录一下,如果您真在这些连载文章中获得了您想要的知识,那么我就会很欣慰了。
        这不快毕业了吗?我选的题目就和Struts有关,做一个关于学校的毕业设计选题系统,就是B/S结构,访问数据库的一些俗套的东西,为了巩固我这段时间学习Struts,我把这个系统竟往难里做,这样对我这个动手能力差的人,实际工作经验少的人来说,会有点帮助吧?
        当初就是这样想的,所以就开始了我的Struts之旅。
        那我就从我的第一页讲起吧,当然第一页一般都是登陆,至于怎么配置Struts,您还是参考一些别人的文章吧,我觉得写这些就够土的了,写怎么配置,怎么实现就更土!

        <%@ page contentType="text/html; charset=gb2312"%>
        <%@ taglib uri="/WEB-INF/struts-bean.tld" prefix="bean" %>
       <%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html" %>
       <html:javascript dynamicJavascript="true" staticJavascript="true" formName="LoginForm"/>这句是生成验证登陆表单所需要的js代码
       <html:form action="/ajax.do?method=login" onsubmit="return validateLoginForm(this)">
            用户名:<html:text property="user" size="16" maxlength="16"/>
            密码:    <html:password property="password" size="16" maxlength="16"/>
                           <html:submit styleClass="loginbutton" property="submit" value="登陆"/>
                           <html:button property="reg" styleClass="loginbutton" 
                                    onclick="window.location='ajax.do?method=register'" value="注册"/>
                           <html:errors property="user"/><html:errors property="password"/>
       </html:form>

       把控制格式的HTML删除掉,应该剩下这些就是主干了,对于这个毕业设计选题系统,有三种角色,管理员(Admin),教师(Teacher),学生(Student)而我把他们的登陆都做到了一起,在后台这三种角色也是都放在了一个表中,对于他们这三种对象,都是继承于Person的类,所以在登陆时可以忽视他们的具体角色,用多态来实现登陆。
        

    action="/ajax.do?method=login" :将一些关于登陆啊,注册的一些乱七八糟的操作我都放到了一个DispatchAction,之后可以用method的不同来分别调用不同的功能。
   onsubmit="return validateLoginForm(this)":这个是用来实现Struts自带的validate验证
   <html:errors property="user"/><html:errors property="password"/> :是用来显示在登陆时的错误信息

    在这里需要的Struts相关配置会有如下的几个方面:
      首先是要对配置文件进行配置我们登陆时需要的FormBean和Action
       (1)struts-config.xml:
            <form-bean name="LoginForm" type="com.boya.subject.view.LoginForm" />
            <action path="/ajax" type="com.boya.subject.controller.InterDispatchAction" name="LoginForm" scope="request" validate="true" input="/index.jsp" parameter="method">
                  <forward name="fail" path="/index.jsp" />   对于登陆失败,我们准备返回到这里
           </action>
     (2)validation.xml:
            <constant>
                  <constant-name>user</constant-name>
                  <constant-value>^[0-9a-zA-Z]*$</constant-value>
               这里是常量配置,因为我们还会需要到用户名的验证,所以把他设置为了常量
           </constant>
          下面是对这个bean的具体严整手段了,按字段field分别来写他们所依赖depaends的检验手段,常用的有必须填required,正则表达式验证mask,最大maxlength和最小minlength
            <form name="LoginForm">
              <field property="user"对应LoginForm里的一个属性  depends="required,mask,minlength,maxlength">
                   <msg name="mask" key="input.user.mask" />从application.properties里读取input.user.mask           
                    <arg0 key="input.user" resource="true" />从application.properties里读取input.user
                   <arg1 name="minlength" key="${var:minlength}" resource="false" />
                   <arg1 name="maxlength" key="${var:maxlength}" resource="false" />
                  以上三部分构成了js的一条错误提示,以下是具体的严整规则了
                <var>
                    <var-name>mask</var-name>
                    <var-value>${user}</var-value>
                </var>
                <var>
                    <var-name>minlength</var-name>
                    <var-value>1</var-value>
                </var>
                <var>
                    <var-name>maxlength</var-name>
                    <var-value>16</var-value>
                </var>
         </field>

   <field property="password"
    depends="required,mask,minlength,maxlength">
    <arg0 key="input.password" resource="true" />
    <arg1 name="minlength" key="${var:minlength}"
     resource="false" />
    <arg1 name="maxlength" key="${var:maxlength}"
     resource="false" />
    <var>
     <var-name>mask</var-name>
     <var-value>${password}</var-value>
    </var>
    <var>
     <var-name>minlength</var-name>
     <var-value>1</var-value>
    </var>
    <var>
     <var-name>maxlength</var-name>
     <var-value>16</var-value>
    </var>
   </field>

  </form>
 对于我们需要的FormBean是这样写的:
package com.boya.subject.view;

import javax.servlet.http.HttpServletRequest;
import org.apache.struts.action.*;

public class LoginForm extends ActionForm
{
    private static final long serialVersionUID = 1L;
    private String user = null;
    private String password = null;

    public String getPassword()
    {
        return password;
    }

    public void setPassword( String password )
    {
        this.password = password;
    }

    public String getUser()
    {
        return user;
    }

    public void setUser( String user )
    {
        this.user = user;
    }
   
    public void reset(ActionMapping mapping,HttpServletRequest request)
    {
        this.password = null;这里很重要,当用户输入有错时,需要返回登陆界面给用户,为了用户填写方便我们可以设置返回给用户的哪部分信息设置为空
    }
}

我用来实现登陆的DispatchAction代码如下:
      public ActionForward login( ActionMapping mapping, ActionForm form,
            HttpServletRequest req, HttpServletResponse res ) throws Exception
    {
         Service service = getService();调用业务逻辑
        LoginForm loginForm = (LoginForm) form;获取formbean
        String user = loginForm.getUser();提取用户名
        Person person = service.getUser( user );从业务逻辑中查找用户
        ActionMessages messages = new ActionMessages();
        ActionMessage am;
        if ( person == null )如果用户不存在,我们就返回
        {
            am = new ActionMessage( "index.jsp.fail.user", user );参数的意义:第一个是主串,而后面的作为arg数组
            messages.add( "user", am );把错误信息放到errors 属性为user那里去显示
            saveErrors( req, messages );
            form.reset( mapping, req );如果出现错误,调用formbean的重置功能
            return mapping.findForward( ID.FAIL );
        }
        if ( !person.getPassword().equals( loginForm.getPassword() ) )如果密码不一致
        {
            am = new ActionMessage( "index.jsp.fail.password", user );
            messages.add( "password", am );
            saveErrors( req, messages );
            form.reset( mapping, req );
            return mapping.findForward( ID.FAIL );
        }
       
        setSessionObject( req, person.getType(), person );把用户放到session里
        return new ActionForward( person.getType() + ".do", true );我在每个类型用户的类中加入了一个getType来在这里调用,之后动态的去对应的admin.do,student.do,teacher.do的主页面,并且这里实现的不是请求转发,而是请求从定向
   }


评论

# re: 体验Struts(1)---用户登陆的实现   回复  更多评论   

2006-05-25 01:22 by 黑蝙蝠
大哥一口气弄了4篇文章,呵呵,虽然我不懂,但是还是支持下!

# re: 体验Struts(1)---用户登陆的实现   回复  更多评论   

2006-11-03 10:08 by haha[匿名]
hao la ji

# re: 体验Struts(1)---用户登陆的实现   回复  更多评论   

2006-11-23 12:55 by liu
不错~~~
另外:鄙视楼上!

# re: 体验Struts(1)---用户登陆的实现   回复  更多评论   

2007-04-22 11:08 by 11
我喜欢。我想请问一下。你的Person是从哪里写的

# re: 体验Struts(1)---用户登陆的实现   回复  更多评论   

2008-09-11 22:57 by Paul Chen
加个Service Layer会更好些

只有注册用户登录后才能发表评论。


网站导航:
 
有事在这里给我留言噢!