Struts2拦截器的权限验证问题,我的代码为啥总空指针异常 100
拦截器的intercept方法publicStringintercept(ActionInvocationinvocation)throwsException{Mapse...
拦截器的intercept方法
public String intercept(ActionInvocation invocation) throws Exception {
Map session=invocation.getInvocationContext().getSession();
System.out.println("这是拦截器"+session.get("loginSign"));
if(session.get("loginSign")==null){
System.out.println("session为空");
return "login";
}else{
System.out.println("执行else");
String result = invocation.invoke();
System.out.println("result="+result);
return result;
}}
action的execute方法,有session和username以及get、set
public String execute() throws Exception {
if("admin".equals(username)){
session = ActionContext.getContext().getSession();
session.put("loginSign", "loginSuccess");
return SUCCESS;
}else{
return LOGIN;
} 展开
public String intercept(ActionInvocation invocation) throws Exception {
Map session=invocation.getInvocationContext().getSession();
System.out.println("这是拦截器"+session.get("loginSign"));
if(session.get("loginSign")==null){
System.out.println("session为空");
return "login";
}else{
System.out.println("执行else");
String result = invocation.invoke();
System.out.println("result="+result);
return result;
}}
action的execute方法,有session和username以及get、set
public String execute() throws Exception {
if("admin".equals(username)){
session = ActionContext.getContext().getSession();
session.put("loginSign", "loginSuccess");
return SUCCESS;
}else{
return LOGIN;
} 展开
2个回答
展开全部
首先,struts2进行权限验证是用拦截器做的
一个简单的登录拦截器示例如下:
package com.zdf.interceptor;
import com.opensymphony.xwork2.Action;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
import com.zdf.entity.Admin;
@SuppressWarnings("serial")
public class LoginInterceptor extends AbstractInterceptor{
@Override
public String intercept(ActionInvocation invocation) throws Exception {
// TODO Auto-generated method stub
Admin admin = (Admin)invocation.getInvocationContext().getSession().get("ADMIN");
if(admin!=null){
return invocation.invoke();
}else{
return Action.LOGIN;
}
}
}
一个简单的登录拦截器示例如下:
package com.zdf.interceptor;
import com.opensymphony.xwork2.Action;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
import com.zdf.entity.Admin;
@SuppressWarnings("serial")
public class LoginInterceptor extends AbstractInterceptor{
@Override
public String intercept(ActionInvocation invocation) throws Exception {
// TODO Auto-generated method stub
Admin admin = (Admin)invocation.getInvocationContext().getSession().get("ADMIN");
if(admin!=null){
return invocation.invoke();
}else{
return Action.LOGIN;
}
}
}
Storm代理
2023-08-29 广告
2023-08-29 广告
"StormProxies是全球大数据IP资源服务商,其住宅代理网络由真实的家庭住宅IP组成,可为企业或个人提供满足各种场景的代理产品。点击免费测试(注册即送1G流量)StormProxies有哪些优势?1、IP+端口提取形式,不限带宽,I...
点击进入详情页
本回答由Storm代理提供
展开全部
异常信息呢?光代码看不出来
更多追问追答
追问
if("admin".equals(username))这样写不会出异常,但是。。。
username=null 我读取username为空
if(username.equals("admin"))这样写会出异常,这是当然的
我就想问username为什么为空
追答
username 在哪里赋的值?
debug调试一下,那个步骤有没有传值进去。
request 里面有没有把这个变量传过来,字段有没有写错,一个一个排查吧
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询