JSP学习12.27——重定向与内部转发,四大作用域,cookie

Servlet API中forward()与redirect()的区别

a、从地址栏显示来说

forward是服务器请求资源,服务器直接访问目标地址的URL,把那个URL的响应内容读取过来,然后把这些内容再发给浏览器.浏览器根本不知道服务器发送的内容从哪里来的,所以它的地址栏还是原来的地址.

redirect是服务端根据逻辑,发送一个状态码,告诉浏览器重新去请求那个地址.所以地址栏显示的是新的URL.所以redirect等于客户端向服务器端发出两次request,同时也接受两response。

b、从数据共享来说

forward:转发页面和转发到的页面可以共享request里面的数据.redirect:不能共享数据.redirect不仅可以重定向到当前应用程序        的其他资源,还可以重定向到同一个站点上的其他应用程序中的资源,甚至是使用绝对URL重定向到其他站点的资源.forward方法      只能在同一个Web应用程序内的资源之间转发请求.forward 是服务器内部的一种操作.redirect 是服务器通知客户端,让客户端重新发起请求.所以,你可以说 redirect 是一种间接的请求, 但是你不能说"一个请求是属于forward还是redirect "。

c、从运用地方来说

forward:一般用于用户登录,根据角色转发到相应的模块

redirect:一般用于用户注销登录时,返回主页面和跳转其他网址

d、从效率来说

forward:高

redirect:低

JSP 的 4 种作用域

page:代表与一个页面相关的对象和属性。

request:代表与客户端发出的一个请求相关的对象和属性。一个请求可能跨越多个页面,涉及多个 Web 组件;需要在页面显示的临时数据可以置于此作用域。

 session:代表与某个用户与服务器建立的一次会话相关的对象和属性。跟某个用户相关的数据应   该放在用户自己的     session 中。

 application:代表与整个 Web 应用程序相关的对象和属性,它实质上是跨越整个 Web 应用程  序,包括多个页面、请求和会话的一个全局作用域。

session 和 cookie 有什么区别

a、存储位置不同:session 存储在服务器端;cookie 存储在浏览器端。

b、安全性不同:cookie 安全性一般,在浏览器存储,可以被伪造和修改。

c、容量和个数限制:cookie 有容量限制,每个站点下的 cookie 也有个数限制。

d、存储的多样性:session 可以存储在 Redis 中、数据库中、应用程序中;而 cookie 只能存储在浏览器中。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值