- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在后端有一个 Android 原生应用程序作为客户端和 Spring Boot 服务,带有 REST 端点。我想知道使用 oAuth2 进行身份验证的最佳策略(没有社交登录方法)。
我目前正在使用 spring oauth security 并启动并运行授权服务器(用户使用电子邮件和密码注册)。我使用授权类型“密码”在 Android 应用程序中获取访问 token 。但是,这种方法需要 android 应用程序在请求中发送客户端 ID 和密码。我读了一些posts这表明这种资助类型并不理想。我不介意收到用户的密码,但我认为将客户端密码存储在应用程序中不是一个好方法。
另一种方法是使用授权代码授权流程,但在这种情况下,因为我只有一个 native 应用程序和后端 API,所以我不知道如何授权用户。用户看到要求他们授权应用程序的浏览器页面似乎并不是一种无缝体验。这也没有意义,因为这不是第三方应用程序。
我找到了一个 post人们建议在 PKCE 中使用授权代码流。但这显然不适用于 spring .
所以,现在我想知道其他 native 移动应用程序如何处理身份验证?他们不使用访问 token 吗?在处理移动应用程序和 Spring 后端时,如何最好地支持身份验证?
最佳答案
Spring Security OAuth 支持 password
和 authorization_code
流 without the client secret ,意思是“公共(public)客户端”。由于您拥有授权服务器和 native 应用程序并且您可以接受 native 应用程序获取凭据,因此让您的 native 应用程序使用具有 password
授权的公共(public)客户端是合理的类型。
但是,如果您决定您的 native 应用不应获取凭据,那么 PKCE 是当前的最佳实践。建议将 authorization_code
流与公共(public)客户端一起使用 alternative to PKCE :
In the time since the spec was originally written, the industry best practice has changed to recommend using the authorization code flow with no secret for native apps.
正如您提到的,这意味着 jumping out to a browser。
关于android - 具有 spring boot 后端的 android native 应用程序的 oauth 授权类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55381923/
有人可以解释一下 spring-boot-parent 和 spring-boot-starter-parent 之间的区别吗,正如我在下面附加的 GIT HUB 代码链接之一中看到的,他们为 spr
我有与 jersey 框架集成的 Spring Boot 应用程序。 现在,当我尝试运行该应用程序时,它只是停留在 Spring 启动徽标上,之后没有任何 react 。 我也尝试添加 -X ,但徽标
我指的是 Spring Boot 关于 的文档自动配置 和 执行器 模块: 自动配置: Spring Boot AutoConfiguration attempts to automatically
我正在尝试将 apache log4j 集成到我的 Spring boot 应用程序中。这是我的 build.gradle 文件: build.gradle buildscript { rep
使用 Spring Boot Maven 插件的以下命令在生产中启动 Spring Boot 应用程序是否是一个好主意或实践? mvn spring-boot:run 最佳答案 不,这是个坏主意。 您
据我所知,spring boot 和 spring session 为我们提供了一站式自动配置,但是当我的应用程序使用 session redis 和应用程序缓存 redis 时,不是同一个 redi
我希望使用Spring Boot创建一个新的Web应用程序。不幸的是,我的服务器在技术堆栈方面相当有限。它安装了Java 5。 谁能告诉我spring boot是否可以在Java 1.5上运行以及什么
我有3个实体 CarWash(设置Wash) Wash(car_wash_id FK到CarWash) WashComment(wash_id FK到Wash) 有什么办法可以写这个查询 @Qu
我一直在关注this文章。 我正在尝试在Spring-boot应用程序中优雅地处理gRPC错误,的主要目标是能够在gRPC客户端中获取错误状态。 在上面的文章之后,我坚持为异常添加拦截器。如何在Spr
我有一个要使用的自定义log4j布局插件。在IntelliJ中运行或与./gradlew bootRun一起运行时,插件可以正常工作。不使用./gradlew bootJar构建启动jar。 启用-D
我想在给定范围 (5001-5100) 的随机端口上启动 Spring Cloud 应用程序(Spring Boot 1.5.14,Spring Cloud Edgware.SR4)。我知道我们可以使
任何人都可以向我展示或指出不使用 spring boot gradle 插件的 spring boot gradle 项目。 我正在寻找类似不使用 gradle 插件的 spring boot sta
我当时尝试包含上述依赖项之一,但找不到任何区别: spring boot starter web:我可以看到 Flux 和 Mono 类并制作一个响应式(Reactive)休息 Controller
我们一直在为我们的应用程序使用 Springboot 1.X。 现在准备开始一些新的应用程序,想知道我们是应该使用 SpringBoot2.0 还是坚持使用 SpringBoot 1.X? 对一种方式
我希望记录应用程序正在加载 application-profile.propeties 或 application.yml。怎么做。在哪种方法中,我可以听取它并检测它是成功加载还是失败。 最佳答案 您
当我在 pom.xml 中添加简单的 spring-boot-starter-data-jpa 依赖项时,在 pom.xml 文件中出现错误。如果我删除该依赖项,则不会再有错误。我不确定为什么会发生这
我希望记录应用程序正在加载 application-profile.propeties 或 application.yml。怎么做。在哪种方法中,我可以听取它并检测它是成功加载还是失败。 最佳答案 您
我在网上看了很多关于 spring-boot-devtools 的文章和问题,但仍然无法弄清楚为什么它对我不起作用。每次运行我的应用程序时,我都会得到以下信息: 17:54:28.057 [main]
我正在尝试将现有的 Spring 应用程序移植到 Spring Boot。我不使用 spring-boot-starter-data-solr 启动器,但是我的类路径上有 apache solrj (
(这主要是一个历史问题。Pivotal 建议所有论坛讨论都在 StackOverflow 上进行,这就是我在这里问它的原因。) Spring Boot 项目用来证明将应用程序的类和依赖项从可执行 ja
我是一名优秀的程序员,十分优秀!