龙卷风驿站

初生牛犊

  BlogJava :: 首页 :: 联系 :: 聚合  :: 管理
  15 Posts :: 0 Stories :: 8 Comments :: 0 Trackbacks

2006年7月5日 #

开发环境:eclipse3.1.2  myeclipse4.1.1   Tomcat5.0.28   Mysql5.0
dwr类包版本是1.1
步骤一:配置web.xml
 <?xml version="1.0" encoding="UTF-8"?>
<web-app>
    <servlet>
        <servlet-name>action</servlet-name>
        <servlet-class>org.apache.struts.action.ActionServlet</servlet-class>
        <init-param>
            <param-name>config</param-name>
            <param-value>/WEB-INF/struts-config.xml</param-value>
        </init-param>
        <init-param>
            <param-name>debug</param-name>
            <param-value>3</param-value>
        </init-param>
        <init-param>
            <param-name>detail</param-name>
            <param-value>3</param-value>
        </init-param>
        <load-on-startup>0</load-on-startup>
    </servlet>


    <servlet-mapping>
        <servlet-name>action</servlet-name>
        <url-pattern>*.do</url-pattern>
    </servlet-mapping>
    <servlet>
        <servlet-name>dwr-invoker</servlet-name>
        <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class>
        <init-param>
            <param-name>debug</param-name>
            <param-value>true</param-value>
        </init-param>
    </servlet>

    <servlet-mapping>
        <servlet-name>dwr-invoker</servlet-name>
        <url-pattern>/dwr/*</url-pattern>
    </servlet-mapping>
    
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>/WEB-INF/applicationContext.xml
        </param-value>
    </context-param>
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener> 
     
    <filter>
        <filter-name>EncodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            `
            <param-value>UTF-8</param-value>
        </init-param>

    </filter>
    <filter-mapping>
        <filter-name>EncodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

      <error-page>
        <error-code>404</error-code>
        <location>/404.jsp</location>
    </error-page>

    <error-page>
        <error-code>500</error-code>
        <location>/500.jsp</location>
    </error-page>

    <taglib>
        <taglib-uri>/WEB-INF/struts-bean</taglib-uri>
        <taglib-location>/WEB-INF/tld/struts-bean.tld</taglib-location>
    </taglib>
    <taglib>
        <taglib-uri>/WEB-INF/struts-logic</taglib-uri>
        <taglib-location>/WEB-INF/tld/struts-logic.tld</taglib-location>
    </taglib>
    <taglib>
        <taglib-uri>/WEB-INF/struts-html</taglib-uri>
        <taglib-location>/WEB-INF/tld/struts-html.tld</taglib-location>
    </taglib>
    <taglib>
        <taglib-uri>/WEB-INF/struts-tiles</taglib-uri>
        <taglib-location>/WEB-INF/tld/struts-tiles.tld</taglib-location>
    </taglib>
    <taglib>
        <taglib-uri>/WEB-INF/ntu</taglib-uri>
        <taglib-location>/WEB-INF/tld/ntu.tld</taglib-location>
    </taglib>

</web-app>

二:spring中注入相关service
<bean id="ajaxTestService" class="com.lion.cms.domain.service.AjaxTestServiceImp">
        <property name="commonDAO">
            <ref bean="commonDAO" />
        </property>
    </bean>

三:AjaxTestServiceImp代码
public class AjaxTestServiceImp implements IAjaxTestService {
  
    private ICommonDAO commonDAO;

     
    public void setCommonDAO(ICommonDAO commonDAO) {
        this.commonDAO = commonDAO;
    }

    public List getEmployeeById(String deptid) {
        DetachedCriteria detachedCriteria=DetachedCriteria.forClass(Employee.class);
        detachedCriteria.setFetchMode(Employee.PROP_DEPTID,FetchMode.JOIN);
        detachedCriteria.add(Restrictions.eq(Employee.PROP_DEPTID+".id",deptid));
        List result=commonDAO.findByCriteria(detachedCriteria);
        return result;
       
    }
}

四:dwr.xml配置
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN" "http://www.getahead.ltd.uk/dwr/dwr10.dtd">

<dwr>
 <allow>
  <create creator="spring" javascript="ajaxTestService">
   <param name="beanName" value="ajaxTestService" />
   <include method="getEmployeeById" />
  </create>
        <convert converter="bean" match="com.lion.cms.domain.pojo.Employee" />
        <param name="exclude" value="com.lion.cms.domain.pojo.Dept"/>
 </allow>
</dwr>

五:jsp页面
<html:select styleId="deptid" property="deptid" onchange="loadEmployList(this.value)">
                <html:optionsCollection name="deptlist" label="deptname" value="id"/>
            </html:select>
            <html:select property="employee" styleId="employee">
            <html:option value="" >请选择</html:option>
            </html:select>    

<script type="text/javascript">
<!--
    // 加载employee下拉列表。
    function loadEmployList(deptid){
        if(deptid==null||deptid==''){
        clearEmployeeSel();
        return;
        }
        ajaxTestService.getEmployeeById(loadEmployListCallback,deptid);
    }
    var loadEmployListCallback=function(items){
        clearEmployeeSel();
        DWRUtil.addOptions("employee",items,"id","truename");
    }
    function clearEmployeeSel(){
        DWRUtil.removeAllOptions("employee");
        DWRUtil.addOptions("employee",[{label:'请选择',value:''}],"value","label");
    }
//-->
</script>


职工和部门是多对一关系,例子简单,不详细叙述了
dwr中spring和hibernate的配置相关帮助文档:
http://getahead.ltd.uk/dwr/server/spring
http://getahead.ltd.uk/dwr/server/hibernate


dept.hbm.xml代码如下:
<hibernate-mapping package="com.lion.cms.domain.pojo">
 <class
   name="Dept"
  table="dept"
 >
 <meta attribute="sync-DAO">false</meta>
   <id
   name="id"
   type="string"
   column="id"
  >
   <generator class="uuid.hex"/>
  </id>

  <property
   name="deptname"
   column="deptname"
   type="string"
   not-null="true"
   length="12"
  />
  <property
   name="creattime"
   column="creattime"
   type="java.lang.Long"
   not-null="false"
   length="20"
  />
 


 </class> 
</hibernate-mapping>


employee.hbm.xml代码如下:

<hibernate-mapping package="com.lion.cms.domain.pojo">
 <class
  name="Employee"
  table="employee"
 >
  <meta attribute="sync-DAO">false</meta>
  <id
   name="id"
   type="string"
   column="Id"
  >
   <generator class="uuid.hex"/>
  </id>

  <property
   name="username"
   column="username"
   type="string"
   not-null="true"
   length="20"
  />
  <property
   name="password"
   column="password"
   type="string"
   not-null="false"
   length="20"
  />
  <property
   name="truename"
   column="truename"
   type="string"
   not-null="false"
   length="11"
  />
  <property
   name="sex"
   column="sex"
   type="string"
   not-null="false"
   length="2"
  />
  <property
   name="intro"
   column="intro"
   type="string"
   not-null="false"
  />
  <many-to-one
   name="deptid"
   column="deptid"
   class="Dept"
   not-null="true"
  >
  </many-to-one>


 </class> 
</hibernate-mapping>

用hibernate同步插件可以快速生成po

 

posted @ 2006-07-05 11:06 龙卷风驿站 阅读(5759) | 评论 (3)编辑 收藏

2006年6月1日 #

明天下午系统演示,14号论文答辩,希望早点拿好毕业证和学位证走人。
posted @ 2006-06-01 18:48 龙卷风驿站 阅读(156) | 评论 (0)编辑 收藏

2006年5月17日 #

这一个月在公司其他事没做,天天做毕业设计,前几天终于完工了。毕业设计做的是计量局的管理系统,采用struts+spring+hibernate完成,运行良好,遗憾的是业务层没有分离,因为时间紧加上系统不是很大,所以都写在action中了,存在部分代码重写,下次改进,呵呵。
   

    系统js代码写了不少,因为某些功能必须要这样来实现。

    论文写了1w多字了,早日做好,公司还有事要做。

    做项目的过程中得到了公司不少高人的指点,尤其是我师父colky,让我少走了很多弯路,好多东西也更清晰,谢谢他们。
posted @ 2006-05-17 11:01 龙卷风驿站 阅读(280) | 评论 (0)编辑 收藏

2006年5月5日 #

嘿嘿,好开心哦,好多人,不知道会不会是同学当中最早的,还有一个多月就正式毕业了,开心ing~

路过的就顶一个吧,你也会很幸福的

posted @ 2006-05-05 18:32 龙卷风驿站 阅读(308) | 评论 (1)编辑 收藏

2006年4月27日 #

哈哈,编码自由写,在eclipse里面最后用ctrl+shift+f 快捷键,代码乖乖的自动排列好,尤其是xml文件,排得真好看
posted @ 2006-04-27 10:51 龙卷风驿站 阅读(226) | 评论 (0)编辑 收藏

2006年4月24日 #

比较一个属性可以这样:
detachedCriteria.add(Restrictions.eq(XXX.PROP_ID,Integer.parseInt(id)));

如果比较的属性本身类型是对象,那么可以这样

detachedCriteria.add(Restrictions.eq(XXX.PROP_BM+".id",Integer.parseInt(bmid)));

以上面的语句为例,如果我比较其他属性
detachedCriteria.add(Restrictions.eq(XXX.PROP_BM+".bmmc",bmmc));

这样是不行的

解决方法:先定义一个别名
detachedCriteria.createAlias(XXX.PROP_BM, "bm");
然后可以这样使用了
detachedCriteria.add("bm.bmmc",bmmc));


ps:个人总结:不使用别名,本身是对象的属性后面只能跟其主键属性,比较其他属性要用别名。个人观点,还没有得到确认


posted @ 2006-04-24 14:26 龙卷风驿站 阅读(1574) | 评论 (3)编辑 收藏

2006年4月19日 #

请假请到论文答辩前,接下来的日子不要担心学校有什么事了,嘿嘿,努力工作,早日完成毕业设计
posted @ 2006-04-19 12:22 龙卷风驿站 阅读(181) | 评论 (0)编辑 收藏

2006年4月15日 #

公司的系统和SQLSERVER的安装文件都和笔记本的一样,公司新机安装什么问题都没有。
可家里的机器换系统以后再装SQLSERVER总是有问题,今天上网查了一下,终于找到原因。

因为以前笔记本SQLSERVER安装的时候数据文件总是指定到E盘,换系统之后还是指定到那边,但是上个版本安装留下了几个系统MDF,所以换系统安装再次选择E盘的时候就会出错了

建议换系统以后装sql数据目录指定到一个新目录,这样就没有问题了

posted @ 2006-04-15 22:58 龙卷风驿站 阅读(211) | 评论 (0)编辑 收藏

2006年4月14日 #

项目特殊,js里面有中文参数传递


接受方: String  EmployeeName =new  String(httpServletRequest.getParameter("EmployeeName").toString().getBytes("ISO8859-1"));
posted @ 2006-04-14 12:13 龙卷风驿站 阅读(667) | 评论 (0)编辑 收藏

2006年4月5日 #

哈哈,今天公司OFFER我了,过几天回学校拿协议书,终于要毕业了。

posted @ 2006-04-05 17:51 龙卷风驿站 阅读(168) | 评论 (0)编辑 收藏