jsp获取action传来的session值问题,有以下几种方法:
比如action中有个session ("sessionid","11111111");
一、用struts标签获取:<s:property value="#sessionsessionid"/>;
二、<%=requestgetSessiongetAttribute("sessionid");> session也是内置对象之一,可以直接用session,比requestgetSession方便多了,也可以写成<%=sessiongetAttribute("sessionid");>;
三、el表达式获取:${sessionScopesessionid};
如果赋值的是个bean,也是一样的,类似于${sessionScopebeanbeansth}。
代码如下:
>
这个功能老版本servlet规范中有,新版本中好像被屏蔽了。可以换一种做法,写一个session监听。创建时将session id与session对象构造一个hashMap放到 application中去,销毁时从application中移除。然后你就可以获取了。
你要先在登录的时候,就把用户信息放到session中去
requestgetSessionsetAttribute("current_user",user)
取:
User user = (User)requestgetSessiongetAttribute("current_user")
你是指你的 web 项目中使用到一个工具性的类,它的形参中没有 >
如果是这样的话,我们需要使用一个 ThreadLocal 变量,我们把当前 request 的变量绑定到里面,在一个 request 请求的生命周期内我们在方法调用的各个更深的层次中都可以直接使用它而不需要在每个方法中都传递这个 request 参数,保存在某个地方就容易导致因为多个请求共用同一个实例而出问题,所有 context 相关的变量不保存在任何业务类相关并且可能被多线程共用的对象实例中才是保证不会出现线程安全问题的途径。
例如,这个例子中我们只要把 webxml 中配置好 ContextFilter 后它就会自动在请求开始时绑定一个 context,结束后自动销毁,在这中间的任何时刻我们都可以通过 MyWebContextgetCurrentContext() 得到我们的 >// MyWebContext 记录当前 Request 的所有 context 变量。因为 servlet 是一个请求绑定一个线程的,我们用 ThreadLocal 不会有线程安全问题。
class MyWebContext {
private static final ThreadLocal contexts = new ThreadLocal();
// 拿出当前线程绑定的 context
public static MyWebContext getCurrentContext() {
return (MyWebContext) contextsget();
}
public static MyWebContext createContext() {
return new MyWebContext();
}
// 绑定一个 context 到当前线程
public static void setContext(MyWebContext context) {
contextsset(context);
}
public static void clearContext() {
contextsset(null);
}
private >
以上就是关于怎么在jsp界面 获取session的值全部的内容,包括:怎么在jsp界面 获取session的值、如何javaEE通过sessionId获取HttpSession对象、java如何通过sessionid获取session对象等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)