开发者社区 > 云原生 > Serverless > 正文

前端是不是只能用jwt认证?

前端是不是只能用jwt认证?

展开
收起
函数计算小白 2023-06-19 15:07:33 80 0
5 条回答
写回答
取消 提交回答
  • 前端使用JWT认证是一种常见的方式,但并不是唯一的方式。JWT认证是一种基于token的认证方式,可以在前端和后端之间传递数据,具有一定的灵活性和安全性。但是,与其他 token-based 认证方案一样,JWT也存在一些问题,例如需要额外的存储空间来存储token、token无法被撤销等等。因此,根据具体情况,前端可以选择使用其他认证方式,例如session、OAuth等。

    在使用认证方式时,需要根据具体的应用场景进行选择。如果您的应用需要支持跨域访问、多种客户端之间的认证等复杂场景,JWT认证可能是更好的选择。但是如果您的应用只需要支持简单的认证和授权,使用session认证可能更加简单和高效。总之,需要根据具体情况选择合适的认证方式。

    2023-06-20 08:06:37
    赞同 展开评论 打赏
  • 公众号:网络技术联盟站,InfoQ签约作者,阿里云社区签约作者,华为云 云享专家,BOSS直聘 创作王者,腾讯课堂创作领航员,博客+论坛:https://www.wljslmz.cn,工程师导航:https://www.wljslmz.com

    阿里云函数计算并没有限制您在前端使用何种方式进行认证。您可以根据实际需求选择适合的认证方式。

    JWT(JSON Web Token)是一种常用的认证方式,它具有轻量、跨平台和易于使用等特点,因此在前端应用中得到了广泛应用。如果您在前端应用中选择使用 JWT 认证,可以考虑使用阿里云的 RAM(Resource Access Management)服务来管理用户身份和权限。

    除了 JWT 认证之外,前端应用还可以使用其他的认证方式,例如基于 OAuth2 的认证、基于 Session 的认证等。具体来说,您可以根据实际需求选择适合的认证方式,并结合阿里云的其他服务进行身份和权限管理。

    2023-06-19 23:49:22
    赞同 展开评论 打赏
  • 都可以哈,不过认证要您自己搞。fc内置了 jwt 认证。如果您要用其他的认证,自己代码里处理一下就行了,和使用 ecs 做认证时时一样的。或者使用 API 网关,API 网关提供了一些认证插件

    此答案来自钉钉群“阿里函数计算官网客户"

    2023-06-19 18:05:53
    赞同 展开评论 打赏
  • 十年摸盘键,代码未曾试。 今日码示君,谁有上云事。

    JWT的工作原理图就是用户的信息被加密,转换成token字符串的形式,保存在客户端浏览器中;服务器通过还原token字符串来获取用户信息,JWT是一种轻量级、简单、可扩展的身份验证机制,具有良好的互操作性和各种编程语言中的广泛支持。可以在前端使用JavaScript生成JWT并在后端进行验证,也可以在后端使用Java、Python等语言生成和验证JWT。同时,JWT具有良好的安全性能,防止了跨站点脚本(XSS)和跨站点请求伪造(CSRF)等攻击。

    JWT由三个部分组成,从前到后分别是:

    Header 头部 Payload 负载 Signature 签名

    Header和Signature是安全性相关的部分,只是为了保证Token的安全。头部包含算法和类型信息,签名则是基于头部和载荷计算得出的,在身份验证时用于验证请求是否是合法的

    Payload部分是用户信息经过加密之后生成的字符串,这部分才是真正的用户信息,载荷包含用户数据和元数据。

    客户端收到服务器返回的JWT之后,通常会将它存储到localStorage(本地存储)或者sessionStorage(会话存储)中,当然cookie也行。

    此后,客户端每次与服务器通信,都要带上这个JWT字符串,从而进行身份认证。

    JWT是一种用于双方之间传递安全信息的简洁的、URL安全的表述性声明规范。也是一种token,但是和token有一些不同。

    token生成的是一个UUID,需要人工持久化处理token(像处理分布式下的sessionId一样)。jwt就不需要,因为自包含(字符串里包含用户信息),token里有身份验证信息,不需要做后台持久化处理,前端每次请求被保护的资源时请求头里带上该token就可以实现。JWT一旦生成,一般就抛给客户端去保存。客户端只需要每次携带这个Token就可以正常地访问接口

    JWT有两个用途: 数据交换:因为JWT使用JSON来存储相关数据,而JSON这一种数据格式可以在各方之间传递。 安全验证:登录之后,后续的请求可以携带JWT,只有携带了JWT(认证Token)的请求才能够正常地访问到相关的数据及资源。

    如果你想在返回的token中附带一些别的信息,可以对jwt进行扩展操作。

    如果需要获取jwt原有信息,直接在请求方法中把Authentication当做参数,就可以获取到jwt原始信息。

    如果需要获取jwt扩展的信息,需要pom导入依赖。

    JWT支持签名和加密机制,可以防止请求被篡改或伪造。

    JWT是基于JSON格式的标准,并且是独立于编程语言的,非常适合跨平台使用。

    JWT的安全性取决于密钥的保护,如果密钥泄漏,攻击者就可以伪造有效的JWT,从而通过身份验证。

    JWT中的载荷是未加密的,因此可能会将敏感数据暴露给未经授权的人员。

    所以在使用时需要注意密钥的保护以及不将敏感数据放在JWT的载荷中。

    2023-06-19 17:37:55
    赞同 1 展开评论 打赏
  • 前端在进行用户认证时,不一定只能使用 JWT(JSON Web Token)这个方式,还有其他可用的认证方式。JWT 作为一种 token-based 认证方式,具有简洁、轻量、易于传输等特点,在前后端分离的应用中应用广泛。但是,JWT 认证并不是万能的,使用时需要结合具体场景和业务需求来确定是否适用。

    除了 JWT 认证,前端还可以使用其他的认证方式来保证用户的身份验证,例如:

    1. 基于 session 的认证 在这种方式中,服务器会在用户登录验证通过后,为用户创建一个 session,存储用户的身份信息和 session ID,将 session ID 通过 cookie 或其他方式返回给前端,并在后续的请求中验证 session ID 的有效性,从而保证用户的身份与权限。这种方式具有回话的特点,也需要在服务端存储会话信息,适用于传统的 web 应用系统。

    2. 基于 OAuth 2.0 的认证 OAuth 2.0 在身份认证的领域中也得到了广泛应用,其认证方式可以包括 token-based 的方式,也有 code-based 的方式。OAuth 2.0 授权服务器可以向前端返回 token,前端在后续的请求中携带 token 来访问受保护的 API 服务。

    3. 基于 OpenID Connect 的认证 OpenID Connect 是基于 OAuth 2.0 的一种身份认证协议,在 OAuth 2.0 的基础上增加了身份认证的部分,可以通过在认证服务器上验证用户身份并颁发 ID Token,前端使用 ID Token 认证来保护应用程序。

    需要注意的是,在使用任何一种认证方式时,都需要对安全性进行充分考虑,确保用户的身份和数据的安全。因此,在实际应用中,需要结合具体的需求和场景来选择认证方式和相关技术。

    2023-06-19 15:14:41
    赞同 展开评论 打赏
问答分类:
问答标签:
问答地址:

快速交付实现商业价值。

相关电子书

更多
Vue.js 在前端服务化上的探索与实践 立即下载
阿里文娱大前端技术实践 立即下载
前端代码是怎样智能生成的 立即下载