证书对 Intranet SSL 有用吗?

2024-04-03

我的任务是开发命令行软件的内联网接口,现在我正在研究安全选项。我们的命令行应用程序已经完成,但我还没有开始编写 Web 界面。我不确切地知道潜在客户的安全要求是什么,尽管我相信ssh对于命令行界面来说通常是可以接受的。考虑到这一点,我请求帮助开发一个选择菜单及其相关的优缺点。有一天,我们可能会考虑将我们的网络界面发布到互联网上,因此,如果简单和/或免费,我愿意考虑比当前必要的更高的安全性。

我已经做了很多阅读,我的初步结论是,没有证书的 SSL 安全性是最好的方法,不是因为较低的安全性是不可接受的,而是因为 SSL 是标准,并且因为它似乎并不困难。设置。作为一名非安全专家,我不需要解释为什么非安全专家可以接受较低的安全性。如果有必要,我可以升级我的应用程序以在将来使用证书。

以下是 SSL 相关安全选择的列表,按我对安全级别的看法和评论排序。我需要什么级别的保护?

  1. No SSL.如果我们的客户不担心他们的员工看到/更改彼此的数据,这可能是可以接受的。无论如何,他们的员工可能希望彼此共享结果,并且我可以使用基于 IP 的访问控制和/或密码来确保安全。

  2. 无需证书即可执行 SSL。这对通信进行了加密,至少可以保护数据不被未经授权的员工读取。使用密码,这与以下安全级别相同ssh在命令行上,对吗?我不需要担心内网中的中间人攻击,对吧?这种方法的缺点是如果存在大量浏览器警告消息。

  3. 使用自签名证书执行 SSL。这给了我什么没有证书给我的东西?如果 DNS 可以被不恰当地更改,那么客户和我的应用程序就不是他们最关心的问题。换句话说,如果 DNS 可以改变,那么我想ssh也会很脆弱。

  4. 使用本地证书颁发机构执行 SSL。OpenSSL 让我可以创建自己的证书颁发机构。这给了我什么是自签名证书所没有的?我假设在 LAN 上,验证服务器不太重要。

  5. 使用外部证书颁发机构执行 SSL。是否有理由为 Intranet 采用这条路线?我发现了一些在网上出售的“内联网证书”——但不清楚他们提供什么,我自己做不到。

作为参考,此页面可能有助于比较证书:

http://httpd.apache.org/docs/trunk/ssl/ssl_faq.html#aboutcerts http://httpd.apache.org/docs/trunk/ssl/ssl_faq.html#aboutcerts

[update]

Here's http://www.networkworld.com/article/2457649/security0/new-ssl-server-rules-go-into-effect-nov-1.html一篇讨论从公共 CA 获取内部证书的风险和规则的文章。


是的,证书对于 Intranet SSL 仍然有用。

SSH 和无证书 SSL 之间有一个重要区别:当您首次使用 SSH 连接到服务器时,您的 SSH 会存储服务器的指纹。如果您随后尝试连接到 SSH 客户端认为是同一台计算机但返回不同指纹的设备,它会提醒您可能有人拦截您的通信。

另一方面,无证书的 SSL 不存储服务器的指纹。您的通信仍将被加密,但如果有人以某种方式劫持了您提到的 DNS 服务器,或者,正如鲁西奥所说 https://stackoverflow.com/questions/20894868/are-certificates-useful-for-intranet-ssl/20895967#comment31387770_20895967,ARP 中毒或类似的东西,他们将能够执行中间人攻击。如前所述,SSH 会(假设您在过去某个时间连接到正确的服务器)注意到指纹已更改并提醒您。

自签名证书的安全性与 SSH 相当。中间人可以生成自己的自签名证书,但只要您的应用程序配置为仅接受that自签名证书,您应该会收到类似于 SSH 给您的警报。

本地证书颁发机构为您提供类似于自签名证书的安全性,但可能更具可扩展性。如果您有多个服务器,每个服务器都可以有自己的证书,但客户端只需要顶级服务器即可信任所有服务器。如果服务器受到威胁,您可以撤销其证书,而不必更改每个服务器的证书。

我不认为外部证书颁发机构有任何优势,除了如果您的计算机已经信任证书颁发机构可能会减少配置之外。

最后,我对双因素身份验证了解不够,无法对其进行评估,但对于大多数应用程序来说,SSL 应该足够了。

Disclaimer: I am not a security expert.

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

证书对 Intranet SSL 有用吗? 的相关文章

  • 在AWS Windows实例中获取SSL的CSR文件

    我需要获取 CSR 才能完成 godaddy com 的 SSL 订单 我在 Amazon AWS 实例中运行 Windows 2012 服务器是 Express js 域名指向该实例IP 一切正常 我想我必须从控制台或类似的东西创建该密钥
  • Spring security @secure 不适用于角色层次结构

    我在 spring security 中使用角色层次结构spring securityConfig xml is
  • 如何向http-client-tls提供客户端证书?

    我在用http 客户端 tls http hackage haskell org package http client tls 0 2 1 2连接到需要客户端证书的启用 TLS 的服务器 我怀疑我需要调整TLS设置 http hackag
  • 如何清除客户端.Net SSL会话缓存

    我正在编写一个小测试工具 它使用 HttpWebRequest 来负载测试服务器 我想要 每次我尝试调用 HttpWebRequest GetResponse 时 它都会建立一个新的 SSL 会话 而不是使用缓存中的会话 注意 我提供客户端
  • ARM(64 位)上的面向返回编程

    我正在 ARM 64 位 上研究 Rop 因此 我正在 ARMv8 Cortex A 72 上测试 Rop 漏洞 以了解它在 Arm64 上的工作原理 我写了一个非常简单的易受攻击的c代码 include
  • Jmeter关闭SSL证书

    如何在 Apache Jmeter 3 2 中禁用 SSL 证书验证 类似于邮递员 SSL证书验证开 关 中的开关 默认情况下 JMeter 不验证证书 如果您遇到 ssl 问题 这是另一个原因 根据您的评论 根本原因是缺少标头 添加这些标
  • 存储应用内购买的正确且安全的方式

    在设备上存储应用内购买的最佳方式是什么 这样购买也可以离线访问 但是 购买的安全性没有受到损害 不要在设备上存储任何有价值的东西 因为它不可信 并且很容易被有动机的人破坏 现在 所有这一切都取决于所购买物品的类型和价值 以及如果物品受损会发
  • Asp.net Mvc自定义机制处理未授权请求

    对于我的网站 我希望安全控制器 或操作 具有以下行为 如果用户发出正常请求重定向到登录页面 我可以轻松做到 如果请求是Ajax类型Request IsAjaxRequest true 返回状态码401 我如何为此创建一个过滤器 public
  • 如何获取使用 PowerShell 创建的新 Azure Linux VM 的 SSH 主机密钥?

    如果我使用 PowerShell 创建 Azure Linux VM 如何获取其新的 SSH 主机密钥 以便将其安装在本地ssh 油灰 最好的解决方案也是 PowerShell 代码 您可以使用new 运行命令 feature https
  • Windows 版 Git - 每次推送时都要求输入 SSH 密码

    我今天安装了 Windows 版 git 并做了一些测试 我发现每次推送时都会要求我输入密码 Linux 上不会发生这种情况 我对另一个线程提出了一些建议 我发现我没有配置 ssh agent 但我这样做了 问题仍然存在 有什么建议吗 谢谢
  • Xamarin 代码安全

    我正在开发一个涉及付款的应用程序 我将在应用程序中采用某种加密 并在服务器后端采用某种加密和安全性 我想知道如何保护我的 Xamarin 代码 特别是在部署到 Android 时 我知道 Xamarin iOS 转换为本机代码 但 Xama
  • pam_unix(sudo:auth): 对话失败,auth 无法识别 [用户名] 的密码

    我在用着ansible配置我的 Centos 7 生产集群 不幸的是 执行以下命令的结果是ansible Tiemout和 Linux 可插入身份验证模块 pam error conversation failed 相同ansible命令运
  • AddKeysToAgent 是 ssh 配置在 Mac 上不起作用

    您好 我的 ssh 配置文件设置为自动将 ssh 密钥添加到 ssh 代理 然而 目前它不起作用 它之前正在工作 我更新了 bitbucket 的 ssh 密钥 但它不再起作用 当我重新启动时 我必须使用 ssh add K 选项手动添加
  • Elastic Beanstalk 未创建 ssl.conf

    我正在关注these https docs aws amazon com elasticbeanstalk latest dg https singleinstance php html有关在 Elastic Beanstalk 管理的 E
  • 将现有用户和密码迁移到新的 Symfony/sfDoctrineGuard 用户系统

    我有一个现有的 非基于框架的 PHP MySQL 网站 它有一个简单的安全模型 带有一个包含用户名和散列 MD5 密码的用户表 我目前正在开发该网站的 版本 2 这次使用 Symfony 和 Doctrine 新版本运行良好 我正在使用 s
  • 具有自签名客户端证书的相互身份验证 SSL

    在我们公司 我目前有一个脚本可以通过 SSL 连接到 HTTPS 上的外部供应商 该脚本仅执行服务器身份验证 就是这个 use HTML Parser use HTTP Request Common use LWP UserAgent us
  • 如何使用ansible输入私钥密码

    我有流浪者virtual machine跑步 I can ssh进入它使用ssh email protected cdn cgi l email protection然后它会询问我私钥的密码 我可以输入该密码 然后它就会让我登录 但如果我使
  • 如何使用 Android DownloadManager 和 https 信任所有主机

    我正在使用 DownloadManager 从我的 Android 应用程序中的 https 服务器下载文件 由于我仍处于开发阶段 我想信任所有主机并避免证书检查 我如何告诉 DownloadManager 信任所有主机 为了进一步开发 如
  • 连接到主机 localhost 端口 22:连接被拒绝

    在我的本地计算机上安装 hadoop 时 出现以下错误 ssh vvv localhost OpenSSH 5 5p1 OpenSSL 1 0 0e fips 6 Sep 2011 debug1 Reading configuration
  • 对 .NET Remoting CAO 的暴力攻击

    我正在尝试使用 NET 远程客户端激活对象来在多次调用期间保留客户端的身份验证信息 而不是实现需要客户端在每次调用中发送会话 ID 的会话管理系统 正如 MSDN 所说 当客户端使用 new 运算符提交对服务器对象的请求时 激活请求消息将发

随机推荐

  • 为什么变量指针包含相同数据类型的地址?

    指针声明的一般语法 data type pointer name 指针是一个变量 其值是另一个变量的地址 即内存位置的直接地址 与任何变量或常量一样 您必须先声明一个指针 然后才能使用它来存储任何变量地址 指针的数据类型必须与指针所指向的变
  • 在nginx反向代理后面处理flask url_for

    我有一个使用 nginx 进行反向代理 ssl 终止的 Flask 应用程序 但是在 Flask 中使用 url for 和重定向时遇到了麻烦 nginx conf 条目 location flaskapp proxy pass http
  • 如果表单没有焦点,则不会调用 OnPaint

    我有一个带有自定义绘画的用户控件 据我所知 构造函数正确设置了样式 基本代码 public partial class LineChart2 UserControl public LineChart2 InitializeComponent
  • 更改 const 对象 - 没有警告?另外,什么情况下是UB?

    为什么下面的代码没有警告呢 int deserialize students const Student dest const int destCapacityMax FILE ptr file int i 0 ptr file fopen
  • 具有自定义模板的 STL 迭代器

    我有以下模板方法 template
  • 如何重定向到移动网站但保留主题标签?

    我希望拥有它 以便当用户加载我们的页面时 它会检查他们是否在移动设备上 然后将他们重定向到我们网站的移动版本 但保留原始哈希标签他们关注的链接 我尝试使用 javascript 中的哈希标签设置新位置 它在 Chrome 中工作 但在 Sa
  • 创建 ArrayList 元素的数组

    我想创建一个包含 ArrayList 元素的数组 我试过了 ArrayList
  • 创建一个仅指向另一个数组的一部分的数组?

    我有一个包含引用类型元素的巨大数组 并且我想创建许多其他数组 这些数组本质上只是指向该一个大数组的特定部分 换句话说 我想创建 索引器 或 具有长度的指针 在 C 中 使用指针很容易做到这一点 并为每个指针分配一个长度 例如创建一个包含具有
  • 在 iOS 上使用可调整大小的图像时避免混合图层

    我试图避免 iOS 上的混合层以提高性能 但是 我注意到我使用的可调整大小的图像backgroundView of my UITableViewCell被标记为混合层 事实上 使用任何可调整大小的图像 即使是没有透明度的 JPEG 都会导致
  • 如何使用 rspec 配置 Sorbet?

    我有一个简单的测试 但是describe关键字在冰糕测试中不起作用 我在这些方法上收到的错误 Method describe does not exist on T class of
  • 增大/缩小 WPF 动画

    在 WPF 中 当用户获得焦点时TextBox 我想要一些动画 可以使TextBox变成多行并使其Width更大 当他打字时 并且当焦点丢失时 TextBox恢复到原来的大小 尺寸未知 另外 最终 TextBox需要在 WPF 内DataG
  • Gunicorn 与 unix 套接字不工作给出 502 bad gateway

    我正在关注http www obeythetestinggoat com book chapter 08 html http www obeythetestinggoat com book chapter 08 html书上说要添加一个un
  • 如何更改 Notepad++ 更改文本行的背景颜色?

    更新 未保存 的文本行有亮粉色 ffc286 背景色 更改和保存的文本行有亮绿色 b5ffb5 此背景对于任何颜色样式都是相同的 我在样式配置器中找不到它 我以为它可能是增量突出显示 但事实并非如此 并且它不在全局设置中 我已经在寻找这个值
  • 授予子网中所有计算机的 mysql 访问权限

    我有一个在 Windows 上运行的 mysql 实例 和架构 我可以通过基于 localhost 作为服务器的连接字符串进行访问 现在我希望能够从同一子网上的另一台计算机访问该数据库 如果可能的话 我想使用单个用户 但允许它从同一子网上的
  • 在 n 层系统中,您应该从数据访问层向业务层返回哪些对象

    例如 如果您有一个名为 Person ID Name 等 的数据库表 数据访问层应将什么样的对象返回给业务层 我在想这样的事情 data access tier public class DataAccess public interfac
  • 具有多个参数的 Blazor EventCallback - 如何响应父主机控件中的事件

    我有一个带有 EventCallBack 参数的 blazor 组件 该组件利用允许多个参数的新结构格式 Parameter public EventCallback lt EmployeeShiftDay DateTime DateTim
  • Java中泛型参数类的反射?

    想象一下以下场景 class MyClass extends OtherClass
  • TableView 复选标记

    我想在选择字典数据数组时在表格视图中放置复选标记 例如 数组包含 10 个模型名称 它是字典 它包含子模型 我的问题是 当我选择子模型时 模型名称自动获得复选标记 现在我为不同的模型和子模型添加了复选标记 但是我们如何根据子模型添加复选标记
  • jquery 在视口检查器中同时检查多个元素

    我有一个 jQuery 函数来检查元素是否在视口中 如果是 它会添加 animate 类来启动动画并使元素可见 上面的方法有效 但现在 有多个元素 jQuery 仅针对该类的第一个元素blogcard 然后执行addClass animat
  • 证书对 Intranet SSL 有用吗?

    我的任务是开发命令行软件的内联网接口 现在我正在研究安全选项 我们的命令行应用程序已经完成 但我还没有开始编写 Web 界面 我不确切地知道潜在客户的安全要求是什么 尽管我相信ssh对于命令行界面来说通常是可以接受的 考虑到这一点 我请求帮