2005年8月24日

提高网络新闻竞争力七个基本原则

  在旧的“以传播者为中心”的模式逐步被“以受众为中心”的新模式所代替的今天,网络媒体给受众提供了更多的选择信息的自由和方便,这也为网络编辑工作提出了挑战。因此,对网络新闻编辑而言提供信息并不是最重要的,对信息做出有效的处理,提高信息的服务质量才是竞争最有力的武器。

  互联网的不断普及,网民开始更多地关注一些深层次的新闻。在网络新闻大战中,竞争的焦点正在悄然地发生转移,“眼球信息”的初步阶段开始演绎到“头脑信息”的深层次较量。提高网络新闻竞争力的主要部分体现在日常新闻质量、突发轰动事件以及网站新闻搜索,这是一个潜移默化的综合因素作用的结果。

规范编辑工作流程(每天都要排专人发帖)

  制定编辑工作守则和编辑操作手册,让编辑以及相关员工有规可依、有法可循。手册应该适应不断变化的竞争环境,应该对稿件采集的来源,新闻稿件编辑的具体事项,一天的工作流程以及交接班时注意的事项等等做出相应的规范。应该包括新闻处理的最基本和最新要求,对于各种情形的处理办法固定,各类基本规范和通报等等。

  建立对新闻事实核准制度,在各个栏目建立起对各自领域内对合作媒体群的评估体系,确定新闻价值的判断原则以及实现方法。还要不断查找发现自己的短处并且及时对症下药,进行有针对性的指导和培训,增强网络新闻的整体竞争力。

  建立突发事件预案(平常老出事的公司和人物都要盯紧点儿!,比如百度和DELL)

  长期以来,突发性新闻事件以其蕴含的巨大新闻价值而成为新闻报道中的一大重点。新闻网站在短时间内提升人气或者改善品牌的最好机会,当在重大突发事件的报道。

  在突发事件报道过程中,需要在短时间内调动大量人力,需要培养一支专门应急的“特种兵”小分队。网络新闻媒体应该建立突发事件预案,建立高效率的快速反应机制。利用新闻传播速度、方式、广泛程度等方面的优势一展身手。

  建立突发事件预案,配置足够的资源支持。按照紧急处理流程,电话通知值班总编,并迅速发布快讯;应制定固定专题模版,在短时间内迅速做出专题报道。为受众全面深入了解突发性新闻事件提供了一个开放性和多样性的途径。

抢抓新闻制高点(什么倒闭啊亏损啊风投啊模式啊热门词都用上)

  网络新闻表现出来的娱乐化、平民化、媚俗化为现阶段消费时代的自然表现。“媚俗美学成为后传播时代的审美风尚,即美学已渗透到了经济、政治、文化以及日常生活中,因而丧失了其自主性和特殊性”。

  鉴于受众在网络新闻内容选择上对于媚俗与娱乐元素的偏好,追求浏览率的网站,需要一定比例的“软新闻”。实际上,对于成熟的品牌网站来说,没有必要一味迎合受众的这种“求软”心理。“硬新闻”永远是主流媒体的标志性核心产品,应该以“硬”为主,“软”只是一种佐料,只是气氛上的调剂。

  网络新闻编辑在“把关”过程中要防止新闻煽情化。心理学家研究成果表明,受众的本我是趋向“享乐”与“刺激”的,他们喜好“新奇”“娱乐”的传播内容。网络传媒为了在众多的媒体中脱颖而出,就必需要注意受众的这一内在需求,通过满足网民的阅读喜好,来获得支持。

技术创新(找程序员做几个机器人,智能回帖,顶,狂顶)

  好的发布系统可以形成更快的发布速度、更丰富的表现形式,更快捷的专题组织以及更多的内容关联,而这些都是提升网站访问量的关键因素。同时,利用好搜索引擎也是重要的一部分。

  新闻网站吸引受众,提高网络新闻的点击率,一是要依靠口碑等人际关系的传播,二是要依靠网站搜索的链接来实现。与搜索引擎相结合后,每一条新闻都可以看成是网站、频道的品牌营销通路。因为网友通过一个主题词的搜索,都可能进入网站的一条新闻、一个专题、一个栏目、一个频道。从这个意义上讲,网络新闻的生产过程本身就是构成自身品牌的营销过程。

加大专稿写作力度(该造谣的时候下手一定要狠)

  在众多的新闻网站中,真正吸引受众,有长足的发展,做出特色新闻是新闻网站很重要的一个问题。

  网络新闻媒体具有两个突出的特点:原创性与整合性。原创性的独家新闻报道是网络新闻的特色。在现有资源情况下,要提升新闻网站的知名度,原创的新闻是必不可少的。典型报道在我国一直是主流媒媒体的优势和强项。作为新闻的重要组成部分,典型宣传在唱响主旋律、引领积极健康的主流舆论方面发挥着重要的作用。要深入学习理解,使先进典型宣传主题紧扣党的路线方针政策。更要精心细致采访,寻觅独家视角,使典型宣传主题增强个性特色。

  同时,还应做一些解释性报道、客观性报道等深度报道。保持新闻特点的同时注意受众的现实情况,行文多考虑时新性、趣味性、可读性、思想性、人情味。这样网络才能有新的生命力和活力。

研究受众需求增强互动性(要让别人发点小广告,灌些MM图)

  互联网带来的不仅是一种新的传播方式,同时也对大众的生活习惯、工作方式、价值观念以及思维方式产生了重大影响。从传播学的发展历史来看,受众与传播者的角色经历了多次的转变。

  作好网络新闻,要分析受众的微观和宏观需求,;理解网络新闻的受众,满足受众的心理要求。在宏观上,以传播者为中心,编辑考虑的是战略目的——提高新闻点击率等,网络编辑有新闻的选择权,传播者是主动的。在微观上,网络新闻的选择是以受众为中心,需要了解受众需要的信息和传播的方式。

  根据受众心理特征,网络编辑需要处理好网络新闻“软”与“硬”,“新”与“旧”,“真”与“假”,“深”与“浅”,“长”与“短”的关系。

  由于网络的开放性和跨空间性,使得受众群体有一定的发言权。新闻事件发生之后,现场目击者、当事人可以通过论坛发布信息。广泛的信息来源使得受众在全面了解信息之后就能发表自己的看法、就不同观点进行争论。交互功能可以通过嘉宾聊天、新闻留言、网上新闻调查、主题论坛等方式来实现。

页面、栏目设计(一定要方便匿名发帖!!这最最重要了,)

  根据网络受众对新闻内容阅读的跳跃性以及检索性,建立合理的链接系统、方便受众搜索。应该遵循视觉接触中心的原则,注重版面“和谐、平衡、活泼、富有表现力”的色彩进行设计。

  网络新闻媒体的版面语言主要体现在新闻在网页的“空间位置“上。一般说来,处于网页左方和上方的信息强势较大,因为这部分信息往往最先争得读者的“眼球”。这样,受众能从阅读的顺序中体会到稿件重要与否。标题的字体大小、排列方式、色彩等手段也在网络新闻的表现中得到应用。

  在旧的“以传播者为中心”的模式逐步被“以受众为中心”的新模式所代替的今天,网络媒体给受众提供了更多的选择信息的自由和方便,这也为网络编辑工作提出了挑战。因此,对网络新闻编辑而言提供信息并不是最重要的,对信息做出有效的处理,提高信息的服务质量才是竞争最有力的武器。

posted @ 2006-08-10 11:46 我的JAVA 阅读(266) | 评论 (0)编辑 收藏

这次有这样的机会,希望自己好好把握,希望是做最后一个网站。风险投资项目:www.cnmb.cnwww.cnmb.cnwww.cnmb.cnwww.cnmb.cnwww.cnmb.cnwww.cnmb.cnwww.cnmb.cnwww.cnmb.cnwww.cnmb.cnwww.cnmb.cnwww.cnmb.cnwww.cnmb.cnwww.cnmb.cnwww.cnmb.cn

posted @ 2006-06-21 23:32 我的JAVA 阅读(192) | 评论 (0)编辑 收藏

嘿嘿,偶来介绍下Webwork2结合Spring, Hibernate,Default认为对Spring,Hibernate有一定了解。
从User说起,包括创建/修改/删除User,以及对User的列表,先看Webwork2的Action代码
为简单说明问题,不考虑什么Interceptor, Duplicated Submit, Validation,等问题

创建/修改/删除User:UserAction.java相关代码

java代码: 

UserManager userManager;

public void setUserManager(UserManager) {
    this.userManager = userManager;
}

public String create() {
    userManager.create(getUser());
}

public String modify() {
    userManager.modify(modifyUser())
    return "success";
}

public String remove() {
    userManager.remove(getUser())
    return "success";
}



xwork.xml相关代码
java代码: 

<action name="user" class="com.caryo.user.actions.UserAction">
    <external-ref name="userManager">userManager</external-ref>
    <result name="success" type="dispatcher">user.jsp</result>
</action>



webwork action会自动接受页面上传过来的信息,而且还支持JavaBean的BeanInfo(BeanInfo没用过,偶
都是直接在action中完成获取属性,以及类型转换与校验的工作的)
Webwork2很方便的支持了Command模式,允许一个Action拥有多个Command,对应的url调用
user!create.action, user!modify.action, user!remove.action,会对应的调用UserAction中的方法,
然后根据方法返回值去寻找对应的View,return "sucess" 就会forward到user.jsp。
其中的userManager是Spring中applicationContext中定义的bean

java代码: 

<bean id="userManager" class="com.caryo.user.DefaultUserManager">
    <property name="userDAO"><ref local="userDAO"/></property>
</bean>



对User的列表:ListUserAction.java相关片断

java代码: 

UserManager userManager;

public void setUserManager(UserManager) {
    this.userManager = userManager;
}
// userManager的获取可放在一个User的根类声明,如AbstractUserAction,这里重复为了看得清楚些

public List getAllUsers() {
    userManager.getAllUsers();
}

public List getOnlineUsers() {
    userManager.getOnlineUsers();
}



xwork.xml相关代码
java代码: 

<action name="listuser" class="com.caryo.user.actions.ListUserAction">
    <external-ref name="userManager">userManager</external-ref>
    <result name="success" type="dispatcher">listuser.jsp</result>
</action>



这样对应的url就是listuser.action,无command模式下会自动执行public String execute()这一方法,
Default是一个返回"success"的空方法,当然你也可以重写此方法,例如做校验等等。

listuser.jsp中使用webwork taglib打出User列表的片断
java代码: 

<ww:iteraor value="allUsers">
userId: <ww:property value="id" />
userName: <ww:property value="name" />
</ww:iterator>

<ww:iteraor value="onlineUsers">
userId: <ww:property value="id" />
userName: <ww:property value="name" />
</ww:iterator>



webwork taglib功能比较强大,其中还可使用带参数的方法调用,而且在逻辑控制等方面都考虑的比较完善
详细参见 http://wiki.opensymphony.com/pages/viewpage.action?pageId=1876
只要设计合理,基本上使用其taglib就可以控制整个view,包括复杂的页面。尽管也支持Velocity, Freemarker等
不过考虑到性能,推荐还是使用jsp view。
大型网站的UI层应该尽可能的薄,JSP不易维护,我觉得taglib是可接受的厚度的上限了。

Spring+hibernate的部分跟dhj1版主的相近,http://forum.javaeye.com/viewtopic.php?t=7925
偶就不重复了。只说一些不同的地方
1. web.xml 可以使用listener来初始化基本信息而不是用servlet
2. 在Session in DAO中,用iterator返回数据应该是不行的,那么要获取count,不是iterator.next()
也不是获取整个list,然后list.size(),而应是一个list.get(0);
3. 可将HQL放到对应的hbm.xml中
java代码: 

public class HibernateVehicleDAO extends CaryoHibernateObjectDAO implements VehicleDAO {
   
        Class vehicleClass;

        public Class getPersistentClass() {
                return vehicleClass != null ? vehicleClass : (vehicleClass = Vehicle.class);
        }
       
        public Vehicle getById(final long id) {
        return (Vehicle) getByClassId(id);
        }

        public List findAllGlobalVehicles() {
                return findNamedQuery("caryo.vehicle_findAllGlobalVehicles");
        }
}



vehicle.hbm.xml相关代码
java代码: 

<query name="caryo.vehicle_findAllGlobalVehicles"><![CDATA[
    from Vehicle vehicle
]]></query>

posted @ 2005-08-29 11:03 我的JAVA 阅读(1020) | 评论 (2)编辑 收藏

本文是开发基于spring的web应用的入门文章,前端采用Struts MVC框架,中间层采用spring,后台采用Hibernate。

  本文包含以下内容:

   ·配置Hibernate和事务

   ·装载Spring的applicationContext.xml文件

   ·建立业务层和DAO之间的依赖关系

   ·将Spring应用到Struts中

  简介

  这个例子是建立一个简单的web应用,叫MyUsers,完成用户管理操作,包含简单的数据库增,删,查,该即CRUD(新建,访问,更新,删除)操作。这是一个三层的web应用,通过Action(Struts)访问业务层,业务层访问DAO。图一简要说明了该应用的总体结构。图上的数字说明了流程顺序-从web(UserAction)到中间层(UserManager),再到数据访问层(UserDAO),然后将结果返回。

  Spring层的真正强大在于它的声明型事务处理,帮定和对持久层支持(例如Hiberate和iBATIS)

  以下下是完成这个例子的步骤:

  1. 安装Eclipse插件

  2. 数据库建表

  3. 配置Hibernate和Spring

  4. 建立Hibernate DAO接口的实现类

  5. 运行测试类,测试DAO的CRUD操作

  6. 创建一个处理类,声明事务

  7. 创建web层的Action和model

  8. 运行Action的测试类测试CRUD操作

  9. 创建jsp文件通过浏览器进行CRUD操作

  10. 通过浏览器校验jsp

  安装eclipse插件

  1. Hibernate插件http://www.binamics.com/hibernatesync

  2. Spring插件http://springframework.sourceforge.net/spring-ide/eclipse/updatesite/

  3. MyEclipse插件(破解版)

  4. Tomcat插件. tanghan

  5. 其他插件包括xml,jsp,

  数据库建表


create table app_user(id number not null primary,firstname vchar(32),lastname vchar(32));

  新建项目

  新建一个web project,新建后的目录结构同时包含了新建文件夹page用于放jsp文件,和源文件夹test用于放junit测试文件。同时将用到的包,包括struts,hibernate,spring都导入到lib目录下。

  创建持久层O/R mapping

  1. 在src/com.jandar.model下用hibernate插件从数据库导出app_user的.hbm.xml文件改名为User.hbm.xml

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
   "-//Hibernate/Hibernate Mapping DTD//EN"
   "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd" >
<hibernate-mapping package="com.jandar.model">
<class name="User" table="APP_USER">
 <id
  column="ID"
  name="id"
  type="integer"
 >

  <generator class="assigned" />

 </id>

 <property
   column="LASTNAME"
   length="10"
   name="lastname"
   not-null="false"
   type="string"
 />

 <property
   column="FIRSTNAME"
   length="10"
   name="firstname"
   not-null="true"
   type="string"
 />

</class>
</hibernate-mapping>

  2. 通过hibernate synchronizer->synchronizer file生成User.java文件,User对象对应于数据库中的app_user表

  注:在eclipse下自动生成的对象文件不完全相同,相同的是每个对象文件必须实现Serializable接口,必需又toString和hashCode方法;

import java.io.Serializable;
import org.apache.commons.lang.builder.EqualsBuilder;
import org.apache.commons.lang.builder.HashCodeBuilder;
import org.apache.commons.lang.builder.ToStringBuilder;
import org.apache.commons.lang.builder.ToStringStyle;

public class BaseObject implements Serializable {
 public String toString() {
  return ToStringBuilder.reflectionToString(this,
  ToStringStyle.MULTI_LINE_STYLE);
 }

 public boolean equals(Object o) {
  return EqualsBuilder.reflectionEquals(this, o);
 }

 public int hashCode() {
  return HashCodeBuilder.reflectionHashCode(this);
 }
}

public class User extends BaseObject {
 private Long id;
 private String firstName;
 private String lastName;

 /**
 * @return Returns the id.
 */

 public Long getId() {
  return id;
 }

 /**
  * @param id The id to set.
 */

 public void setId(Long id) {
  this.id = id;
 }

 /**
 * @return Returns the firstName.
 */

 public String getFirstName() {
  return firstName;
 }

 /**
  * @param firstName The firstName to set.
 */

 public void setFirstName(String firstName) {
  this.firstName = firstName;
 }

 /**
 * @return Returns the lastName.
 */

 public String getLastName() {
  return lastName;
 }

 /**
 * @param lastName The lastName to set.
 */

 public void setLastName(String lastName) {
  this.lastName = lastName;
 }
}
创建DAO访问对象

  1. 在src/com.jandar.service.dao新建IDAO.java接口,所有的DAO都继承该接口

package com.jandar.services.dao;

public interface IDAO {

}

  2. 在src/com.jandar.service.dao下新建IUserDAO.java接口

public interface IUserDAO extends DAO {
 List getUsers();
 User getUser(Integer userid);
 void saveUser(User user);
 void removeUser(Integer id);
}

  该接口提供了访问对象的方法,

  3. 在src/com.jandar.service.dao.hibernate下新建UserDAOHiberante.java

import java.util.List;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.orm.hibernate.support.HibernateDaoSupport;
import com.jandar.model.User;
import com.jandar.service.dao.IUserDAO;

public class UserDaoHibernate extends HibernateDaoSupport implements IUserDAO {

 private Log log=LogFactory.getLog(UserDaoHibernate.class);
 /* (非 Javadoc)
 * @see com.jandar.dao.IUserDAO#getUsers()
 */

 public List getUsers() {
  return getHibernateTemplate().find("from User");
 }

 /* (非 Javadoc)
 * @see com.jandar.dao.IUserDAO#getUser(java.lang.Long)
 */

 public User getUser(Integer id) {
  // TODO 自动生成方法存根
  return (User) getHibernateTemplate().get(User.class,id);
 }

 /* (非 Javadoc)
 * @see com.jandar.dao.IUserDAO#saveUser(com.jandar.model.User)
 */

 public void saveUser(User user) {
  log.debug("xxxxxxx");
  System.out.println("yyyy");
  getHibernateTemplate().saveOrUpdate(user);
  if(log.isDebugEnabled())
  {
   log.debug("userId set to "+user.getId());
  }
 }

 /* (非 Javadoc)
 * @see com.jandar.dao.IUserDAO#removeUser(java.lang.Long)
 */

 public void removeUser(Integer id) {
  Object user=getHibernateTemplate().load(User.class,id);
  getHibernateTemplate().delete(user);
  if(log.isDebugEnabled()){
   log.debug("del user "+id);
  }
 }
}

  在这个类中实现了IUserDAO接口的方法,并且继承了HibernateDAOSupport类。这个类的作用是通过hibernate访问、操作对象,进而实现对数据库的操作。

posted @ 2005-08-26 15:58 我的JAVA 阅读(694) | 评论 (1)编辑 收藏

spring+hibernate开发网站

http://www.xyzp.net 校园招聘一网打尽

spring,一个轻量级的j2ee框架,轻量级的,这几个字就深深的把我吸引住了。抱着《spring in action》啃了一个星期,小了解之后,把自己所学的东西几乎通通用在了xyzp.net这个网站上,下面介绍一下:

校园招聘一网打尽 提供专业的校园招聘信息。系统自动采集全国各大高校BBS和就业中心的招聘信息,按照地区、学校进行组织分类。

http://www.xyzp.net网站分为两个部分:后台数据采集与前台展示。
1.后台数据采集,利用htmlparser分析网页,抽取我们所需的数据,以rss的结构进行存储。
2.前台展示,利用spring+hibernate开发。hibernate处理数据库逻辑,逻辑层使用spring,表示层应用spring本身的mvc。应用spring开发确实很方便,速度快,效率高;),整个网站2周就搞完了。而且,我不得不说,spring太美了。

hibernate处理数据库逻辑真是没的说,整个网站一共就4张表,大量一对多和多对多的逻辑,hibernate处理的很好,主要是编程方面要处理的逻辑简单了很多,但是效率方面有一点欠缺;(

spring本身提供一套完整的mvc,应用起来很方便,功能也很强大,几乎用的到的页面逻辑它都想到了。推荐使用。

应用了xmlhttprequest技术,因为首页调用数据库的次数太多,所以每个栏目都用一个远程调用来解决的,速度很快,不过有的ie显示还有一些问题;(

虽然xmlhttprequest提升速度比较明显,但对数据库操作的次数并没有减少,引入缓存机制才能从根本上解决,oscache是opensymphony的出品,它的页面级缓存把整个网页缓存下来,速度提升自然很明显。

整个网站没有使用table,全部使用css搞定,大家可以看一下。

整个网站全部采用开源软件构建,包括spring,hibernate,oscache,tomcat,mysql,eclipse,java commons.lucene等等。

在开发中碰到不少问题,字符集、链接池,spring与hibernate集成等等,对此有兴趣可以和我联系,QQ:21231398

如果大家觉得这个网站还不错,请推荐一下,谢谢;)

posted @ 2005-08-25 01:28 我的JAVA 阅读(978) | 评论 (3)编辑 收藏

其实Hibernate本身是个独立的框架,它不需要任何web server或application server的支持。然而,大多数的Hibernate入门介绍都加入了很多非Hibernate的东西,比如: Tomcat, Eclipse, Log4J,Struts, XDoclet, 甚至JBoss。这容易让人产生Hibernate复杂难懂的误解,特别是打击了初学者的积极性。

在这篇文章将不涉及Eclipse, log4j, Struts, Tomcat, XDoclet,和JBoss。本文的目的是演示一下Hibernate的安装过程以及最基本的功能,从而给初学者一个低得不能再低的入门门槛。


下载文件

你需要Java SDK、 Hibernate包、Ant包、和JDBC Driver。

1、Hibernate包下载地址:
http://prdownloads.sourceforge.net/hibernate/?sort_by=date&sort=desc

2、Ant包下载地址:
http://apache.130th.net/ant/binaries/apache-ant-1.6.1-bin.zip

3、JDBC Driver要根据你用的database来定,一般database官方网站上都会有。Hibernate支持常用的database,比如 MySQL, Oracle, PostgreSQL, 和MS-SQL Server。这些数据库都有JDBC Driver:

Oracle JDBC Driver下载地址(下载前必须同意Oracle协议书)
http://otn.oracle.com/software/htdocs/distlic.html?/software/tech/java/sqlj_jdbc/htdocs/jdbc9201.html

MySQL JDBC Driver下载地址
http://dev.mysql.com/downloads/connector/j/3.0.html

PostgreSQL JDBC Driver下载地址
http://jdbc.postgresql.org/download.html

MS-SQL Server JDBC Driver下载地址
http://www.microsoft.com/downloads/details.aspx?FamilyID=9f1874b6-f8e1-4bd6-947c-0fc5bf05bf71&displaylang=en

4、将Hibernate包和Ant包分别解压至c:\dev\下(此目录不重要,你可以换其它任何目录)。


配置环境

1、你需要添加一个新的环境变量: ANT_HOME,让它指向c:\dev\<你的ANT包所在目录>。并在PATH环境变量里添加%ANT_HOME%\bin。

2、你需要添加一个新的环境变量: JAVA_HOME,让它指向你的j2sdk根目录。并在PATH环境变量里添加%JAVA_HOME%\bin。

3、创建一个项目目录,比如c:\workspace\My1stHibernate。

在项目目录下,另外创建三个目录: src, classes, lib。

在lib目录下,创建两个目录: hibernate和db。

这样你有了如下的文件结构:

c:\workspace\My1stHibernate\
c:\workspace\My1stHibernate\src
c:\workspace\My1stHibernate\classes
c:\workspace\My1stHibernate\lib
c:\workspace\My1stHibernate\lib\hibernate
c:\workspace\My1stHibernate\lib\db

4、将c:\dev\<你的Hibernate包所在目录>\hibernate2.jar文件copy到c:\workspace\My1stHibernate\lib\hibernate下。

将c:\dev\<你的Hibernate包所在目录>\lib\下的所有文件同样copy到c:\workspace\My1stHibernate\lib\hibernate下。

将你的JDBC Driver文件(一般是一个jar文件)copy到c:\workspace\My1stHibernate\lib\db下。


创建数据库

1、用你最喜爱的database软件,创建一个hibernate_test的数据库。

2、在此数据库下,新建一个table名为CUSTOMER

CREATE TABLE CUSTOMER
(
    CID INTEGER NOT NULL PRIMARY KEY,
    USERNAME VARCHAR(12) NOT NULL,
    PASSWORD VARCHAR(12)
);


编写Java文件

public class Customer {
   
    private int id;
    private String username;
    private String password;


    public int getId() {
        return id;
    }

    public String getPassword() {
        return password;
    }

    public String getUsername() {
        return username;
    }

    public void setId(int id) {
        this.id = id;
    }

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

    public void setUsername(String username) {
        this.username = username;
    }

}

将此类存为c:\workspace\My1stHibernate\src\Customer.java文件。

编写Test类

import net.sf.hibernate.*;
import net.sf.hibernate.cfg.*;

public class Test {

    public static void main(String[] args) {

        try {
            SessionFactory sf =
                new Configuration().configure().buildSessionFactory();
            Session session = sf.openSession();
            Transaction tx = session.beginTransaction();

            for (int i = 0; i < 200; i++) {
                Customer customer = new Customer();
                customer.setUsername("customer" + i);
                customer.setPassword("customer");
                session.save(customer);
            }

            tx.commit();
            session.close();

        } catch (HibernateException e) {
            e.printStackTrace();
        }
    }
}

将此类存为c:\workspace\My1stHibernate\src\Test.java文件。


创建Hibernate映射文件

因为这里只有一个Class --- Customer 和一个Table --- CUSTOMER,你只需要建立一个映射文件--- Customer.hbm.xml,来对应Customer类和CUSTOMER表之间的关系。

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
    "-//Hibernate/Hibernate Mapping DTD//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">

<hibernate-mapping>
    <class name="Customer" table="CUSTOMER">
        <id name="id" column="CID">
            <generator class="increment" />
        </id>
        <property name="username" column="USERNAME" />
        <property name="password" column="PASSWORD" />
    </class>
</hibernate-mapping>

把此文件存为c:\workspace\My1stHibernate\src\Customer.hbm.xml,和Customer.java放在同一目录下。


编写Ant build.xml文件


你不一定要知道这个build.xml的细节,其实Ant也不是Hibernate所必须的。这里用Ant是为了简化一些任务,比如: 编译、copy、运行,等。

<?xml version="1.0" ?>

<project name="My1stHibernate" default="build" basedir=".">

    <property name="base.dir" value="." />
    <property name="src.dir" value="src" />
    <property name="lib.dir" value="lib" />
    <property name="build.dir" value="classes" />

    <path id="myclasspath">
        <fileset dir="${lib.dir}">
            <include name="**/*.jar" />
        </fileset>
        <pathelement location="${build.dir}" />
    </path>

    <target name="init">
        <mkdir dir="${build.dir}" />
    </target>
   
    <target name="build" depends="init" description="compile the source files">
        <javac classpathref="myclasspath" srcdir="${src.dir}" destdir="${build.dir}" />
        <copy todir="${build.dir}" >
            <fileset dir="${src.dir}" >
                <exclude name="**/*.java"/>
            </fileset>
        </copy>
    </target>

    <target name="run" depends="build">
        <java classpathref="myclasspath" classname="Test" fork="true" />
    </target>

    <target name="clean">
        <delete includeEmptyDirs="true">
            <fileset dir="${build.dir}" />
        </delete>
    </target>

</project>


配置Hibernate描述文件

Hibernate描述文件可以是一个properties或xml 文件,其中最重要的是定义数据库的连接。我这里列出的是一个XML格式的hibernate.cfg.xml描述文件。

<?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE hibernate-configuration
    PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
    "http://hibernate.sourceforge.net/hibernate-configuration-2.0.dtd">

<hibernate-configuration>
   
    <session-factory name="java:/hibernate/HibernateFactory">
       
        <property name="show_sql">true</property>
        <property name="connection.driver_class">
            oracle.jdbc.driver.OracleDriver <!-- 这里是Oracle 9i的JDBC driver class名 -->
        </property>
        <property name="connection.url">
            jdbc:oracle:oci8:@hibernate_test <!-- 这里是Oracle的hibernate_test数据库URL -->
        </property>
        <property name="connection.username">
            你的数据库用户名
        </property>
        <property name="connection.password">
            你的数据库密码
        </property>
        <property name="dialect">
            net.sf.hibernate.dialect.Oracle9Dialect <!-- 这里是Oracle 9i的Dialect -->
        </property>
       
        <mapping resource="Customer.hbm.xml" /> <!-- 指定Customer的映射文件 -->
       
    </session-factory>
   
</hibernate-configuration>

如果你用的不是Oracle 9i,可到C:\dev\<你的Hibernate包所在目录>\src\hibernate.properties文件里找到你的数据库,然后替换以上相对应的值。


开始运行

到c:\workspace\My1stHibernate下,运行ant run。如果你严格依照以上步骤,应该看到

run:
        [java] log4j:WARN No appenders could be found for logger (net.sf.hibernate.cfg.Environment).
        [java] log4j:WARN Please initialize the log4j system properly.
        [java] Hibernate: insert into CUSTOMER (USERNAME, PASSWORD, CID) values (?, ?, ?)
BUILD SUCCESSFUL

到你的hibernate_test数据库看一下,在CUSTMOR表里新添了200条记录,但你没有写任何JDBC code。
以后如果你要更换数据库,只需要改变hibernate.cfg.xml描述文件里相应的值即可。


结论

此文是一篇门槛极低的入门介绍。我给一个完全不懂Hibernate的朋友看,他用了不到30分钟就运行了他的第一个Hibernate程序,从此引起了 他对Hibernate的兴趣。但读者必须认识到这只是一个开始,此文实乃窥Hibernate冰山一角上的一颗小冰晶。千里之行始于足下,你可以把此文 当作迈向Hibernate大道的一个起点。

posted @ 2005-08-24 01:58 我的JAVA 阅读(657) | 评论 (0)编辑 收藏

对象、关系的映射(ORM)是一种耗时的工作,在Java环境下,有几种框架来表示持久数据,如实体Bean、OJB、JDO、Hibernate等。Hibernate是一种新的ORM映射工具,它不仅提供了从Java类到数据表的映射,也提供了数据查询和恢复等机制。本文介绍怎么在Web应用开发中配置Hibernate的环境,并且使用Hibernate来开发一个具体的实例。

  介绍

  面向对象的开发方法是当今的主流,但是同时我们不得不使用关系型数据库,所以在企业级应用开发的环境中,对象、关系的映射(ORM)是一种耗时的工作。围绕对象关系的映射和持久数据的访问,在Java领域中发展起来了一些API和框架,下面分别简单介绍。

  JDBC可以说是访问持久数据层最原始、最直接的方法。在企业级应用开发中,我们可能使用DAO(Data Access Object)模式来把数据访问封装起来,然后在其它的层中同一调用。这种方式的优点是运行效率最高,缺点是把DAO对象和SQL语言紧密耦合在一起使得在大项目中难以维护。但是不管怎么说,使用JDBC来直接访问持久数据层是当今企业级应用开发中使用最广泛的。

  实体Bean是J2EE平台中用来表示和访问持久数据的方式。虽然实体Bean是一种方便快捷的方法,但是在运行时我们需要额外购买EJB容器(当然,如今也有免费的EJB容器,如JBOSS),并且使用不同的应用服务器,需要重新书写不同的部署描述,使得在不同应用服务器下移植企业级应用会带来一些困难。

  另外,在Java领域中,还有一些表示持久数据的框架,比如JDO和OJB,在这里就不详细介绍了。

  Hibernate是一种新的ORM映射工具,它不仅提供了从Java类到数据表之间的映射,也提供了数据查询和恢复机制。相对于使用JDBC和SQL来手工操作数据库,使用Hibernate,可以大大减少操作数据库的工作量。

  Hibernate可以和多种Web服务器或者应用服务器良好集成,如今已经支持几乎所有的流行的数据库服务器(达16种)。

  下面我们来介绍怎么结合Hibernate2.0和Apache Tomcat5.0在Web应用中使用Hibernate。

  配置

  1、下载安装Tomcat,并且下载Hibernate的运行环境(主要包含一些JAR包)。
  2、把要使用的数据库的JDBC驱动程序拷贝到%TOMCAT_HOME%\common\lib目录下。笔者使用的是MYSQL,对应的驱动程序的JAR包为mm.mysql-2.0.4-bin.jar。
  3、在Tomcat的Webapps目录下新建一个Web应用,名字为hibernate。
  4、把Hibernate提供的hibernate2.jar和一些第三方的运行库拷贝到hibernate\WEB\INF\lib目录下。(这些第三方的运行库包含在下载的Hibernate lib目录下)
  5、在%TOMCAT_HOME%\conf\server.xml中Web应用和数据源。在server.xml中加入以下的配置描述。

  例程1 配置web应用

 <Context path="/hibernate" docBase="hibernate" debug="0"   reloadable="true" crossContext="true">
  <Resource name="jdbc/hibernate" auth="Container" type="javax.sql.DataSource"/>  
     <ResourceParams name="jdbc/hibernate"> 
      <parameter>  
          <name>factory</name>  
       <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>  
      </parameter>
      <parameter>  
         <name>driverClassName</name>  
            <value>org.gjt.mm.mysql.Driver</value>  
       </parameter> 
        <parameter> 
              <name>url</name>  
              <value>jdbc:mysql:///test</value>  
         </parameter>  
       <parameter> 
            <name>username</name> 
           <value>root</value> 
       </parameter>  
      <parameter> 
         <name>password</name>  
         <value></value> 
          </parameter>  
      <parameter> 
      <name>maxActive</name> 
      <value>20</value> 
    </parameter>
         <parameter>  
        <name>maxIdle</name>  
           <value>10</value>
    </parameter> 
    <parameter> 
          <name>maxWait</name> 
      <value>-1</value> 
    </parameter>  
  </ResourceParams>  
 </Context>

  在这里,配置了一个名为hibernate的Web应用,并且配置了一个数据源,数据源的JNDI名称为jdbc/hibernate。您需要根据情况修改数据源的链接属性。

  6、下一步就是书写Hibernate的配置描述符。可以使用XML的配置描述,也可以使用基于属性的配置描述。在这里使用基于XML的配置描述。在hibernate\WEB-INF\classes目录下新建一个hibernate.cfg.xml文件。然后加入例程2所示的内容。

<!DOCTYPE hibernate-configuration
    PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
    "http://hibernate.sourceforge.net/hibernate-configuration-2.0.dtd">

<hibernate-configuration>
    <session-factory>
        <property name="connection.datasource">java:comp/env/jdbc/hibernate</property>
        <property name="show_sql">false</property>
        <property name="dialect">net.sf.hibernate.dialect.MySQLDialect</property>
        <!-- Mapping files -->
    </session-factory>
</hibernate-configuration>

  注意connection.datasource属性必须和server.xml中配置的数据源的属性一样。如果不是使用MYSQL,那么需要更改dialect属性。

  到现在,配置基本完成,下面我们来开发一个最简单的应用。

  开发持久对象、编写映射描述

  我们使用hibernate来封装一个简单的数据表。这个表的名字为Courses,它有两个字段,一个是ID,它是Courses表的主键;另一个是name,表示Courses的名字。在数据库中使用以下的脚本来创建这个表:

  create table Courses(CourseId varchar(32) not null, name varchar(32), constraint pk_Courses primary key (CourseId) );

  接下来的任务就是为Courses表书写持久对象,如例程3所示。

  例程3 Courses的持久对象(Courses.java)

package com.hellking.study.hibernate;

import java.util.Set;

/**
 *在hibernate中代表了Course表的类。
 */
public class Course
{
   /**每个属性和表的一个字段对应**/
   private String id;
   private String name;
  
   /**students表示course中的学生,在后面才会用到,暂时不管**/
   private Set students;
    
    /**属性的访问方法**/
 public void setId(String string) {
  id = string;
 }
 
 public String getId() {
  return id;
 }
 
 public void setName(String name)
 {
  this.name=name;
 }
 public String getName()
 {
  return this.name;
 }
 public void setStudents(Set stud)
 {
  this.students=stud;
 }
 public Set getStudents()
 {
  return this.students;
 }
}

  可以看出,在Course类中也包含了两个属性,id和name,它的属性和表Courses的字段是一一对应的,并且类型一致。

  书写好了持久对象,接下来的任务就是书写对象、关系映射描述。在hibernate\WEB-INF\classes目录下新建一个Course.hbm.xml描述文件,内容如例程4所示。

  例程4 Course.hbm.xml

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
    "-//Hibernate/Hibernate Mapping DTD 2.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">

<hibernate-mapping>
    <class
        name="com.hellking.study.hibernate.Course"
        table="Courses"
        dynamic-update="false"
    >

        <id
            name="id"
            column="CourseId"
            type="string"
            unsaved-value="any"
        >
            <generator class="assigned"/>
        </id>

        <property
            name="name"
            type="string"
            update="true"
            insert="true"
            column="Name"
        />     
    </class>
</hibernate-mapping>

  在Course.hbm.xml映射文件中,指定了要映射的类和映射的表,并且指定了表的各个字段和Java对象中各个字段的映射关系,比如Course对象中的id属性对应了Courses表的courseId字段。

  接下来的任务就是在hibernate.cfg.xml中指定这个映射关系。如下所示:

<session-factory>

<!-- Mapping files --> 
 <mapping resource="Course.hbm.xml"/>
</session-factory>

  编写业务逻辑

  到此,我们已经封装了一个名为Courses的表,并且配置完成。接下来的任务就是在Web应用开发中使用它们,为了演示在Hibernate中对数据库的不同类型的操作,我们开发的Web应用有以下的功能:
  增加一个Course;
  删除一个Course;
  按照Course的名字进行模糊搜索;
  查看系统中所有的Course。

  虽然我们可以直接在JSP中使用hibernate,但是往往我们不这样,而是把这些业务逻辑封装在JavaBean中,然后在JSP中通过调用JavaBean以访问Hibernate封装的对象。

  由于访问通过使用hibernate有一些共性的操作,在这里我们把这些共性的操作封装在一个专门的类中,这样其它的类可以继承它,如例程5所示。

  例程5 HibernateBase.java

package com.hellking.study.hibernate;

import net.sf.hibernate.*;
import net.sf.hibernate.cfg.*;
import java.util.*;
import java.io.IOException;
import java.io.PrintWriter;

public abstract class HibernateBase
{
 protected SessionFactory sessionFactory;//会话工厂,用于创建会话
    protected Session session;//hibernate会话
    protected Transaction transaction; //hiberante事务
   
    public HibernateBase()throws HibernateException
    {
     this.initHibernate();
    }
    // 帮助方法
    protected void initHibernate()
        throws HibernateException {

        // 装载配置,构造SessionFactory对象
        sessionFactory = new Configuration().configure().buildSessionFactory();
    }
   
    /**
     *开始一个hibernate事务
     */
    protected void beginTransaction()
        throws HibernateException {

        session = sessionFactory.openSession();
        transaction = session.beginTransaction();
    }
   
    /**
     *结束一个hibernate事务。
     */
    protected void endTransaction(boolean commit)
        throws HibernateException {

        if (commit) {
            transaction.commit();
        } else {
           //如果是只读的操作,不需要commit这个事务。
            transaction.rollback();
        }
         session.close();
    }
}

  下面编写业务逻辑类,新建一个名为CourseBean的JavaBean,并且CourseBean继承HibernateBase类,代码如例程6所示。

  例程6 CourseBean.java

package com.hellking.study.hibernate;

import net.sf.hibernate.*;
import net.sf.hibernate.cfg.*;
import java.util.*;

/**
 *和course相关的业务逻辑
 */
public class CourseBean extends HibernateBase
{
 public CourseBean()throws HibernateException
 {
  super();
 }
 /**
  *增加一个Course
  */
 public void addCourse(Course st)throws HibernateException
 {
  beginTransaction();
         session.save(st);        
         endTransaction(true);
    }
   
    /**
     *查询系统中所有的Course,返回的是包含有Course持久对象的Iterator。
     */
    public Iterator getAllCourses()throws HibernateException
    {
      String queryString = "select courses from Course as courses";
        beginTransaction();
        Query query = session.createQuery(queryString);
        Iterator it= query.iterate();
        return it;
    }
   
    /**
     *删除给定ID的course
     */
    public void deleteCourse(String id)throws HibernateException
    {
      beginTransaction();     
      Course course=(Course)session.load(Course.class,id);     
      session.delete(course);
      endTransaction(true);
     }
   
    /**
     *按course的名字进行模糊查找,返回的是包含有Course持久对象的Iterator。
     */
    public Iterator getSomeCourse(String name)throws HibernateException
    {
       String queryString = "select c from Course as c where c.name like :name" ;
         beginTransaction();
         Query query = session.createQuery(queryString);
         query.setString("name", "%"+name+"%");
        Iterator it= query.iterate();
        return it;
    }     
}

  在CourseBean封装了4个业务方法,你可以根据情况增加其它的业务方法。在CourseBean中,通过Hibernate来操作潜在的数据库资源。

  要保存Course数据到数据库,可以通过:

  session.save(Course);

  方法来保存,它相当于使用在JDBC中执行以下语句:

  Connection con=…
  Statement stmt=con.createStatement();
  stmt.executeUpdate("insert into courses values('"+course.getId(),+"','"+course.getName()+"')");
  con.close();

  可以看出,通过使用Hibernate,可以大大减少数据访问的复杂度。

  在JSP中调用业务逻辑

  添加数据

  CourseBean这个业务对象封装了和Hibernate的交互关系,从而使JSP和Hibernate关系的解藕。我们来看测试主页面的部分代码,如例程7所示。

  例程7 测试Hibernate开发的应用(course.jsp)

<%@ page import="java.sql.*,java.util.*" errorPage="error.jsp"%>
<jsp:useBean id="course" class="com.hellking.study.hibernate.Course" scope="page">
<jsp:setProperty name="course" property="*"/>
</jsp:useBean>
<jsp:useBean id="courseBusiness" class="com.hellking.study.hibernate.CourseBean" scope="page"/>
<html><body><center>
<% 
  try
  {
  if(course.getId().equals(null)||course.getId().equals(""));
  else courseBusiness.addCourse(course);
 
  %>
成功添加了Course:<br>
name:<%=course.getName()%>
Id:<%=course.getId()%>
<%
}
  catch(Exception e)
  {
  } 
%>

<hr>
<br>::增加一个course::<br>
<form action="course.jsp" method="get" name="add">
id:<input type=text name="id"><br>
name:<input type=text name="name"><br>
<input type=submit value="submit"><br>
</form>
<hr>
::按名字模糊查找::<br>
<form action="queryCourse.jsp" method="get" name="queryByName">
name:<input type=text name="name"><br>
<input type=submit value="query"><br>
</form>
<hr>
::删除一个Course::<br>
<form action="deleteCourse.jsp" method="get" name="queryByName">
id:<input type=text name="id"><br>
<input type=submit value="delete"><br>
</form>
<hr>
<a href=viewAll.jsp>::查看所有Course::<a>
</body>
</html>

  首先通过一个值对象Course(这个类正好是Hibernate使用的持久对象,这里作为值对象来传递数据)接收获得的参数,然后CourseBean的addCourse(Course)方法把数据保存到数据库。可以看出,通过使用Hibernate,把数据从表单中添加到数据库非常简单。

  查询

  下面来看模糊查找的JSP代码,如例程8所示。

  例程8 按名字模糊查找Course

<%@ page import="java.sql.*,java.util.*,com.hellking.study.hibernate.Course" errorPage="error.jsp"%>
<jsp:useBean id="courseBusiness" class="com.hellking.study.hibernate.CourseBean" scope="page"/>

<% try
{
   Iterator it=courseBusiness.getSomeCourse((String)request.getParameter("name"));
   while(it.hasNext())
   {
     Course temp=(Course)it.next();
     out.println("<tr><td>"+temp.getId()+"</td>");
     out.println("<td>"+temp.getName()+"</td></tr>");
   }
  }
  catch(Exception e)
  {
    out.println(e.getMessage());
   }
%>
….

  它实际上调用的是CourseBean的Iterator getSomeCourse(String name)方法。我们来回顾一下这个方法中的代码:

  /**
     *按course的名字进行模糊查找
     */
    public Iterator getSomeCourse(String name)throws HibernateException
    {
       String queryString = "select c from Course as c where c.name like :name" ;
        beginTransaction();
        Query query = session.createQuery(queryString);
         query.setString("name", "%"+name+"%");
        Iterator it= query.iterate();
        return it;
    }

  在查询前,首先调用beginTransaction方法启动新的Hibernate事务,然后创建一个Query对象,在创建这个对象时,同时指定查询的语句。

  注意,在查询语句:

  select c from Course as c where c.name like :name"

  中,它虽然和普通的SQL语句相似,但是不同,在数据库中,使用的表的名字是Courses,而在这个查询语句中使用的是Course,它和持久对象的名字一致,也就是说,这个查询的概念是查询持久对象,而不是数据库的记录。

  创建了查询对象Query后,需要设置查询的参数,它和在JDBC中PreparedStatement对象中设置参数的方法相似。通过"Iterator it= query.iterate()"语句来执行查询,并且返回一个Iterator对象。在这里使用了Hibernate提供的查询机制,一般的JDBC查询返回的是ResultSet对象,而这里返回的是包含了CourseBean对象的Iterator。

  要查询系统中所有的Course,也同样非常简单,可以通过例程9所示的代码实现。

  例程9 查询数据库中所有的Course


<jsp:useBean id="courseBusiness" class="com.hellking.study.hibernate.CourseBean" scope="page"/>

<% try
{
   Iterator it=courseBusiness.getAllCourses();
   while(it.hasNext())
   {
     Course temp=(Course)it.next();
     out.println("<tr><td>"+temp.getId()+"</td>");
     out.println("<td>"+temp.getName()+"</td></tr>");
   }
  }
  catch(Exception e)
  {
    out.println(e.getMessage());
   }
%>

  实际上调用的是CourseBean的getAllCourses方法,它和getSomeCourse方法机制一样,就不再介绍了。

  删除数据

  在JSP中,使用以下的代码来执行删除操作。

  例程10 删除数据库中Courses表的记录

<jsp:useBean id="courseBusiness" class="com.hellking.study.hibernate.CourseBean" scope="page"/>

删除id为:<%=request.getParameter("id")%>的course::::<br>

<% try
{
 courseBusiness.deleteCourse(request.getParameter("id"));
 out.println("删除成功");
}
  catch(Exception e)
  {
    out.println("不存在这个记录");
   }
%>

  我们来看CourseBean中执行删除操作的具体代码:

  /**
     *删除给定ID的course
     */
    public void deleteCourse(String id)throws HibernateException
    {
     beginTransaction();     
     Course course=(Course)session.load(Course.class,id);     
     session.delete(course);
     endTransaction(true);
     }

  在这个方法中,首先开始一个事务,然后通过session.load(Course.class,id)方法来装载指定ID的持久对象,接下来通过"session.delete(course)"来删除已经装载的course,并且结束Hibernate事务。

  总结

  下面总结一下使用Hibernate的开发过程:

  1、配置Hibernate(一次即可);
  2、确定数据表;
  3、创建持久对象;
  4、编写对象和数据表的映射描述;
  5、编写和业务逻辑。

  实际上,上面的过程和使用EJB没有什么区别:在使用EJB时,首先当然也是配置环境,初始化数据表;然后创建实体Bean(对象于Hibernate的持久对象);接下来编写部署描述符(ejb-jar.xml,厂商专有的部署描述),在这些部署描述符里,指定了EJB和数据表的映射关系,如果多个实体Bean存在关联关系,需要描述它们之间的关系,这些描述对应于Hibernate中持久对象的描述,如Course.hbm.xml;往往我们并不在应用程序中直接操作实体Bean,而是通过业务对象(如会话Bean)来操作,这里的会话Bean可以简单的和Hibernate中执行业务逻辑的JavaBean对应。这里只是简单的类比,不是绝对的,比如我们同样可以在会话Bean中访问Hibernate持久对象,也就是说使用Hibernate,同样可以把业务逻辑放在会话Bean中。

  通过本文的学习,相信读者对Hibernate已经有了初步的认识,并且能够使用Hibernate开发简单的应用。在下一篇中,我们将学习怎么使用Hibernate来为复杂的数据表进行映射,并且维护它们之间的关系。

posted @ 2005-08-24 01:56 我的JAVA 阅读(1074) | 评论 (0)编辑 收藏


posts - 10, comments - 9, trackbacks - 0, articles - 0

Copyright © 我的JAVA