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;
} 展开
展开全部
首先,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;
}
}
}
微测检测5.10
2023-05-10 广告
2023-05-10 广告
您好!建议咨 深圳市微测检测有限公司,已建立起十余个专业实验室,企业通过微测检测就可以获得一站式的测试与认 证解决方案;(EMC、RF、MFi、BQB、QI、USB、安全、锂电池、快充、汽车电子EMC、汽车手机互 联、语音通话质量),认证遇...
点击进入详情页
本回答由微测检测5.10提供
展开全部
异常信息呢?光代码看不出来
更多追问追答
追问
if("admin".equals(username))这样写不会出异常,但是。。。
username=null 我读取username为空
if(username.equals("admin"))这样写会出异常,这是当然的
我就想问username为什么为空
追答
username 在哪里赋的值?
debug调试一下,那个步骤有没有传值进去。
request 里面有没有把这个变量传过来,字段有没有写错,一个一个排查吧
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询