EJB3.0实现登录注册(一)

 

环境

IDE:Eclipse3.4JavaEE版)

数据库:MySQL5.0

服务器:Jboss4.0.5

步骤

1. 搭建环境

2. MySQL中建立数据库表

表结构如下:

Id:无实意主键,采用自增方式生成

stuId:学号

Name:姓名

Password:密码

registerDate:注册时间

email:Email

phone:电话号码

sex:性别

对应的SQL语句如下:

DROP TABLE IF EXISTS `account`;

CREATE TABLE `account` (

  `Id` int(11) NOT NULL auto_increment,

  `stuId` varchar(20) NOT NULL,

  `name` varchar(50) NOT NULL,

  `sex` varchar(6) ,

  `registerDate` date ,

  `email` varchar(100) ,

  `phone` varchar(30 ,

  `password` varchar(20) ,

  PRIMARY KEY  (`Id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

3. 建立EJB工程

4. 编写简单Bean文件Account.java

定义Account类所具有的属性和方法,不包含任何业务相关代码,其中的属性与数据库表的各列相对应,通过Eclipse自动生成各属性的gettersetter方法。

5.创建实体Bean

6. 编写无状态SessionBean

 SessionBean用于实现业务逻辑,可分为有状态Bean(Stateful Bean)和无状态Bean(Stateless Bean)。当客户端请求时,服务器就会分配Session Bean为客户端服务。Session Bean可以直接访问数据库,但更多的时候是通过实体Bean实现数据访问。Session Bean可以作为业务处理对象出现在应用体系中。在本实验中EclipseSessionBean创建向导创建无状态SessionBean, 命名为AccountManageState type选择"Stateless",接口类型选择"Remote",创建成功后Eclipse会自动生成远程接口类AccountManageRemote。首先需要定义接口的内容,因为调用EJB 的客户端是通过使用这个接口的引用从EJB容器得到的会话Bean对象stub,从而进行所需操作的。

在实现类中添加EntityManager的获取代码,EntityManager 是用来对实体Bean进行操作的辅助类。它可以用来产生/删除持久化的实体Bean,通过主键查找实体bean,也可以通过EJBQL语言查找满足条件的实体BeanEntityManager 的获取可以通过@PersistenceContext注释由EJB容器(本实验中即jboss)动态注入。修改后的AccountManage类如下

@Stateless

public class AccountManage implements AccountManageRemote {

 

@PersistenceContext(unitName = "test")

private EntityManager manager;

 

public AccountManage() {

}

 

@Override

public void addAccount(Account account) {

manager.persist(account);

try {

Producer.sendMessage("Congratulations! Register success!");

catch (Exception e) {

System.out.println("@Send message error!");

e.printStackTrace();

}

}

 

@Override

public Account findAccount(String name, String password) {

Query query = manager.createQuery("from Account c " +

                " where c.name=:name" +

                " and c.password=:password");

query.setParameter("name", name);

query.setParameter("password", password);

Account account = (Account)query.getSingleResult();

try {

if(account==null){

Producer.sendMessage("Login failed!");

}else{

Producer.sendMessage("Congratulations! Login success!");

}

catch (Exception e) {

System.out.println("@Send message error!");

e.printStackTrace();

}

return account;

}

 

@Override

public Account findAccountById(int id) {

return manager.find(Account.class, id);

}

 

}

代码中对应于注册的addAccount方法通过EntityManager自带的API中的persist方法来实现,而对应于注册的查询方法findAccount通过手动编写EJB QL来实现,以用户名(学号)和密码作为参数,返回符合条件的结果,如果登录失败则返回null,同时利用消息驱动Bean向队列中发送成功或失败的消息。

7. 编写客户端程序调用SessionBean来完成登录和注册的功能。

为简单起见,客户端程序并没有提供图形用户界面,只起到简单测试的作用,因此将注册和登录信息都写死在了程序中。具体如下:

 

8. 编写相关配置文件

由于一部分配置文件可以由EclipseJboss自动生成,所以需要写的配置文件只有两个,一个是JNDI的配置文件,另一个是日志的相关配置。其中的JNDI(The Java Naming and Directory Interface,Java 命名和目录接口) 是一组在Java 应用中访问命名和目录服务的API。为开发人员提供了查找和访问各种命名和目录服务的通用、统一的方式。借助于JNDI 提供的接口,能够通过名字定位用户、机器、网络、对象服务等。命名服务就像DNS 一样,通过命名服务器提供服务,大部分的J2EE 服务器都含有命名服务器。目录服务一种简化的RDBMS 系统,通过目录具有的属性保存一些简单的信息。目录服务通过目录服务器实现,比如微软ACTIVE DIRECTORY 等。使用JNDI可带来如下好处:
        (1)包含大量命名和目录服务,可以使用相同API 调用访问任何命名或目录服务。
        (2)可以同时连接多个命名和目录服务。
        (3)允许把名称同JAVA 对象或资源关联起来,不必知道对象或资源的物理ID。
        (4)使用通用接口访问不同种类的目录服务
        (5)使得开发人员能够集中使用和实现一种类型的命名或目录服务客户API 上。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值