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;
}
}
}
网易云信
2023-12-06 广告
2023-12-06 广告
信令SDK是一种软件开发工具包,旨在帮助开发者在应用程序中实现信令协议的通信功能。它主要提供了一系列函数、协议和工具,用于处理信令消息的生成、解析、传输和存储等操作。通过使用信令SDK,开发者可以更快速、便捷地实现信令通信功能,提高应用程序...
点击进入详情页
本回答由网易云信提供
展开全部
异常信息呢?光代码看不出来
更多追问追答
追问
if("admin".equals(username))这样写不会出异常,但是。。。
username=null 我读取username为空
if(username.equals("admin"))这样写会出异常,这是当然的
我就想问username为什么为空
追答
username 在哪里赋的值?
debug调试一下,那个步骤有没有传值进去。
request 里面有没有把这个变量传过来,字段有没有写错,一个一个排查吧
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询