Session—HTTPSession 服务器创建的,Javaweb提供的 与HTTP协议无关是服务器端对象,保存在服务器端。用来会话跟踪。

Cookie与服务器创建,与HTTP协议相关,保存在客户端上面。

SerVlet三大域对象

Request 多个 一次一个

Session 一个用户打开浏览器开始到关闭。一个用户一个Session

底层依赖于cookie 或是url重写。

服务器一方可以存放多个Session 放在一个map中

Servlet中得到Session对象 HTTPSession Session=request.getSession();

Jsp中得到Session对象:Session是jsp的内置对象,不用创建即可使用

Cookie底层不能跨浏览器。

<body>

保存Session. <br>

<%

session.setAttribute("aaa", "AAA");

%>

</body>

<body>

获取Session. <br>

<% String s=(String)session.getAttribute("aaa"); %>

<%=s %>

</body>

第二个例子

action="<%=path%>/LoginServlet"

重定向时我们的servlet的路径不显示在地址栏中。

重定向是使用 response.sendRedirect("必须得些项目名");

可以是本项目以外的路径。两次请求,不存在request域

转发时会看到servlet的路径,不用加项目名,必须是本项目内的路径

request.setAttribute("message", "用户名或密码错误");

request.getRequestDispatcher("anli/error.jsp").forward(request, response);

存在request域。一次请求

保存cookie用response

拿到cookie使用request 注意判断是否为空

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

request.setCharacterEncoding("utf-8");

String username=request.getParameter("username");

String password=request.getParameter("password");

if (username.equals("124")&&password.equals("zhangsan")) {

Cookie cookie=new Cookie("uname", username);

cookie.setMaxAge(60*60);

response.addCookie(cookie);

HttpSession session=request.getSession();

session.setAttribute("username", "124");

session.setAttribute("password", "zhangsan");

request.getRequestDispatcher("anli/success1.jsp").forward(request, response);

}else {

request.setAttribute("message", "用户名或密码错误");

request.getRequestDispatcher("anli/login.jsp").forward(request, response);

}

}

<body>

This is my JSP page. <br>

<h1>登陆页面</h1>

<%

String uname="";

Cookie[]cookies=request.getCookies();

if(cookies!=null){

for(Cookie c:cookies){

if("uname".equals(c.getName())){

uname=c.getValue();

}

}

}

%>

<%

String message="";

String mes=(String)request.getAttribute("message");

if(mes!=null){

message=mes;

}

%>

<font color="red"><b><%=message %></b></font>

<form action="<%=path%>/LoginServlet" method="pot">

<!-- 获取cookie中的uname的值放到用户名文本框中 -->

用户名:<input type="text" name="username" value="<%= uname%>"><br>

密码:<input type="password" name="password"><br>

<input type="submit" value="提交">

</form>

</body>

Session的原理

Jssessionid

Jsp自动创建Session,servlet不自动创建

其他方法:getId()

Invalidate()

isNew()

重温httpsession①的更多相关文章

  1. 重温Java Web的技术细节

    目录 一.背景 二.请求与响应 2.1.Http请求 2.2.Http响应 三.ServletConfig 3.1 测试ServletConfig参数 四.ServletContext 4.1 测试S ...

  2. java使用websocket,并且获取HttpSession,源码分析

    转载请在页首注明作者与出处 http://www.cnblogs.com/zhuxiaojie/p/6238826.html 一:本文使用范围 此文不仅仅局限于spring boot,普通的sprin ...

  3. HttpSession与Hibernate中Session的区别

    一.javax.servlet.http.HttpSession是一个抽象接口 它的产生:J2EE的Web程序在运行的时候,会给每一个新的访问者建立一个HttpSession,这个Session是用户 ...

  4. 被我们忽略的HttpSession线程安全问题

    1. 背景 最近在读<Java concurrency in practice>(Java并发实战),其中1.4节提到了Java web的线程安全问题时有如下一段话: Servlets a ...

  5. 重温Servlet学习笔记--session对象

    session的类型是属于HttpSession,HttpSession是由javaWeb提供的,用来会话跟踪的类.session是服务器端对象,保存在服务器端. HttpSession是servle ...

  6. 重温JSP学习笔记--三大指令九大内置对象

    最近在温习javaweb的相关基础知识,鉴于我弄丢了记满了整整一本的笔记,决定以后把笔记和一些学习上的心得以及碰到的一些问题统统都放在网上,今天看了一下jsp的相关基础,以下是笔记: JSP三大指令: ...

  7. HttpSession

    (Cookie是用来设置浏览器保存数据的时间的: Session是只要浏览器不关闭,数据则会存在,一旦关闭浏览器数据即消失 ) 1. HttpSession概述 * HttpSession是由Java ...

  8. JSP中的 HttpSession、pageContext对象

    pageContext 隐含对象对应javax.servlet.jsp.PageContext,都自动的被加入至pageContext中, 您可以由它来取得与JSP相关的对应之Servlet对象,像是 ...

  9. 解剖SQLSERVER 第十篇 OrcaMDF Studio 发布+ 特性重温(译)

    解剖SQLSERVER 第十篇  OrcaMDF Studio 发布+ 特性重温(译) http://improve.dk/orcamdf-studio-release-feature-recap/ ...

随机推荐

  1. SecureCRT Win免安装版本,简单好用

    SecureCRT是一款支持SSH(SSH1和SSH2)的终端仿真程序,简单地说是Windows下登录UNIX或Linux服务器主机的软件. 这个简单好用,程序员必备. 下载地址:SecureCRT. ...

  2. 7、Django的模型层(1)

    第1节:ORM简介 ORM简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极 ...

  3. node学习笔记_03 express框架

    express api地址:http://www.expressjs.com.cn/starter/static-files.html 一.安装依赖 npm i --save express npm ...

  4. 2298: [HAOI2011]problem a

    Description 一次考试共有n个人参加,第i个人说:"有ai个人分数比我高,bi个人分数比我低."问最少有几个人没有说真话(可能有相同的分数) 这句话的意思就等于是说第i个 ...

  5. pytorch的一些函数

    1.tensor的view函数: view(*args) → Tensor 返回一个有相同数据但大小不同的tensor. 返回的tensor必须有与原tensor相同的数据和相同数目的元素,但可以有不 ...

  6. shiro实战系列(三)之架构

    Apache Shiro 的设计目标是通过直观和易于使用来简化应用程序安全.Shiro 的核心设计体现了大多数人们是如何考虑应用程序安全的——在某些人(或某些事)与应用程序交互的背景下.   应用软件 ...

  7. shiro实战系列(九)之Web

    一.Configuration(配置) 将 Shiro 集成到任何 Web 应用程序的最简单的方法是在 web.xml 中配置 ContextListener 和 Filter,理解如何读取 Shir ...

  8. threedLocal设计原因及详解

    ThreedLocal在中文的翻译中应该翻译成:线程局部变量. 1:设计的原因 在并发编程的时候,成员变量如果不做任何处理其实是线程不安全的,各个线程都在操作同一个变量,显然是不行的,并且我们也知道v ...

  9. MVC bundle的使用总结

    在我们的项目里面充斥着很多静态文件,为了追求模块化.插件化很多静态文件都被设计成模块的方式或者被分解,在需要的时候在通过组合的方式在UI层上使用:这就带来一个问题,文件多了会影响浏览器加载页面的速度, ...

  10. js 获取当前页url网址信息

    转载地址:js如何准确获取当前页面url网址信息 摘录: 举例一个URL,然后获得它的各个组成部分:http://i.cnblogs.com/EditPosts.aspx?opt=1 1.window ...