- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我很确定以前有人问过类似的问题,但我没有找到任何问题(也许我使用了错误的术语)。
我有一个不安全的网络应用程序(内置于 Laravel)。前端和后端之间的所有通信都通过 http。现在,我想切换到 https。据我所知,有两种方法可以做到这一点。
首先是将服务器(托管应用程序的服务器)配置为仅接受 https 请求。如果我这样做,客户端和服务器之间的通信将被加密,我将不必更改我的应用程序中的任何内容(这是正确的吗?)。
第二种方法是将我的应用配置为仅接受 https 请求。如果我这样做,我将不得不对我的应用程序代码进行一些更改。
现在我想问一下,这两种方式都同样安全吗?首选哪种方式,为什么?
最佳答案
恐怕这里有几件事混在一起了。
您只能在您的网络服务器(Apache、Nginx 等)上启用 SSL。您需要服务器证书,并且必须配置 Web 服务器才能接收 https (ssl) 连接。至于具体如何做到这一点超出了这个答案的范围,但是您可以找到很多教程。您必须先执行此操作。
当您的 Web 服务器配置为支持 SSL 时,您希望您的 Web 应用程序仅可通过 HTTPS 而不是纯 HTTP 进行访问。目的是,一方面,不知道差异的用户仍然是安全的,另一方面,攻击者无法将用户连接降级为不安全的纯 HTTP。
现在至于您希望如何为您的应用程序强制执行 HTTPS,您确实有两种选择。您可以让您的 Web 服务器处理纯 HTTP 请求并将它们重定向到 SSL,这在 Apache 中都是一个简单的配置。和 Nginx .或者,您可以向您的应用程序添加重定向以处理通过普通 HTTP 访问它的情况,并使用类似 Location
header 的内容将您的用户重定向到 HTTPS。
在安全方面,无论是网络服务器还是应用程序进行重定向并不重要,从客户端的角度来看,它们是相同的(实际上几乎无法区分)。选择您最喜欢的选项。例如,可能有可维护性原因来选择一个或另一个。 (你想在你的应用程序代码中维护重定向,还是让你的服务器操作添加重定向 header 等)
但请注意,无论哪种方式,您的应用程序都可能仍然容易受到名为 SSL Stripping 的攻击。 , 为了防止你应该总是发送 HSTS response header .
关于security - 在服务器级别与应用程序级别强制使用 SSL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40094048/
Android 项目中最低(最低 sdk)和最高(目标 sdk)级别是否有任何影响。这些东西是否会影响项目的可靠性和效率。 最佳答案 没有影响,如果您以 SDK 级别 8 为目标,那么您的应用将以 9
我将现有的 android 项目升级到 API 级别 31。我使用 Java 作为语言。我改变了 build.gradle compileSdkVersion 31 defaultConfig {
我正在使用 ionic 3 创建一个 android 应用程序,当我尝试上传到 playstore 时,我收到一个错误,提示我的应用程序以 api 25 为目标,当我检查我的 project.prop
我刚刚尝试将应用程序的目标和编译 API 级别更新为 29 (Android 10),并注意到我无法再编译,因为 LocationManager.addNmeaListener 只接受 OnNmeaM
我的代码没有在 Kitkat 上显示工具栏。 这是我的两个 Android 版本的屏幕截图。 Kitkat 版本: Lollipop 版: 这背后的原因可能是什么。 list 文件
我正在构建面向 API 级别 8 的 AccessabilityService,但我想使用 API 级别 18 中引入的功能 (getViewIdResourceName())。这应该可以通过使用 A
当我想在我的电脑上创建一个 android 虚拟机时,有两个选项可以选择目标设备。它们都用于相同的 API 级别。那么我应该选择哪一个呢?它们之间有什么区别? 最佳答案 一个是基本的 Android,
当我选择 tagret 作为 Android 4.2.2(API 级别 17)时,模拟器需要很长时间来加载和启动。 所以我研究它并通过使用 找到了解决方案Intel Atom(x86) 而不是 ARM
我有一个使用 Android Studio 创建的 Android 项目。我在项目中添加了一些第三方依赖项,但是当我尝试在 Android Studio 中编译时,我遇到了以下错误: Error:Ex
如上所述,如何使用 API 8 获取移动设备网络接口(interface)地址? 最佳答案 NetworkInterface.getInetAddresses() 在 API8 中可用。 关于andr
我想显示 Snackbar并使用图像而不是文本进行操作。 我使用以下代码: val imageSpan = ImageSpan(this, R.drawable.star) val b
我有一个用 python 编写的简单命令行程序。程序使用按以下方式配置的日志记录模块将日志记录到屏幕: logging.basicConfig(level=logging.INFO, format='
使用下面的代码,实现游戏状态以控制关卡的最简单和最简单的方法是什么?如果我想从标题画面开始,然后加载一个关卡,并在完成后进入下一个关卡?如果有人能解释处理这个问题的最简单方法,那就太好了! impor
我想创建一个可以找到嵌套树结构深度的属性。下面的静态通过递归找出深度/级别。但是是否可以将此函数作为同一个类中的属性而不是静态方法? public static int GetDepth(MenuGr
var myArray = [{ title: "Title 1", children: [{ title: "Title 1.1", children: [{
通过下面的代码,实现游戏状态来控制关卡的最简单、最容易的方法是什么?如果我想从标题屏幕开始,然后加载一个关卡,并在完成后进入下一个关卡?如果有人可以解释处理这个问题的最简单方法,那就太好了! impo
我有一个树结构,其中每个节点基本上可以有无限个子节点,它正在为博客的评论建模。 根据特定评论的 ID,我试图找出该评论在树中的深度/级别。 我正在关注 this guide that explains
考虑任何给定的唯一整数的数组,例如[1,3,2,4,6,5] 如何确定“排序度”的级别,范围从 0.0 到 1.0 ? 最佳答案 一种方法是评估必须移动以使其排序的项目数量,然后将其除以项目总数。 作
我如何定义一个模板类,它提供一个整数常量,表示作为输入模板参数提供的(指针)类型的“深度”?例如,如果类名为 Depth,则以下内容为真: Depth::value == 3 Depth::value
我的场景是:文件接收器应该包含所有内容。另一个接收器应包含信息消息,但需要注意的是 Microsoft.* 消息很烦人,因此这些消息应仅限于警告。两个sink怎么单独配置?我尝试的第一件事是: str
我是一名优秀的程序员,十分优秀!