亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

在java中由類名和方法名字符串實現其調用方式

瀏覽:2日期:2022-08-24 08:54:05

js里通過eval()函數,在知道某個方法名是可以實現調用該方法,那么在java里邊又怎么實現的呢?

java里邊是通過反射機制來實現,代碼如下:

import java.lang.reflect.Method; public class Test { public static void main(String[] args) throws Exception { String className = 'com.runqianapp.ngr.alias.example.FunClass'; String methodName = 'sayHello'; Class clz = Class.forName(className); // Object obj = clz.newInstance(); //獲取方法 Method m = obj.getClass().getDeclaredMethod(methodName, String.class); //調用方法 String result = (String) m.invoke(obj, 'aaaaa'); System.out.println(result); }} class FunClass{ public String sayHello(String s){ System.out.println(s); return 'hello!'; }}

補充知識:一個controller調用根據不同業務分發不同service

在一個項目中需要寫很多的controller去調用不同的service,而寫一個網關可以省去寫controller層的痛苦。

下面開始介紹可以分發不同service。

1.因為service在項目啟動時就已全部注入到spring容器中,所以我們需要寫一個工具類,可以從spring上下文(applicationContext)中獲取到對應service

@Componentpublic class SpringUtil implements ApplicationContextAware { @Autowired private static ApplicationContext applicationContext; @Override public void setApplicationContext(ApplicationContext applicationContext) throws BeansException { if (SpringUtil.applicationContext == null) { SpringUtil.applicationContext = applicationContext; } System.out.println('========ApplicationContext配置成功,在普通類可以通過調用SpringUtil.getAppContext()獲取applicationContext對象,applicationContext=' + SpringUtil.applicationContext + '========'); } //獲取applicationContext public static ApplicationContext getApplicationContext() { return applicationContext; } //通過name獲取 Bean. public static Object getBean(String name) { return getApplicationContext().getBean(name); } //通過class獲取Bean. public static <T> T getBean(Class<T> clazz) { return getApplicationContext().getBean(clazz); } //通過name,以及Clazz返回指定的Bean public static <T> T getBean(String name, Class<T> clazz) { return getApplicationContext().getBean(name, clazz); }}

2.上面的SpringUtil我們已經可以在上下文中直接取到對于的service了,下面就開始編寫controller進行請求的分發(我稱之為網關)。首先我們需要先寫一個抽象類,來定義service,這樣接下來的sevice只需要繼承這個抽象類即可(我們還可以寫一些時間統計,交易流水入庫等。。自我感覺很大的用處)。

public abstract class RootService { private Logger logger = LoggerFactory.getLogger(RootService.class); private long beforeTime; private long endTime; private void before (String action) { beforeTime = System.currentTimeMillis(); logger.info('交易:' + action + '開始時間:' + beforeTime); } private void end (String action) { endTime = System.currentTimeMillis(); long time = endTime - beforeTime; logger.info('交易:' + action + '結束時間:' + endTime); logger.info('交易:' + action + '耗時:' + time); } public JSONObject execute(String actionName,Map map) { before(actionName); JSONObject jsonObject = doNext(map); end(actionName); return jsonObject; } private JSONObject doNext(Map map) { try { return doAction(map); } catch (Exception e) { e.printStackTrace(); JSONObject js = new JSONObject(); js.put('retCode','000000'); js.put('retMsg','程序報錯'); return js; } } protected abstract JSONObject doAction(Map map); }

3.一切準備就緒,我們可以開始編寫contrconoller了(網關)

@Controller@RequestMapping('/root')public class RootController { @ResponseBody @RequestMapping(value = '/h5.do',produces = {'application/json;charset=UTF-8'},method = RequestMethod.POST) public JSONObject root(@RequestBody Map<String,Object> map, HttpServletRequest httpServletRequest){ String service = (String) map.get('service'); JSONObject js = new JSONObject(); RootService rootService = (RootService) SpringUtil.getBean(service); return rootService.execute(service,map); } }

到這里一個網關就寫好了,然后我們寫一個service進行測試一下(對應的Dao層我就不現丑了,相信大家都會)

@Servicepublic class UserServiceImpl extends RootService{ private Logger logger = LoggerFactory.getLogger(UserService.class); @Autowired private UserDao userDao; @Override protected JSONObject doAction(Map map) { JSONObject js = new JSONObject(); String id = (String) map.get('id'); User user = userDao.getUser(id); js.put('user',user); logger.info('進入了UserService'); return js; }}

下面我們用postman測試一下測試報文為:

{ 'id':'1', 'service':'userServiceImpl'}

控制臺打印為:

2019-10-18 17:24:41.089 INFO 6452 --- [nio-8080-exec-2] c.s.s.service.util.RootService : 交易:userService開始時間:15713906810892019-10-18 17:24:41.138 INFO 6452 --- [nio-8080-exec-2] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Starting...2019-10-18 17:24:41.227 INFO 6452 --- [nio-8080-exec-2] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Start completed.2019-10-18 17:24:41.255 INFO 6452 --- [nio-8080-exec-2] c.s.s.service.impl.UserService : 進入了UserService2019-10-18 17:24:41.256 INFO 6452 --- [nio-8080-exec-2] c.s.s.service.util.RootService : 交易:userService結束時間:15713906812562019-10-18 17:24:41.256 INFO 6452 --- [nio-8080-exec-2] c.s.s.service.util.RootService : 交易:userService耗時:167

返回為:

{ 'user': { 'user_id': '1', 'password': '123456', 'user_name': '張三' }}

總結:這樣寫法的好處在于 1.有一個統一的入口,不需要在編寫controller, 可以專注于業務(service)2.可以在公共入口做公共處理。

以上這篇在java中由類名和方法名字符串實現其調用方式就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 一区二区亚洲视频 | 伊人久久在线视频 | 亚洲伦理中文字幕一区 | 国产成人精品第一区二区 | 亚洲在线免费观看 | 美女被免费网站91 | 国产美女挤奶水在线观看 | 九九这里只有精品视频 | 看中国国产一级毛片真人视频 | 日韩激情淫片免费看 | 国产a级淫片 | 午夜成年视频 | 人与牲动交bbbbxxxx | 麻豆精品在线观看 | 在线观看国产日韩 | 狠狠色狠狠色综合婷婷tag | 特级无码a级毛片特黄 | 久久草在线看 | 欧美一级毛片一 | 99亚洲精品高清一二区 | 欧美成人h版影院在线播放 欧美成人h版整片合集 | 免费在线观看成人 | 亚洲精品欧洲久久婷婷99 | 亚洲视频国产 | 免费中文字幕一级毛片 | 国产激情视频在线观看首页 | 亚洲欧洲国产日产 | 免费黄色影院 | 91香蕉小视频 | 国内精品久久久久久久aa护士 | 一级毛片特黄久久免费看 | 国产爽妇网 | 久久青草免费线观最新 | 亚洲国产精品久久久久秋霞66 | 亚洲精品久久玖玖玖玖 | 免费在线观看黄色小视频 | 免费一级特黄3大片视频 | 妞干网在线观看 | 亚洲+国产+图片 | 五月久久亚洲七七综合中文网 | 亚洲色图在线观看 |