麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Java > 正文

淺析Mybatis 在CS程序中的應用

2019-11-26 16:01:48
字體:
來源:轉載
供稿:網友

因為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,這里就不詳細介紹了(除非有需要)。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 亚州综合| 欧美综合在线观看 | 久久色伦理资源站 | 亚洲精品成人久久久 | 香蕉久草视频 | 国产亚洲精彩视频 | 精品亚洲二区 | 成人午夜视频在线观看免费 | 久久千人斩 | 欧美一区二区三区免费观看 | 黄色免费大片 | 国产精品久久久久久久久粉嫩 | 亚欧在线免费观看 | 欧美囗交 | 欧美一区二区网站 | 成年人性视频 | 男女污视频在线观看 | 亚洲午夜一区二区三区 | 国产成人自拍视频在线观看 | 国产精品成人久久久久a级 欧美特黄一级高清免费的香蕉 | 国产无遮挡一级毛片 | 免费观看9x视频网站在线观看 | 在火车上摸两乳爽的大叫 | 在线亚州 | 亚洲精品成人久久久 | 亚洲免费资源 | 黄色成年在线观看 | 久草久视频 | 久久国产精品99国产 | 久久美女免费视频 | 在线成人亚洲 | 国产1区2区3区在线观看 | 日韩毛片在线看 | 成人免费福利 | 亚洲福利在线视频 | 亚洲午夜在线观看 | 国产精品久久久久久久久久久久午夜 | 精品久久久久久综合日本 | 欧美成人se01短视频在线看 | 久久综合婷婷 | 91色琪琪电影亚洲精品久久 |