用properties配置hibernate连接数据库信息

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import java.util.Properties;

import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;


public class HibernateUtil {
static SessionFactory sessionFactory = null;

static
{
try
{

final String path = URLDecoder.decode(Thread.currentThread().getContextClassLoader().getResource(
"config.properties").getPath(), "UTF-8"); //config.properties保存的真实路径
final Properties properties = new Properties();
final InputStream fis = new FileInputStream(path); //config.properties 文件对象,里面有数据库的连接信息,
properties.load(fis);
fis.close(); //关流
final String dbhost = properties.getProperty("dbhost"); //数据库IP(从config.properties读)
final String dbport = properties.getProperty("dbport"); //端口(从config.properties读)
final String dbname = properties.getProperty("dbname"); //数据库名(从config.properties读)
final String dbuser = properties.getProperty("dbuser"); //用户名(从config.properties读)
final String dbpw = properties.getProperty("dbpw"); //密码(从config.properties读)

final Properties extraProperties = new Properties();
extraProperties.setProperty("hibernate.connection.url", "jdbc:mysql://" + dbhost + ":" + dbport + "/"
+ dbname + "?zeroDateTimeBehavior=convertToNull");
extraProperties.setProperty("hibernate.connection.username", dbuser);
extraProperties.setProperty("hibernate.connection.password", dbpw);

final Configuration cfg = new Configuration();
cfg.addProperties(extraProperties);
cfg.configure("hibernate.cfg.xml"); //路径可以改变
sessionFactory = cfg.buildSessionFactory();
}
catch (final UnsupportedEncodingException e)
{
//不支持字符编码。
e.printStackTrace();
}
catch (final FileNotFoundException e)
{
//config.properties文件没找到
e.printStackTrace();
}
catch (final HibernateException e)
{
//cfg.configure("hibernate.cfg.xml");时异常
e.printStackTrace();
}
catch (final Exception e)
{
//创建SessionFactory 异常
e.printStackTrace();
}
}

public static SessionFactory getSessionFactory()
{
return sessionFactory;
}

/**
* 取得session
*
* @return session
*/
public static Session getSeesion()
{
return sessionFactory.openSession();
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值