热门标签 | 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;
在这里插入图片描述


推荐阅读
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • Python + Pytest 接口自动化测试中 Token 关联登录的实现方法
    本文将深入探讨 Python 和 Pytest 在接口自动化测试中如何实现 Token 关联登录,内容详尽、逻辑清晰,旨在帮助读者掌握这一关键技能。 ... [详细]
  • 本文详细探讨了在微服务架构中,使用Feign进行远程调用时出现的请求头丢失问题,并提供了具体的解决方案。重点讨论了单线程和异步调用两种场景下的处理方法。 ... [详细]
  • 本文详细介绍了JSP(Java Server Pages)的九大内置对象及其功能,探讨了JSP与Servlet之间的关系及差异,并提供了实际编码示例。此外,还讨论了网页开发中常见的编码转换问题以及JSP的两种页面跳转方式。 ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
  • 深入理解 .NET 中的中间件
    中间件是插入到应用程序请求处理管道中的组件,用于处理传入的HTTP请求和响应。它在ASP.NET Core中扮演着至关重要的角色,能够灵活地扩展和自定义应用程序的行为。 ... [详细]
  • Django Token 认证详解与 HTTP 401、403 状态码的区别
    本文详细介绍了如何在 Django 中配置和使用 Token 认证,并解释了 HTTP 401 和 HTTP 403 状态码的区别。通过具体的代码示例,帮助开发者理解认证机制及权限控制。 ... [详细]
  • 本文介绍如何配置SecureCRT以正确显示Linux终端的颜色,并解决中文显示问题。通过简单的步骤设置,可以显著提升使用体验。 ... [详细]
  • 本文探讨了如何通过WebBrowser控件在用户点击输入框时自动显示图片验证码。该过程可能涉及JavaScript事件的触发与响应。 ... [详细]
  • 本文将介绍如何利用Python爬虫技术抓取国内主流在线学习平台的数据,并以51CTO学院为例,进行详细的技术解析和实践操作。 ... [详细]
  • Spring Security核心概念与应用实践
    本文详细介绍了Spring Security的核心机制,包括其作为一系列过滤器的工作原理,如何实现用户认证与授权,以及常见的配置方法和高级特性如CSRF防护。 ... [详细]
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社区 版权所有