百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

从零开始搭建HTTPS服务(如何搭建http服务)

wptr33 2025-05-08 21:37 3 浏览

搭建 HTTPS 服务的最初目的是为了开发微信小程序,因为 wx.request 只允许发起 HTTPS 请求,并且还必须和指定的域名进行网络通信。要从零开始搭建一个 HTTPS 的服务需要下面 4 个要素:域名,备案,云服务器,服务搭建。本文将分别介绍这四要素的具体要求。

简介

HTTPS (Hyper Text Transfer Protocol over SecureSocket Layer)叫超文本传输安全协议,是一种通过计算机网络进行安全通信的传输协议。HTTPS 经由 HTTP 进行通信,但利用 SSL/TLS 来加密数据包。HTTPS 开发的主要目的,是提供对网站服务器的身份认证,保护交换资料的隐私与完整性。这个协议由网景公司(Netscape)在 1994 年首次提出,随后扩展到互联网上,目前基本上所有的网站都使用了 HTTPS 协议。下面就围绕域名,备案,云服务器,服务搭建这 4 个方面来从零搭建 HTTPS 服务。

域名

域名[1]Domain Name)又叫网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位。例如, blog.haojunyu.com 是一个域名,可以通过域名名称系统(Domain Name System)将该域名映射成对应的 IP 地址。该操作可以通过域名解析来实现。

域名注册和解析

域名注册前,可以通过WHOIS[2] 来查询该域名是否被注册过。目前 BAT 都提供域名注册,如阿里的万网[3],百度的域名服务[4],腾讯的Dnspod[5]。我的域名 haojunyu.com 是在阿里的万网注册的,之前注册域名的初衷是为了给 github 上面的个人博客作个性化的域名。并在其中的域名解析中作了设置,这里并不需要做太多的改动,只需要添加如下图的解析记录:

设置完成后,当我们向 https://api.haojunyu.com/* 发送请求时,DNS 会自动将其解析为映射的 IP 地址(上图中涂鸦的部分),并向目标服务器请求对应服务。

备案

这里的备案是针对像个人博客这类非经营性网站所做的备案,其目的是为了方便网站的管理。因为只有守法的网站才会对促进信息共享、文化繁荣和社会进步产生积极的作用。

目前网站域名的备案 BAT 都能提供,不过备案这个流程很长,大概要一个月,我的域名 haojunyu.com 是在百度云备案的,当时是先提交的资料(主要是身份证正反面照片),然后等百度快递来背景墙,再拍照片上传核实后才可以备案成功。

云服务器

服务器就是一台可以运行的电脑,可以是自己家里的电脑,也可以到 BAT 上买云服务。这里因为腾讯云上面有免费8天的试用,所以就试着在云服务上面搭建个 https 的服务,以方便微信小程序能成功发起 request 请求。如果试用体验还不错的话,可以续费(74元/月)。新建云主机时要选一个操作系统,鉴于对 Ubutnu 的熟悉以及服务器的需要,所以选择了 Ubuntu Server 16.04.1 LTS 64 的镜像做系统。当新建一个云主机后,百度云会提供一个对外的 IP 地址,这个 IP 地址就是域名解析中要填入的记录值。

服务搭建

服务器的配置主要有三步个,第一步是应用程序的布置,第二步是Nginx服务器的配置,第三步是 http 升级为 https 。前两步的配置是参考这篇博文在Ubuntu上使用Nginx部署Flask应用[6],第三步是参考腾讯云上Nginx证书安装[7]

应用程序

考虑到微信小程序主要是用 json 的数据,所以就想服务器能够提供 restful 服务,又因为对 python 语言比较喜欢,所以就挑了 python 里的 Flask 这个轻量级的 Web 框架。服务器选择的是 Nginx ,而连接服务器和应用程序的是 uWSGI。具体的安装步骤如下:

1.环境配置

sudo apt-get update && sudo apt-get upgrade # 更新所有软件
sudo apt-get install build-essential  # 安装编译环境
sudo apt-get install  python python-dev python-setuptools # 安装python环境
sudo easy_install pip
sudo apt-get install nginx  # 安装Nginx
sudo apt-get install uwsgi uwsgi-plugin-python  # 安装uwsgi及其插件
sudo apt-get install supervisor # 安装进程管理软件

2.应用配置

sudo mkdir -p /var/www/flaskApp # 创建应用程序文件夹
sudo chown -R ubuntu:ubuntu /var/www/flaskApp # 更改应用程序文件夹所有权
sudo pip install virtualenv # 安装python虚拟环境
# 创建python虚拟环境
cd /var/www/flaskApp
virtualenv venv
. venv/bin/activate # 激活python虚拟环境venv
pip install flask flask-restful # 在虚拟环境中安装flask Web框架

3.创建api.py代码

#!flask/bin/python
from flask import Flask, jsonify

app = Flask(__name__)

tasks = [
    {
        'id': 1,
        'title': u'Buy groceries',
        'description': u'Milk, Cheese, Pizza, Fruit, Tylenol',
        'done': False
    },
    {
        'id': 2,
        'title': u'Learn Python',
        'description': u'Need to find a good Python tutorial on the web',
        'done': False
    }
]

@app.route('/todo/api/v1.0/tasks', methods=['GET'])
def get_tasks():
    return jsonify({'tasks': tasks})

if __name__ == '__main__':
    app.run(host='0.0.0.0', port=8080)

执行脚本python api.py后可以通过浏览器来访问 http://主机
IP:8080/todo/api/v1.0/tasks,以此来获取 tasks 数据。

服务配置

Nginx配置

1.删除nginx默认配置文件

sudo rm /etc/nginx/sites-enabled/default

2.创建新的配置文件
/var/www/flaskApp/config/flaskApp_nginx.conf

server {
  listen      80;
  server_name api.haojunyu.com; #此时域名已经映射到主机IP
  charset     utf-8;
  client_max_body_size 75M;

  location / { try_files $uri @yourapplication; }
  location @yourapplication {
      include uwsgi_params;
      uwsgi_pass unix:/var/www/flaskApp/config/flaskApp_uwsgi.sock;
  }
}

3.创建配置文件服务,重启服务

sudo ln -s /var/www/flaskApp/config/nginx.conf /etc/nginx/conf.d/ #将应用文件夹里的配置文件链接到nginx配置文件处
sudo nginx -t           # 检验nginx配置是否有误
sudo nginx -s reload    # 重新加载nginx配置
sudo /etc/init.d/nginx restart  # 重启nginx

4.验证

现在通过浏览器来访问
http://api.haojunyu.com/todo/api/v1.0/tasks ,无法获取到数据,因为 flaskApp_uwsgi.sock 尚未生成,无法让 uwsgi 在 Nginx 和 python 应用程序之间构建一座桥。

uWSGI配置

1.创建新的配置文件/var/www/flaskApp/config/flaskApp_uwsgi.ini

[uwsgi]
#application's base folder
base = /var/www/flaskApp

#python module to import
app = api
module = %(app)

home = %(base)/venv
pythonpath = %(base)
## 使用virtualenvwrapper管理virtualenv后用下面的两个参数取代home和pythonpath
#chdir = %(base)
#virtualenvs = %HOME/.virtualenvs/flaskEnv

#socket file's location
socket = /var/www/flaskApp/%n.sock

#permissions for the socket file
chmod-socket    = 666

#the variable that holds a flask application inside the module imported at line #6
callable = app

#location of log files
logto = /var/log/uwsgi/%n.log

2.创建uWSGI日志文件夹,并更改文件所有权

sudo mkdir -p /var/log/uwsgi # uWSGI日志文件夹
sudo chown -R ubuntu:ubuntu /var/log/uwsgi # 更改uWSGI日志文件夹所有权
uwsgi --ini /var/www/flaskApp/config/flaskApp_uwsgi.ini --plugin python & # 后台启动uwsgi

supervisor配置

supervisor 是为了方便管理进程而存在的,因为每次开机后,都得重新执行 uwsgi --ini /var/www/flaskApp/config/flaskApp_uwsgi.ini 命令来启动 uwsgi ,这个很费神,因为你不可能永远记得清楚这么个应用,这么个配置。所以使用 supervisor 来管理,而我们只需要在开发这个应用时创建一个 flaskApp_supervisor.conf 配置文件,而重启机器后启动 supervisor 服务,即执行 sudo service supervisor start

1.安装 supervisor

sudo apt install supervisor

2.创建配置文件:

[program:flaskApp]
# 启动命令入口
command=/usr/local/bin/uwsgi --ini /var/www/flaskApp/flaskApp_uwsgi.ini
# 运行命令的用户名
user=ubuntu
autostart=true
autorestat=true
#日志地址
stdout_logfile=/var/log/supervisor/flaskApp_supervisor.log

3.创建配置文件副本并重启服务

sudo ln -s /var/www/flaskApp/flaskApp_supervisor.conf /etc/supervisor/conf.d/
sudo service supervisor restart

HTTP 升级 HTTPS

升级 HTTP 需要证书的支持,这里 BAT 都提供这样的服务,都有相对应的配置安装说明。我这里是按照 腾讯云上Nginx证书安装[8],主要就是将申请的证书保存到 config 目录中,并将 flaskApp_nginx.conf 修改如下:

server {
  listen 80;
  server_name api.haojunyu.com;
  return 301 https://api.haojunyu.com$request_uri;
}

server {
  listen      443 ssl;
  server_name api.haojunyu.com; #此时域名已经映射到主机IP

  ssl on;
  ssl_certificate /var/www/flaskApp/1_haojunyu.com_bundle.crt;
  ssl_certificate_key /var/www/flaskApp/2_haojunyu.com.key;
  ssl_session_timeout 5m;
  ssl_protocols TLSv1 TLSv1.1 TLSv1.2; #按照这个协议配置
  ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;#按照这个套件配置
  ssl_prefer_server_ciphers on;

  location / { try_files $uri @yourapplication; }
  location @yourapplication {
      include uwsgi_params;
      uwsgi_pass unix:/var/www/flaskApp/config/flaskApp_uwsgi.sock;
  }
}

当时 SSL 的证书有免费的可以用,限制就是一个证书只能帮忙一个二级域名或子域名。如果愿意折腾,可以使用 certbot[9] 来自动化来配置 SSL 证书和定时更新。

详细的安装配置步骤可以参考官网(需要选择代理软件 nginx/apache 等和操作系统 Ubuntu/CentOS/MacOS 等)。

# 安装命令
sudo apt install certbot python-certbot-nginx  # cerbot及其插件

# 配置域名 
sudo certbot certonly --nginx --cert-name haojunyu.com -d api.haojunyu.com
# 删除配置的域名
sudo certbot delete --cert-name haojunyu.com
# 查看配置的域名
sudo certbot certificates
# 更新证书
sudo certbot renew --dry-run

最终效果如下图所示, 访问
https://api.haojunyu.com/todo/api/v1.0/tasks 可以获得对应的数据。

参考文献

1.wiki-域名[10]

2.whois域名查询[11]

3.万网[12]

4.百度域名服务[13]

5.Dnspod[14]

6.在Ubuntu上使用Nginx部署Flask应用[15]

7.腾讯云上Nginx证书安装[16]

8.certbot[17]

References

[1] 域名: https://zh.wikipedia.org/wiki/%E5%9F%9F%E5%90%8D
[2] WHOIS:
https://who.is/
[3] 万网:
https://wanwang.aliyun.com/?spm=5176.8142029.388261.26.C75xLA
[4] 域名服务:
https://cloud.baidu.com/product/bcd.html
[5] Dnspod:
https://dnspod.qcloud.com/?from=console
[6] 在Ubuntu上使用Nginx部署Flask应用:
https://www.oschina.net/translate/serving-flask-with-nginx-on-ubuntu
[7] 腾讯云上Nginx证书安装:
https://www.qcloud.com/document/product/400/4143#2.-nginx-.E8.AF.81.E4.B9.A6.E9.83.A8.E7.BD.B2
[8] 腾讯云上Nginx证书安装:
https://www.qcloud.com/document/product/400/4143#2.-nginx-.E8.AF.81.E4.B9.A6.E9.83.A8.E7.BD.B2
[9] certbot:
https://certbot.eff.org/
[10] wiki-域名:
https://zh.wikipedia.org/wiki/%E5%9F%9F%E5%90%8D
[11] whois域名查询:
https://who.is/
[12] 万网:
https://wanwang.aliyun.com/?spm=5176.8142029.388261.26.C75xLA
[13] 百度域名服务:
https://cloud.baidu.com/product/bcd.html
[14] Dnspod:
https://dnspod.qcloud.com/?from=console
[15] 在Ubuntu上使用Nginx部署Flask应用:
https://www.oschina.net/translate/serving-flask-with-nginx-on-ubuntu
[16] 腾讯云上Nginx证书安装:
https://www.qcloud.com/document/product/400/4143#2.-nginx-.E8.AF.81.E4.B9.A6.E9.83.A8.E7.BD.B2
[17] certbot:
https://certbot.eff.org/


如果该文章对您产生了帮助,或者您对技术文章感兴趣,可以关注微信公众号: 技术茶话会, 能够第一时间收到相关的技术文章,谢谢!

相关推荐

在python中用于处理用户界面的方法除了Tkinter外还有哪几种?

Python是一种通用编程语言,它本身不直接提供UI(用户界面)功能,也就是说,如果你只安装了python,那恐怕只能用命令行来运行命令,那谁受得了啊。要知道linux就是因为用户界面不够强大,...

【AI大模型】:结合wxauto实现智能微信聊天机器人

文章目录...

wxPython - 布局管理简介及绝对位置布局

实战wxPython系列-009一个典型的GUI程序的窗口界面中,一般是由各种控件(或者部件)组成,这些部件一般都会按一定的布局呈现在窗口中。布局方式可以分为绝对定位布局和相对定位布局,绝对定位布局中...

wxpython入门第五步(组件)(wxpython控件大全)

Widgets在本节中,我们将介绍wxPython中的基本widgets。每个组件都会有一个小的代码示例。wxPython中有很多不同的组件,包括按钮、复选框、滑块和列表框。wx.Buttonwx....

python+kivy实现极致的跨平台跨终端开发体验

这几天查找python资料的时候,偶然发现了一个专为python打造的gui框架:kivy。这是一个很优秀的,基于python的GUI框架。可以利用Python快速编程的特点,快速编写应用程序。它可以...

Python GUI库大盘点,9款热门框架供您选择!

GUI(图形用户界面,GraphicalUserInterface)是一种允许用户通过图形元素(如图标、按钮、窗口等)与电子设备进行交互的用户界面。...

第10天 | 25天学会wxPython,事件处理

事件,就是程序在运行中发生的事儿,桌面应用软件都是事件驱动的。事件可以是用户的操作,如鼠标点击或按键按下,也可以由系统产生,如定时关机。事件会触发相应的行为,即事件函数。...

从零开始搭建HTTPS服务(如何搭建http服务)

搭建HTTPS服务的最初目的是为了开发微信小程序,因为wx.request只允许发起HTTPS请求,并且还必须和指定的域名进行网络通信。要从零开始搭建一个HTTPS的服务需要下面4...

如何将AI助手接入微信(打开ai手机助手)

Dify平台搭建好后就可以创建各种应用,如聊天助手、文本生成、Agent、工作流等,那这些AI助手我们能不能分享给朋友使用,如接入微信、企微等?工具介绍DifyOnWeCha...

python gui编程框架推荐以及介绍(python开发框架)

Python的GUI编程框架有很多,这里为您推荐几个常用且功能强大的框架:Tkinter:Tkinter是Python的标准GUI库,它是Python内置的模块,无需额外安装。它使用简单,功能较为基础...

Python 程序发送微信(python程序如何发布)

在一些日常办公场景中,需要定时自动通知指定账户的微信信息及文件,如果账户很多,可能存在遗漏的情况,借助于以下的Python程序,则可以满足要求。运行时,需保证本地微信已安装并处于登录状态。#se...

美化Python GUI界面!让你的窗口拥有Win11般的质感 | pywinstyles

1.PythonGUI外观个性化的福音在使用Python开发GUI时,我们经常会使用如Tkinter、PyQt等常见的库,然而这些库的默认界面总显得有些...普通。而如果你想让你的PythonG...

推荐10款Python图形界面(GUI)框架

图形用户界面(GUI)是用户打开应用程序或网站时的第一印象,这通常包括图标、按钮、图形、显示文本等多种视觉元素,是用户体验的重要组成部分。Python就有大量用于开发GUI的框架,下面给大家介绍10个...

开发图形界面Tkinter、wxPython、PyQt、PySide选哪一个?

  学习Python,就不得不提一下Python的图形界面开发,如果只用命令行写程序,用户体验不太好,难以胜任复杂的人机交互场景。Python的图形界面开发库常用的有:Tkinter、wxPython...

利用Python开发App实战(如何用python开发app)

我很早之前就想开发一款app玩玩,无奈对java不够熟悉,之前也没有开发app的经验,因此一直耽搁了。最近想到尝试用python开发一款app,google搜索了一番后,发现确实有路可寻,目前也有了一...