浅析Mybatis 在CS程序中的应用
2013-07-19 11:58
1611 查看
因为mybatis好使,所以几乎需要操作数据库的时候,我都会使用mybatis,而且在一个正式的项目中,同时存在BS和CS的程序,都使用的Mybatis,使用的相同mapper文件。
Mybatis的XML配置文件正常如下:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<property name="driver" value="driver" />
<property name="url" value="url" />
<property name="username" value="username" />
<property name="password" value="password" />
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="com/isea/dao/YouMapper.xml" />
</mappers>
</configuration>
为了防止数据库用户名密码泄漏,我将XML进行双向加密,变成了一个字节文件,而且文件名后缀随意。
例如:basic.data,内容局部如下:
根据XML生成Mybatis的SqlSessionFactory,代码如下:
public class MyBatis {
private static final String CONFIG = "basic.data";
private SqlSessionFactory sqlSessionFactory;
private static MyBatis instance = new MyBatis();
private MyBatis(){
InputStream inputStream = null;
try {
inputStream = getXMLIS();
if(inputStream==null){
throw new RuntimeException("数据库信息配置失败!");
}
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} finally{
try {
inputStream.close();
} catch (Exception e) {
}
}
}
public static InputStream getXMLIS(){
InputStream inputStream = null;
try {
//对资源进行加密,解密后处理
BufferedReader reader = new BufferedReader(new FileReader(new File(Config.LOCATION+"/"+CONFIG)));
String str = null;
StringBuffer sbBuffer = new StringBuffer();
while((str=reader.readLine())!=null){
sbBuffer.append(str);
}
EncrypDES encrypDES = new EncrypDES();
String result = encrypDES.Decryptor(sbBuffer.toString());
inputStream = new ByteArrayInputStream(result.getBytes());
return inputStream;
} catch (Exception e) {
}
return null;
}
public SqlSessionFactory getSqlSessionFactory(){
return sqlSessionFactory;
}
public static MyBatis getInstance(){
return instance;
}
}
这里的data文件是在src下。
代码中的EncrypDES是一个使用DES的加密解密类。
代码中的Config.LOCATION代码如下:
复制代码 代码如下:
public static String getRealPath() throws Exception {
String realPath = Config.class.getClassLoader().getResource("").getFile();
java.io.File file = new java.io.File(realPath);
realPath = file.getAbsolutePath();
realPath = java.net.URLDecoder.decode(realPath, "utf-8");
return realPath;
}
getRealPath()返回的值赋给LOCATION.
上面代码的主要流程:读取data文件,解密,以流的形式返回给mybatis.
通过Mybatis类就可以在程序的任意地方进行调用了。
除了使用XML方式配置Mybatis外,还可以完全使用JAVA代码进行配置,这种方式比较麻烦,需要创建一个DataSource,然后用Mybatis配置类加载所有需要的mapper.class,这里就不详细介绍了(除非有需要)。
您可能感兴趣的文章:
相关文章推荐
- Mybatis 在CS程序中的应用
- Mybatis 在CS程序中的应用
- 浅析java程序中hibernate的应用总结
- bs系统调用cs应用(Js调用exe程序方法)
- 浅析map和multimap应用的小程序
- 浅析java程序中hibernate的应用总结
- 浅析Java web程序之客户端和应用服务器端交互原理
- iPhone应用提交流程:如何将App程序发布到App Store?
- 应用 Valgrind 发现 Linux 程序的内存问题
- 安卓开发中蓝牙应用开发浅析
- 20170716Windows11_4_信号量/互斥体/程序单开应用
- mybatis 的配置与应用
- mybatis和hibernate本质区别和应用场景
- 微信小程序开发记账应用实战服务端之用户注册与登录基于ThinkPHP5描述
- android从应用到驱动之—camera(1)---程序调用流程
- android 在应用中安装其他程序
- C++11新特性应用--让你的程序更高效(右值引用避免深拷贝)
- 解决“只能通过Chrome网上应用商店安装该程序”的方法
- Handler一般处理程序的应用--随机图片生成
- 【专题二】应用号(小程序)开发教程首发第二弹!(0923)