热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Java工程师web开发其他面试题(Day21)

1cookie和session的区别是什么?参考答案存储位置不同:cookie存放于客户端;session存放于服务端。存储容量不同&#x

1 COOKIE和session的区别是什么?
参考答案
存储位置不同:COOKIE存放于客户端;session存放于服务端。
存储容量不同&#xff1a;单个COOKIE保存的数据<&#61;4KB&#xff0c;一个站点最多保存20个COOKIE&#xff1b;而session并没有上限。
存储方式不同&#xff1a;COOKIE只能保存ASCII字符串&#xff0c;并需要通过编码当时存储为Unicode字符或者二进制数据&#xff1b;session中能够存储任何类型的数据&#xff0c;例如字符串、整数、集合等。
隐私策略不同&#xff1a;COOKIE对客户端是可见的&#xff0c;别有用心的人可以分析存放在本地的COOKIE并进行COOKIE欺骗&#xff0c;所以它是不安全的&#xff1b;session存储在服务器上&#xff0c;对客户端是透明的&#xff0c;不存在敏感信息泄露的风险。
生命周期不同&#xff1a;可以通过设置COOKIE的属性&#xff0c;达到COOKIE长期有效的效果&#xff1b;session依赖于名为JSESSIONID的COOKIE&#xff0c;而该COOKIE的默认过期时间为-1&#xff0c;只需关闭窗口该session就会失效&#xff0c;因此session不能长期有效。
服务器压力不同&#xff1a;COOKIE保存在客户端&#xff0c;不占用服务器资源&#xff1b;session保管在服务器上&#xff0c;每个用户都会产生一个session&#xff0c;如果并发量大的话&#xff0c;则会消耗大量的服务器内存。
浏览器支持不同&#xff1a;COOKIE是需要浏览器支持的&#xff0c;如果客户端禁用了COOKIE&#xff0c;则会话跟踪就会失效&#xff1b;运用session就需要使用URL重写的方式&#xff0c;所有用到session的URL都要进行重写&#xff0c;否则session会话跟踪也会失效。
跨域支持不同&#xff1a;COOKIE支持跨域访问&#xff0c;session不支持跨域访问。

2 COOKIE和session各自适合的场景是什么&#xff1f;
参考答案
对于敏感数据&#xff0c;应存放在session里&#xff0c;因为COOKIE不安全。
对于普通数据&#xff0c;优先考虑存放在COOKIE里&#xff0c;这样会减少对服务器资源的占用。

3 请介绍session的工作原理
参考答案
session依赖于COOKIE。
当客户端首次访问服务器时&#xff0c;服务器会为其创建一个session对象&#xff0c;该对象具有一个唯一标识SESSIONID。并且在响应阶段&#xff0c;服务器会创建一个COOKIE&#xff0c;并将SESSIONID存入其中。
客户端通过响应的COOKIE而持有SESSIONID&#xff0c;所以当它再次访问服务器时&#xff0c;会通过COOKIE携带这个SESSIONID。服务器获取到SESSIONID后&#xff0c;就可以找到与之对应的session对象&#xff0c;进而从这个session中获取该客户端的状态。

4 get请求与post请求有什么区别&#xff1f;
参考答案
GET在浏览器回退时是无害的&#xff0c;而POST会再次提交请求。
GET产生的URL地址可以被Bookmark&#xff0c;而POST不可以。
GET请求会被浏览器主动cache&#xff0c;而POST不会&#xff0c;除非手动设置。
GET请求只能进行url编码&#xff0c;而POST支持多种编码方式。
GET请求参数会被完整保留在浏览器历史记录里&#xff0c;而POST中的参数不会被保留。
GET请求在URL中传送的参数是有长度限制的&#xff0c;而POST没有。
对参数的数据类型&#xff0c;GET只接受ASCII字符&#xff0c;而POST没有限制。
GET比POST更不安全&#xff0c;因为参数直接暴露在URL上&#xff0c;所以不能用来传递敏感信息。
GET参数通过URL传递&#xff0c;POST放在Request body中。

5 get请求的参数能放到body里面吗&#xff1f;
参考答案
GET请求是可以将参数放到BODY里面的&#xff0c;官方并没有明确禁止&#xff0c;但给出的建议是这样不符合规范&#xff0c;无法保证所有的实现都支持。这就意味着&#xff0c;如果你试图这样做&#xff0c;可能出现各种未知的问题&#xff0c;所以应该当避免。

6 post不幂等是为什么&#xff1f;
参考答案
HTTP方法的幂等性是指一次和多次请求某一个资源应该具有同样的副作用。幂等性属于语义范畴&#xff0c;正如编译器只能帮助检查语法错误一样&#xff0c;HTTP规范也没有办法通过消息格式等语法手段来定义它。
POST所对应的URI并非创建的资源本身&#xff0c;而是资源的接收者。比如&#xff1a;POST http://www.forum.com/articles的语义是在http://www.forum.com/articles下创建一篇帖子&#xff0c;HTTP响应中应包含帖子的创建状态以及帖子的URI。两次相同的POST请求会在服务器端创建两份资源&#xff0c;它们具有不同的URI。所以&#xff0c;POST方法不具备幂等性。

7 页面报400错误是什么意思&#xff1f;
参考答案
400状态码标识请求的语义有误&#xff0c;当前请求无法被服务器理解。除非进行修改&#xff0c;否则客户端不应该重复提交这个请求。通常情况下&#xff0c;是本次请求中包含有错误的参数&#xff0c;此时应该排查前端传递的参数。

8 请求数据出现乱码该怎么处理&#xff1f;
参考答案
服务端出现请求乱码的原因是&#xff0c;客户端编码与服务器解码方案不一致&#xff0c;可以有如下几种解决办法&#xff1a;
将获得的数据按照客户端编码转成BYTE&#xff0c;再将BYTE按服务端编码转成字符串&#xff0c;这种方案对各种请求方式均有效&#xff0c;但是十分的麻烦。
在接受请求数据之前&#xff0c;显示声明实体内容的编码与服务器一致&#xff0c;这种方式只对POST请求有效。
修改服务器的配置文件&#xff0c;显示声明请求路径的编码与服务器一致&#xff0c;这种方式只对GET请求有效。

9 如何在SpringBoot框架下实现一个定时任务&#xff1f;
参考答案
Spring给我们提供了可执行定时任务的线程池ThreadPoolTaskScheduler&#xff0c;该线程池提供了多个可以与执行定时任务的方法&#xff0c;如下图。在Spring Boot中&#xff0c;只需要在配置类中启用线程池注解&#xff0c;就可以直接使用这个线程池了。
在这里插入图片描述

10 调用接口时要记录日志&#xff0c;该怎么设计&#xff1f;
参考答案
可以定义一个记录日志的组件&#xff0c;并通过AOP将其织入到这个接口的调用中。这种方式对接口无需做任何改造&#xff0c;业务代码中也无需增加任何调用的逻辑&#xff0c;完美地消除了记录日志和业务代码的耦合度。

11 了解Spring Boot JPA吗&#xff1f;
参考答案
JPA即Java Persistence API&#xff0c;它是一个基于O/R映射的标准规范。也就是说它指定以了标准规则&#xff0c;不提供实现&#xff0c;软件提供商可以按照标准规范来实现&#xff0c;而使用者只需按照规范中定义的方式来使用&#xff0c;不用和软件提供商打交道。JPA主要实现有Hibernate、EclipseLink、OpenJPA等&#xff0c;我们使用JPA来开发&#xff0c;无论是采用哪一种实现方式都一样。
欢迎大家加我微信交流讨论&#xff08;请备注csdn上添加&#xff09;
在这里插入图片描述


推荐阅读
  • pypy 真的能让 Python 比 C 还快么?
    作者:肖恩顿来源:游戏不存在最近“pypy为什么能让python比c还快”刷屏了,原文讲的内容偏理论,干货比较少。我们可以再深入一点点,了解pypy的真相。正式开始之前,多唠叨两句 ... [详细]
  • 本文将从基础概念入手,详细探讨SpringMVC框架中DispatcherServlet如何通过HandlerMapping进行请求分发,以及其背后的源码实现细节。 ... [详细]
  • 小程序的授权和登陆
    小程序的授权和登陆 ... [详细]
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • 本文详细介绍了JQuery Mobile框架中特有的事件和方法,帮助开发者更好地理解和应用这些特性,提升移动Web开发的效率。 ... [详细]
  • 我的读书清单(持续更新)201705311.《一千零一夜》2006(四五年级)2.《中华上下五千年》2008(初一)3.《鲁滨孙漂流记》2008(初二)4.《钢铁是怎样炼成的》20 ... [详细]
  • 本文详细探讨了在Web开发中常见的UTF-8编码问题及其解决方案,包括HTML页面、PHP脚本、MySQL数据库以及JavaScript和Flash应用中的乱码问题。 ... [详细]
  • 本文详细记录了腾讯ABS云平台的一次前端开发岗位面试经历,包括面试过程中遇到的JavaScript相关问题、Vue.js等框架的深入探讨以及算法挑战等内容。 ... [详细]
  • 驱动程序的基本结构1、Windows驱动程序中重要的数据结构1.1、驱动对象(DRIVER_OBJECT)每个驱动程序会有唯一的驱动对象与之对应,并且这个驱动对象是在驱 ... [详细]
  • 本文探讨了 Java 中 HttpClient 和 HtmlUnit 的区别,重点介绍了它们的功能和应用场景。 ... [详细]
  • 在运行于MS SQL Server 2005的.NET 2.0 Web应用中,我偶尔会遇到令人头疼的SQL死锁问题。过去,我们主要通过调整查询来解决这些问题,但这既耗时又不可靠。我希望能找到一种确定性的查询模式,确保从设计上彻底避免SQL死锁。 ... [详细]
  • 阿里云 Aliplayer高级功能介绍(八):安全播放
    如何保障视频内容的安全,不被盗链、非法下载和传播,阿里云视频点播已经有一套完善的机 ... [详细]
  • 本文整理了一份基础的嵌入式Linux工程师笔试题,涵盖填空题、编程题和简答题,旨在帮助考生更好地准备考试。 ... [详细]
  • Cookie学习小结
    Cookie学习小结 ... [详细]
  • 秒建一个后台管理系统?用这5个开源免费的Java项目就够了
    秒建一个后台管理系统?用这5个开源免费的Java项目就够了 ... [详细]
author-avatar
单纯的猪猪zhu
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有