感觉自己看起来都费劲( ⊙ o ⊙ ),
[code="java"]
public String login() {
boolean loginpass = false;
Pckey pckey = null;
int validate = 0; // 密码验证标识
Integer keyright = 1;
HttpServletRequest request = ServletActionContext.getRequest();
String remoteIp = request.getRemoteAddr();
String localIp = request.getLocalAddr();
String passFlag = request.getParameter("validate");
if (StringUtils.isNotEmpty(passFlag)) {
validate = Integer.parseInt(passFlag);
}
if (StringUtils.isNotEmpty(username)) {
keyright = Integer.parseInt(userright);
pckey = pckeyService.findKey(username, keyright);
}
if (pckey != null) {
boolean locked = pckeyService.isLocked(pckey);
if (!locked) { // 没锁定
if (pckeyService.reachMaxCount(pckey)) {
pckeyService.clearErrorCount(pckey);
}
// 验证密码标识
if (validate == 100) {
pckeyService.clearErrorCount(pckey);
HttpSession session = ServletActionContext.getRequest()
.getSession();
session.setAttribute("keyname", username); // 登录名
session.setAttribute("keyright", userright); // 登录权限
Calendar c = Calendar.getInstance();
c.add(Calendar.HOUR_OF_DAY, 10);
session.setAttribute("logintime", c.getTime().toString()); // 登录时间
loginpass = true;
} else {
int errorCount = pckeyService.addErrorCount(pckey);
if (errorCount > 0) {
msg = "用户名或密码错误,剩余" + errorCount + "次key将被锁定";
} else {
msg = "用户名或密码错误,此key已被限制登陆!";
pckeyService.setLockDate(pckey);
}
}
} else {
// 锁定
msg = "此key已经被锁定,您无法登陆系统";
}
} else {
// key 不合法
msg = "请插入合法key";
}
// 添加审计日志
auditlogService.addAuditlog(remoteIp, username, localIp, 1, 1,
loginpass == true ? "登录系统成功!" : "登陆系统失败", 1);
return loginpass == true ? SUCCESS : "error";
}
[/code]
[code="java"]
private List queryFromlist(List list) {
List sublist = new ArrayList();
if (list == null || list.size() == 0) {
return null;
}
for (AuditlogVO vo : list) {
if (StringUtils.isNotEmpty(startTime)) {
long starttime = DateUtils.date2LongNumber(startTime);
long createdate = DateUtils.date2LongNumber(vo.getCreatedate());
if (starttime > createdate)
continue;
}
if (StringUtils.isNotEmpty(endTime)) {
long endtime = DateUtils.date2LongNumber(endTime);
long createdate = DateUtils.date2LongNumber(vo.getCreatedate());
if (createdate > endtime)
continue;
}
if (StringUtils.isEmpty(logType) || logType.equals("全部")
|| logType.equals(vo.getTypename())) {
if (StringUtils.isEmpty(logaction) || logaction.equals("全部")
|| logaction.equals(vo.getActionname())) {
if (StringUtils.isEmpty(logLevel) || logLevel.equals("全部")
|| logLevel.equals(vo.getLevelname())) {
if (StringUtils.isEmpty(logResult)
|| logResult.equals("全部")
|| logResult.equals(vo.getResult())) {
if (StringUtils.isEmpty(subname)
|| subname.equals(vo.getSubname())) {
if (StringUtils.isEmpty(from)
|| from.equals(vo.getAddress())) {
if (StringUtils.isEmpty(targetIp)
|| targetIp.equals(vo.getObjname())) {
sublist.add(vo);
}
}
}
}
}
}
}
}
return sublist;
}
[/code]
第一个就不说了,如果不拆分的话,也是可以接受的。至于第二个,也就是private List queryFromlist(List list)方法中的for循环体,我倒是觉得有必要处理一下。
比如,for中的第一第二个if语句可以提取为一个返回值为boolean的方法。这要for循环中就好看一点,然后第三个if语句不用提取函数,直接定义一个boolean变量,如下格式:
boolean b = (StringUtils.isEmpty(logType) || logType.equals("全部") || logType.equals(vo.getTypename())) ;
b &= (StringUtils.isEmpty(logaction) || logaction.equals("全部") || logaction.equals(vo.getActionname()));
b &= (StringUtils.isEmpty(logLevel) || logLevel.equals("全部") || logLevel.equals(vo.getLevelname())) ;
....
尽量把代买拆开,方法里内容太多,比如
boolean locked = pckeyService.isLocked(pckey);
这个时候可以拆开两个方法,就是当锁定的时候调用一个方法,当没有锁定的情况下调用另外一个方法,这样就是简单清晰点
do{
if(1xx){
break;
}
if(2xx){
break;
}
if(3xx){
break;
}
if(4xx){
break;
}
if(5xx){
break;
}
//code
break;
}while(false);