package com.bjpowernode.drp.web.actions;
import java.util.Arrays;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import com.bjpowernode.drp.web.forms.LoginActionForm;
/**
* 登录Action
* 负责取得表单数据、调用业务逻辑、返回转向信息
*
* @author Administrator
*
*/
public class LoginAction extends Action {
@Override
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
//取得表单数据
LoginActionForm laf=(LoginActionForm)form;
//取得用户名,密码
String username=laf.getUsername();
String password=laf.getPassword();
//转向对象
ActionForward actionForward=null;
//判断用户名,密码是否正确
if ("admin".equals(username) && "admin".equals(password)) {
//得到远程客户端IP地址
String remoteAddr=request.getRemoteAddr();
//将客户端IP地址以“.”分割为数组remoteAddrs[1]);
String[] remoteAddrs=remoteAddr.split("\\.");
//从配置文件中取得IP范围 ,四个数组分别保存的IP地址四部分的上界和下界
String[] ipOne=request.getSession().getServletContext().getInitParameter("ip-one").split(",");
String[] ipTwo=request.getSession().getServletContext().getInitParameter("ip-two").split(",");
String[] ipThree=request.getSession().getServletContext().getInitParameter("ip-three").split(",");
String[] ipFour=request.getSession().getServletContext().getInitParameter("ip-four").split(",");
//取得第四部分的上下界
int m=Integer.parseInt(ipFour[0]);
int n=Integer.parseInt(ipFour[1]);
//判断客户端IP地址是否在设置范围内
if (ipOne[0].equals(remoteAddrs[0]) && ipTwo[0].equals(remoteAddrs[1]) && ipThree[0].equals(remoteAddrs[2])) {
for(int i=m;i<=n;i++) {
if (Integer.parseInt(remoteAddrs[3])==i) {
//登录成功
request.getSession().setAttribute("user", username);
actionForward= mapping.findForward("success");
}
}
actionForward= mapping.findForward("ipError");
}
}else {
//登录失败
actionForward= mapping.findForward("index");
}
return actionForward;
}
}