如何在 Mac 上配置一个本地 Web 服务器
创始人
2025-01-17 21:03:49
0

通常情况下,你可以通过在浏览器中直接打开或者通过一个 URL 来访问一个文件。

使用浏览器访问本地文件时,一般地址是 file:// 开头的本地文件地址。
而访问远程文件时,一般地址是 http:// 或者 https:// 开头的地址,表示这个文件通过 http 协议访问的。

2. 直接访问本地文件时存在的问题

在有些情况下,你打开一个本地的 html 文件时,会出现运行错误。

导致这些错误的原因主要有以下两个:
(1) 其中包含了异步请求。 如果你直接打开本地文件运行,一些浏览器(包括 Chrome)将不会运行其中的异步请求(请参阅 从服务器获取数据)。 这是因为安全限制而导致的(更多关于 Web 安全的信息,请参阅Website security)。

比如,你直接在浏览器中打开含有如下内容的文件:

           HTML 测试页面        

测试页面

然后,你会在 console 中看到这样的错误:

index.html:12 Failed to load file:///Users/ShannonChen/Desktop/Playground/nodejs_example/data.json: Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-extension, https. 

(2) 执行文件中的代码时需要通过执行一些附加逻辑(如 PHP 或 Python)才能获得结果,而不仅仅是直接访问一个文件。

比如,我登录了京东网站后,查看购物车页面时,需要服务器返回的是包含我的购物车数据的页面,这个时候,就需要服务端在接收到请求后,跟我的用户信息(一般是 cookie)来返回匹配的数据。

方法一、启动 Mac 自带的 Apache 服务器

  1. 运行 Apache $ sudo apachectl start
  2. 退出 Apache $ sudo apachectl stop
  3. 把工程文件夹放到以下位置中 /Library/WebServer/Documents
  4. 在浏览器中访问:在地址栏中输入地址 http://localhost/工程文件夹名称/,回车。

注意: 不再需要使用后一定要记得退出,否则会消耗电脑性能。

Q:如何修改 Apache 的默认端口?
A:首先,找到 Apache 的配置文件,位于 /etc/apache2 下的 httpd.conf
然后,找到 Listen 80 那一行,修改成你想要的端口即可。

方法二:借助 Mac 系统自带的 Python,使用其中的 SimpleHTTPServer 模块启动服务器

  1. 安装 Python,其实 Mac 系统就自带了 Python2.7。
  2. 通过 cd  进入到你的工作目录下,也就是你要让别人访问的文件所在的目录。
  3. 在工作目录下执行下面的命令后,就可以启动服务了:

    # 如果你的 Python 版本是 3.X python3 -m http.server  # 如果你的 Python 版本是 2.X python -m SimpleHTTPServer 
  4. 默认情况下,上面的操作将会在本地 Web 服务器上的端口 8000 上运行工作目录中的内容。您可以通过在浏览器中输入 URL http://localhost:8000 并回车,来访问此服务器。你会看到列出的目录的内容,点击就可以查看你想运行的 HTML 文件。

Q:如何修改服务器的默认端口?
A:可以通过运行下面的命令来指定一个端口号:

# 如果你的 Python 版本是 3.X python -m http.server    # 如果你的 Python 版本是 2.X python -m SimpleHTTPServer  

结论

方法二相比方法一来说,更简单、方便,也更灵活,而且还可以随时在终端上看到服务器的状态。

参考

  • How do you set up a local testing server? - Learn web development | MDN(推荐阅读)
  • Mac OS X 启用 Web 服务器
  • Mac自带的本地服务器的使用
  • Mac OS原来自带了apache,基本用法总结

相关内容

热门资讯

黑科技系统(wepoke软件透... 黑科技系统(wepoke软件透明演示)外挂透明挂辅助挂(透视)竟然真的是有挂(有人有挂)-哔哩哔哩1...
重大科普!德扑之星专业代打(透... 重大科普!德扑之星专业代打(透明黑科技)攻略教程(2024已更新)(哔哩哔哩)1、每个玩家都可以进行...
黑科技教程(WePoKe)微扑... 黑科技教程(WePoKe)微扑克发牌规律性总结(透明黑科技)总是是真的有挂(2023已更新)(哔哩哔...
一分钟教会你!wpk发牌(透视... 一分钟教会你!wpk发牌(透视)玩家教你(2023已更新)(哔哩哔哩);无聊就玩这款wpk发牌真的有...
辅助黑科技(云扑克德州辅助器)... 辅助黑科技(云扑克德州辅助器)外挂透明挂辅助软件(透视)好像是有挂(确实有挂)-哔哩哔哩1、金币登录...
黑科技苹果版(WePoKe)w... 黑科技苹果版(WePoKe)wepoke软件还可以用吗(透明挂)好像有挂(2025已更新)(哔哩哔哩...
分享认知!德州wepower辅... 分享认知!德州wepower辅助器ai(黑科技ai)存在挂教程(2020已更新)(哔哩哔哩)1、在德...
黑科技玄学(wpk德州ai辅助... 黑科技玄学(wpk德州ai辅助器)外挂透明挂辅助神器(透视)原来是真的有挂(有挂透视)-哔哩哔哩1、...
黑科技脚本(WePoKe)we... 黑科技脚本(WePoKe)wepower游戏有外挂吗(透明挂黑科技)确实是真的有挂(2023已更新)...
玩家必备攻略!fishpoke... 玩家必备攻略!fishpoker正规吗(ai代打)2025新版(2024已更新)(哔哩哔哩);一、f...