AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1152082
Accepted
Django Reinhardt
Django Reinhardt
Asked: 2024-01-23 21:11:34 +0800 CST2024-01-23 21:11:34 +0800 CST 2024-01-23 21:11:34 +0800 CST

仅在 LAN 上运行网站

  • 772

这是一个大问题,所以我只是在寻找一个高级概述答案来帮助我研究我不知道的部分。

本质上,问题是这样的:我需要一台专用的 Mac Mini(或类似的 macOS 机器)并用它来托管一个只有同一本地网络上的用户才能访问的网站。

我的第一反应是购买一个域名(和证书)并将其指向我知道我的服务器所在的本地地址(例如 10.10.10.152)。这样,任何尝试访问该域的人都将被本地重定向到我的网站(如果他们位于正确的网络上)。

这行得通吗?如果是这样,获取域、安装证书并将其指向本地 IP 的主要步骤是什么?

php
  • 3 3 个回答
  • 73 Views

3 个回答

  • Voted
  1. Best Answer
    Zac67
    2024-01-23T22:18:51+08:002024-01-23T22:18:51+08:00

    购买一个域名(和证书)并将其指向我知道我的服务器所在的本地地址(例如 10.10.10.152)。这样,任何尝试访问该域的人都将被本地重定向到我的网站(如果他们位于正确的网络上)。

    可以,但是绝对没有必要买任何东西。

    您可以为例如service.example.org(如果您拥有example.org)或service.lan设置本地 DNS ,而无需您自己的域。将 A 记录指向您的私人 Web 服务器。

    如果您需要 HTTPS (TLS),您可以自签名证书并明确信任每个客户端的该证书,或者启动一个新 CA(使用 OpenSSL 只需一分钟),为 service.lan 签署证书并将 CA 根证书作为信任锚部署到您的客户端。

    • 2
  2. Romeo Ninov
    2024-01-23T21:25:16+08:002024-01-23T21:25:16+08:00

    根据评论讨论,您可以使用例如 Apache 并设置类似:使用模块mod_authz_host和Require指令。

    <Directory /var/www/web/>
      Require host localhost
      Require ip 127.0.0.1
      Require ip 192.168.0
    </Directory>
    

    (上面我假设你的本地网络是192.168.0.0/24)

    此配置将限制对localhost/127.0.0.1网络中所有主机的访问192.168.0.0/24

    • 0
  3. symcbean
    2024-01-23T21:55:31+08:002024-01-23T21:55:31+08:00

    我不确定注册/配置域并购买证书的想法是偶然还是故意的 - 但在缺乏网络配置和系统管理经验的情况下,这可能是实现您目标的最短路径。

    替代方法是

    • 在互联网上配置网站,仅允许访问 ACME 路径并从 LetsEncrypt 获取免费证书(这还要求您拥有有效的公共 DNS 记录 - 因此是相当静态的 IP 或动态 DNS 服务)
    • 构建您自己的证书颁发机构,将 CA 证书分发给客户端并使用它来签署服务证书
    • 或者根本不使用 TLS(不推荐)。

    您将需要一个包含记录的注册域才能从第三方证书颁发机构获取证书。如果您选择其他方法之一,那么您不需要注册域/可公开访问的 DNS 记录 - 您可以(例如)使用 dnsmasq 作为您的内部 DNS(轻松配置特定 DNS 名称的覆盖)。

    只要您的互联网连接不允许外部访问主机的 IP 地址,您就不需要额外的安全控制,但现在添加它们可能会防止将来发生事故。

    • -1

相关问题

  • 用户特定的 Php.ini 当 php 作为模块运行时?

  • 使 php mail() 函数在 ubuntu-server 上工作的步骤是什么?

  • Web 服务器和数据库服务器位于完全不同的位置

  • PHP 作为 CGI 还是 Apache 模块?

  • 通过 VPN 连接什么是远程服务器 IP?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve