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方式一般用于用户注销登录时返回主页面和跳转到其他的网站等,怪不得值机里面用的多的是这个了。