zoukankan      html  css  js  c++  java
  • Mybatis 在CS程序中的应用

    因为mybatis好使,所以几乎需要操作数据库的时候,我都会使用mybatis,而且在一个正式的项目中,同时存在BS和CS的程序,都使用的Mybatis,使用的相同mapper文件。


    如果是自己用的Mybatis,不需要考虑对配置文件加密,如果不是,那就需要考虑加密,这篇文章主要讲如何配置CS的Mybatis。


    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,这里就不详细介绍了(除非有需要)。


  • 相关阅读:
    iis6|iis7|配置URLRewriter|64位操作系统下|.net2.0|.net4.0|配置URLRewriter|Web.config配置详情
    如何用Fiddler对Android应用进行抓包
    asp.net写验证码
    Linq to sql 语法方法示例
    asp.net正则表达式学习例子
    js 根据年月获取当月有多少天_js获取农历日期_及Js其它常用有用函数
    Sql Server 相关错误问题及解决方法
    Javascript 添加自定义静态方法属性JS清除左右空格
    asp.net 文件批量移动重命名
    Memcached监听多个端口_同一台Windows机器中启动多个Memcached服务
  • 原文地址:https://www.cnblogs.com/dyllove98/p/3125121.html
Copyright © 2011-2022 走看看