现在的位置: 首页 > 综合 > 正文

java根据properties配置文件来实现功能模块的动态切换

2019年06月12日 ⁄ 综合 ⁄ 共 2962字 ⁄ 字号 评论关闭
 

无论我们是使用hibernate还是使用spring,struts,jsf等等的开源框架,都有一个共同点,那就是程序框架会根据配置文件的不同配置来动态的改变功能的实现,不过,这里的配置文件多是使用xml,xml是一种很很灵活的文档类型,他能够清晰的体现出数据之间的包含从属关系,但是在数据具有key-value映射关系而且相对来说结构简单的情况下,我们可以考虑更加简单的properties文件格式,java对properties提供了更加简单的内置支持;

 

下面是一个登陆模块,用户登陆的时候会有两种验证方式,一种是db验证,一种是file验证,信息存在于不同的存储介质里面,

下面是代码实现

  1. package org.osgi.util;
  2. import java.io.FileInputStream;
  3. import java.io.FileNotFoundException;
  4. import java.io.IOException;
  5. import java.io.InputStream;
  6. import java.util.Properties;
  7. public class LoginUtil {
  8.     public static final String DEFAULTMETHID="DEFAULT";
  9.     
  10.     private static String getLoginClsName(String filePath,String key) {
  11.         return LoginUtil.getProerties(filePath).getProperty(key);
  12.     }
  13.     
  14.     /**
  15.      * @return the class name of login 
  16.      */
  17.     private static Properties getProerties(String filePath){
  18.         Properties properties=new Properties();
  19.         try {
  20.             InputStream in=new FileInputStream(filePath);
  21.             properties.load(in);
  22.         } catch (FileNotFoundException e) {
  23.             System.out.println("the file can't be found");
  24.             e.printStackTrace();
  25.         } catch (IOException e){
  26.             System.out.println("the file can't be load");
  27.             e.printStackTrace();
  28.         }
  29.             return properties;
  30.     }
  31.     
  32.     /**
  33.      * 
  34.      * @param filePath the configuration file path
  35.      * @return
  36.      */
  37.     public static Object getLoginClsInstance(String filePath) {
  38.         Object instance=null;
  39.         try {
  40.             String loginMethodKey=LoginUtil.getLoginClsName(filePath,LoginUtil.DEFAULTMETHID);
  41.             instance=Class.forName(LoginUtil.getLoginClsName(filePath, loginMethodKey)).newInstance();
  42.         } catch (Exception e) {
  43.             System.out.println("can't get the class");
  44.             e.printStackTrace();
  45.         }
  46.         return instance;
  47.     }
  48. }

改工具类实现了如何从配置文件中查找出当前所配置的验证方式;

  1. package org.osgi.login;
  2. public interface ILogin {
  3.     
  4.     /**
  5.      *  which type login method it is 
  6.      */
  7.     public void printf();
  8.    
  9.     /**
  10.      * 
  11.      * @param name the user's name
  12.      * @param pwd  the user's password
  13.      * @return is it a user
  14.      */
  15.     public boolean isUser(String name, String pwd);
  16. }

 

 

  1. package org.osgi.login;
  2. public class DBLogin implements ILogin {
  3.     public boolean isUser(String name, String pwd) {
  4.         return false;
  5.     }
  6.     public void printf() {
  7.         System.out.println("DBLogin");
  8.     }
  9. }

  1. package org.osgi.login;
  2. public class FileLogin implements ILogin {
  3.     public boolean isUser(String name, String pwd) {
  4.         return false;
  5.     }
  6.     public void printf() {
  7.      System.out.println("fileLogin");
  8.     }
  9. }

 

以上是两种登陆模式,方便于相互之间的转换;

 

 

  1. package org.osgi.TestDemo;
  2. import org.osgi.login.ILogin;
  3. import org.osgi.util.LoginUtil;
  4. public class AppDemo {
  5.     /**
  6.      * @param args
  7.      */
  8.     public static void main(String[] args) {
  9.         ILogin loginoer=(ILogin)LoginUtil.getLoginClsInstance("bin/LoginCfg.properties");
  10.         loginoer.printf();
  11.     }
  12. }

配置文件如下:

db=org.osgi.login.DBLogin
file=org.osgi.login.FileLogin
DEFAULT=file

抱歉!评论已关闭.