Chapter 2、不使用代理

为了满足两个需求

1、打印每个请求从开始到结束的耗时

2、校验某些请求的当前用户是否登录

 

可以在 Service 的实现类 ServiceImpl 中改造,增加耗时打印和校验登录代码。

//耗时统计
long start = System.currentTimeMillis();//计时开始
...
long end = System.currentTimeMillis();//计时结束
System.out.println("耗时:" + (end - start) + "毫秒");//打印耗时
		
/**
 * 模拟  当前用户是否登录
 */
private boolean checkIsLogined() {
	Random r = new Random();
	int i = r.nextInt(10);
	if (i % 2 == 0) {
		System.out.println("已登录");
		return true;
	}
	System.out.println("未登录");
	return false;
}

 

完整代码:

package constxiong.cxproxy.chapter2.service;

import java.util.HashMap;
import java.util.Map;
import java.util.Random;

/**
 * 服务接口实现
 * @author ConstXiong
 * @date 2019-05-29 11:02:15
 */
public class ServiceImpl implements Service {

	@Override
	public boolean login(String username, String password) {
		long start = System.currentTimeMillis();//计时开始
		
		simulateDaOperation(100);
		System.out.println("用户名:" + username + ", 密码:" + password + "  登录成功");
		
		long end = System.currentTimeMillis();//计时结束
		System.out.println("耗时:" + (end - start) + "毫秒");//打印耗时
		
		return true;
	}

	@Override
	public Map getUserInfo(String username) {
		long start = System.currentTimeMillis();//计时开始
		
		Map userInfo = null;
		
		//校验是否登录
		if (checkIsLogined()) {
			userInfo = new HashMap();
			simulateDaOperation(150);
			userInfo.put("username", username);
			userInfo.put("sex", "男");
			userInfo.put("age", 18);
			System.out.println("用户名:" + username + ", 获取用户信息:" + userInfo);
		}
		
		long end = System.currentTimeMillis();//计时结束
		System.out.println("耗时:" + (end - start) + "毫秒");//打印耗时
		
		return userInfo;
	}
	
	
	
	/**
	 * 模拟  当前用户是否登录
	 */
	private boolean checkIsLogined() {
		Random r = new Random();
		int i = r.nextInt(10);
		if (i % 2 == 0) {
			System.out.println("已登录");
			return true;
		}
		System.out.println("未登录");
		return false;
	}

	/**
	 * 模拟数据库操作,休眠
	 * @param millis 毫秒数
	 */
	private void simulateDaOperation(long millis) {
		try {
			Thread.sleep(millis);
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
	}

}

未登录打印:

用户名:ConstXiong, 密码:123456  登录成功
耗时:100毫秒
未登录
耗时:1毫秒

已登录打印:

用户名:ConstXiong, 密码:123456  登录成功
耗时:100毫秒
已登录
用户名:ConstXiong, 获取用户信息:{sex=男, age=18, username=ConstXiong}
耗时:152毫秒

 

完整源码:https://github.com/ConstXiong/xtools    cxproxy项目 chapter2

 

思考:

这种做法的缺点很明显:每次需求变更,核心的业务代码就需要改动,这块就得重测。
有没有做法可以不用修改核心业务代码,也能完成两个功能?有,使用代理。

 


【Java面试题与答案】整理推荐

  • 基础与语法
  • 集合
  • 网络编程
  • 并发编程
  • Web
  • 安全
  • 设计模式
  • 框架
  • 算法与数据结构
  • 异常
  • 文件解析与生成
  • Linux
  • MySQL
  • Oracle
  • Redis
  • Dubbo

 

你可能感兴趣的:(Chapter,2,不使用代理)