JavaWeb学习笔记(三)--- post和get的区别、session和cookie的区别、forward和redirect的区别

1.post与get区别
(1)post是向指定的资源提交要被处理的数据,get是从指定的资源请求数据;
(2)查询字符串(名称、值对)的存放位置:
POST方式的查询字符串是放在POST请求的HTTP消息主体中的;
GET方式的查询字符串是放在GET请求的URL里的,数据量有限制,通常不超过1k;
(3)post方式比get方式安全,前者参数不会保存在浏览器历史或web服务器日志中,后者数据是url的一部分。
(4)get是默认方式,改为post通过更改提交表单方式。

2.session与cookie区别
这两者都是为了保持用户跟服务器之间交互的状态。
cookie是为了处理在较短时间内,同一用户频繁访问数据,针对这个数据做缓存,可以提高访问性能。同一客户端与服务端交互时,但是如果每次都传回所有的cookie值,客户端和服务端的数据传输量太大。
开发人员调用request方法的getSession()方法获取session对象,如果服务器没有,就创建一个session对象,并将session的Id以cookie的形式设置在HTTP协议头里,并传给客户端,客户端的浏览器访问服务器时,就会带上这个sessionId,服务器即寻找与之对应的session对象。

总结:
(1) cookie数据存放在客户的浏览器上,session数据放在服务器上;
(2) cookie不是很安全,别人可以分析存放在本地的COOKIE并进行COOKIE欺骗,考虑到安全应当使用session;
(3) session会在一定时间内保存在服务器上。当访问增多,会比较占用服务器的性能
考虑到减轻服务器性能方面,应当使用COOKIE;
(4) 单个cookie在客户端的限制是3K,就是说一个站点在客户端存放的COOKIE不能3K;
(5) 将登陆信息等重要信息存放为SESSION;其他信息如果需要保留,可以放在COOKIE中。

3.forward与redirect的区别

当客户端向服务端请求一个资源,
(1)如果是forward方式,服务器在容器内部寻找资源传给客户端,浏览器地址栏的URL不变,浏览器不知道资源的来源;
(2)如果是redirect方式,服务器回应浏览器一个状态码,告诉浏览器去哪个地方请求资源,浏览器重新对服务器提出请求,获取资源,浏览器地址栏的URL改变了。

用法区别:
forward方式一般用于用户登录;
redirect方式一般用于用户注销登录时返回主页面和跳转到其他的网站等,怪不得值机里面用的多的是这个了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值