<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • JAVA認證基礎知識:基于反射機制的服務代理調用

    時間:2024-09-20 00:55:41 JAVA認證 我要投稿

    JAVA認證基礎知識:基于反射機制的服務代理調用

      實現原理:通過傳遞服務bean的名稱、執行的方法及參數,通過反射機制進行調用返回。

    JAVA認證基礎知識:基于反射機制的服務代理調用

      優點:只需對外提供一個接口服務即可,只要容器中操作服務bean,通過接口即可調用,增加服務bean無需增加對外接口。

      代碼如下:

      接口類

      public interface ProxyService {

      /**

      * webservice調用代理

      * @param beanName bean或類名

      * @param functionName 調用的函數名

      * @param params 參數

      * @return

      * @throws Exception

      */

      Object proxy(String beanName, String functionName,String… params) throws Exception;

      }

      實現類:

      服務基于spring,為了方便獲取服務bean,實現類實現spring的ApplicationContextAware接口

      @Service

      public class ProxyServiceImpl implements ProxyService ,ApplicationContextAware{

      protected final Logger logger = LoggerFactory.getLogger(getClass());

      @Resource

      private ApplicationContext applicationContext;

      @Override

      public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {

      this.applicationContext = applicationContext;

      }

      /**

      * 通過代理執行業務方法,方法數據

      */

      @SuppressWarnings("rawtypes")

      @Override

      public Object proxy(String beanName, String functionName, String… params) throws ServiceException {

      //參數判斷

      if(StringUtils.isEmpty(beanName)){

      throw new Exception("error: beanName is empty.");

      }

      if(StringUtils.isEmpty(functionName)){

      throw new Exception("error: functionName is empty.");

      }

      //獲取服務bean

      Object bean = getBean(beanName);

      if(bean == null){

      throw new Exception("error: bean is not exist.");

      }

      if(params == null || params.length ==0){

      logger.warn("proxy params is empty.");

      }

      Method method = null;

      //處理無參數調用

      if(params == null || params.length ==0){

      try {

      //獲取服務bean方法

      method = bean.getClass()。getMethod(functionName);

      } catch (SecurityException e) {

      logger.error("proxy getMethod SecurityException:"+e.getMessage());

      e.printStackTrace();

      } catch (Exception e) {

      logger.error("proxy invoke IllegalArgumentException:"+e.getMessage());

      e.printStackTrace();

      throw new Exception("error: get method Exception:"+e.getMessage());

      }

      }else{

      //處理有參數調用

      //處理調用方法參數

      Class[] paraTypes = new Class[params.length];

      for (int i = 0; i < paraTypes.length; i++) {

      paraTypes[i] = String.class;

      }

      //獲取服務bean方法

      method = bean.getClass()。getMethod(functionName, paraTypes);

      }catch (Exception e) {

      logger.error("proxy invoke IllegalArgumentException:"+e.getMessage());

      e.printStackTrace();

      throw new Exception("error: get method Exception:"+e.getMessage());

      }

      }

      if(method == null ){

      throw new Exception("error: function is not exist.");

      }

      Object rs = null;

      try {

      //調用返回數據

      rs = method.invoke(bean,params);

      } catch (Exception e) {

      logger.error("proxy invoke IllegalArgumentException:"+e.getMessage());

      e.printStackTrace();

      throw new Exception("error: invoke method Exception:"+e.getMessage());

      }

      return rs;

      }

      /**

      * 獲取bean對象

      * @param beanName

      * @return

      */

      private Object getBean(String beanName){

      Object bean = null;

      bean = applicationContext.getBean(beanName);

      if(bean == null){

      try {

      Class classe = Class.forName(beanName);

      bean = classe.newInstance();

      } catch (InstantiationException e) {

      logger.error("getBean InstantiationException:"+e.getMessage());

      e.printStackTrace();

      } catch (IllegalAccessException e) {

      logger.error("getBean IllegalAccessException:"+e.getMessage());

      e.printStackTrace();

      }catch ( ClassNotFoundException e) {

      logger.error("getBean ClassNotFoundException:"+e.getMessage());

      e.printStackTrace();

      }

      }

      logger.debug("getBean(),beanName:"+beanName);

      return bean;

      }

      }

      調用方式如下:

      proxyService.proxy("testservice","say","helloword");

      testservice 為spring中bean實例

      say 為testservice的業務方法

      helloword 為參數

      以上方式可以使用與遠程調用(如webservice等),對外為的代理調用接口。只需實現一個對外接口,調用服務內部多個業務服務。

    【JAVA認證基礎知識:基于反射機制的服務代理調用】相關文章:

    2016年JAVA認證基礎知識:基于反射機制的服務代理調用03-03

    JAVA認證基礎知識:Java獲取當前的系統時間03-18

    JAVA認證基礎知識:JavaNativeInterface學習小結01-11

    java調用cmd命令01-29

    Java認證基礎知識:java字符串轉化整型問題03-18

    JAVA認證簡介03-19

    關于Java的內省與反射03-17

    JAVA認證基礎知識:JSP使用數據庫操作03-18

    SUN JAVA認證介紹12-18

    主站蜘蛛池模板: 无码精品日韩中文字幕| 国产精品白丝AV嫩草影院| 日韩精品专区AV无码| 91自慰精品亚洲| 国产精品无码一区二区三区电影| 精品成人av一区二区三区| 99精品免费视品| 日韩精品专区在线影院重磅| 久久精品中文字幕第23页| 久久r热这里有精品视频| 久久精品国产亚洲av高清漫画| 亚州日韩精品专区久久久| 国产精品乱视频| 中文精品久久久久国产网址| CAOPORM国产精品视频免费| 色一乱一伦一图一区二区精品 | 精品无码国产一区二区三区AV| 日韩AV毛片精品久久久| 国产一区二区精品久久岳| 亚洲色图国产精品| 久久精品国产亚洲一区二区| 2021精品国产综合久久| 国产精品三级在线观看无码| 午夜精品久久久久久久久| 亚洲av午夜成人片精品网站 | 久久久久久国产精品无码下载| Xx性欧美肥妇精品久久久久久| 欧美精品国产一区二区| 国产一区二区三区久久精品| 国产精品美女久久久久久2018 | 国产综合精品久久亚洲| 国产精品单位女同事在线| 91精品国产91久久| 亚洲欧美日韩精品久久| 中文字幕精品一区二区日本| 欧美精品人爱c欧美精品| 日韩精品在线视频| 伊人久久大香线蕉精品| 国产精品免费久久久久久久久| 国产精品视频一区二区三区不卡| 国产精品伦理久久久久久|