Asp.net Core Kestrel 免費實現https

来源:https://www.cnblogs.com/jionsoft/archive/2020/04/03/12624867.html
-Advertisement-
Play Games

0、概述 先瞭解下https是個啥: https://www.bilibili.com/video/BV1j7411H7vV so!只要給我們的web伺服器配置一個證書就行了,證書可以買,也可以用免費的Let's Encrypt,此證書提供商是多個牛X大公司為了推進全球https化搞出來的,所以不用 ...


0、概述

先瞭解下https是個啥:  https://www.bilibili.com/video/BV1j7411H7vV

so!只要給我們的web伺服器配置一個證書就行了,證書可以買,也可以用免費的Let's Encrypt,此證書提供商是多個牛X大公司為了推進全球https化搞出來的,所以不用擔心免費的會有啥問題。唯一的問題是90天有效期,所以你得提前免費續簽,當然有辦法容易的實現自動續簽。
為了實現自動化的證書申請、發放、續簽、刪除.....各種證書相關的功能,所以Let's Encrypt提出了個ACME協議,不同編程語言都可以實現這個協議來完成這些工作。本文要講的內容就是這種方式。某隻大牛在github上開源了一個庫,這個庫實現了前面說的這個什麼協議,實現了自動申請證書,自動續簽、自動與asp.net core內置Kestrel集成。僅僅需要幾行配置。

asp.net core 有多種發佈模式

 

這種方式需要給IIS或Nginx..配置證書,其中IIS首選用win-acme,這個工具也實現上面說的ACME協議,使用它可以很容易在IIS中安裝Let's Encrypt證書,並實現自動續簽


 

我現在用的這種方式,伺服器上啥都不裝,直接一個發佈好的asp.net core程式(一個文件夾)丟到伺服器上,啟動裡面的.exe就可以運行。主要是因為簡單,方便移動。

在這種方式下,如果能在應用程式內部實現ACME協議自動申請證書然後配置給Kestrel,並實現自動續簽,就完美了。然後github上搜出倆比較成熟的:ACMESharpCore LetsEncrypt ,我使用的後面這種方式。我只是用的windowserver發佈的,應該支持跨平臺的,因為它只是一個庫

 

1、創建項目

首先創建一個asp.net core 3.1的程式(mvc razorPages都行)

2、添加包引用

然後添加nuget包 paket add McMaster.AspNetCore.LetsEncrypt --version 0.3.0 

3、啟動配置

然後在Startup中配置

1 using Microsoft.Extensions.DependencyInjection;
2 
3 public class Startup
4 {
5     public void ConfigureServices(IServiceCollection services)
6     {
7         services.AddLetsEncrypt();
8     }
9 }

下麵是配置文件

 1 // appsettings.json
 2 {
 3     "LetsEncrypt": {
 4         // Set this to automatically accept Let's Encrypt's terms of service.
 5         // If you don't set this in config, you will need to press "y" whenever the application starts
 6         "AcceptTermsOfService": true,
 7 
 8         // 申請證書要綁定的功能變數名稱,闊以多個,不能寫埠哦
 9         "DomainNames": [ "example.com", "www.example.com" ],
10 
11         // You must specify an email address to register with letsencrypt.org
12         "EmailAddress": "[email protected]"
13     },
14     "urls":"http://*;https://*"
15 }

 

4、發佈

 

根據你的方式選,我這裡選擇獨立模式,發佈後的程式里就自動包含了.net core運行時,所以包比較大,但是不需要伺服器安裝.net core,發佈好的包放哪都能直接運行。
目標運行時看著選,也可以發佈層跨平臺的通用包,詳細的看官網吧。

5、運行

找到那個xxx.exe 直接啟動就可以了,內部那個庫會自動去申請證書並設置到Kestrel上,申請時會驗證功能變數名稱,我估計就是簡單訪問下這個功能變數名稱看能不能正常訪問,所以一定要保證你配置的功能變數名稱都能正常訪問。如果一切正常就可以通過https訪問了。估計到期前會自動續簽證書,得3個月後才能驗證。

 

6、最後

做個備忘,回頭看這種方式真TM簡單,引用庫、配置、發佈。文件夾複製到哪都能運行,還自帶https。比如 做點微信小程式開發 美滋滋


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 經過數十天的忙碌,今天終於有時間寫博客。 前面一章通過介紹有關模板工作方式相關的內容,同時介紹了FrameWorkElement下所有控制項的模板。接下來將介紹如何構建一個簡單的自定義按鈕,併在該過程中學習有關控制項模板的一些細節。 通過上一章內容,基本Button控制項使用ButtonChrome類繪製 ...
  • 問題: 還是升級到3.1的問題,直接上圖,現象如下: 我們的系統里,有一些查詢條件是從枚舉轉化過來的,但是為了統一,界面渲染的時候追加了一個“請選擇”,value為-999,這種場景很多很多, 可以看到-999不在枚舉的定義里,只要我以當前選擇狀態提交請求,後端全局的modal valid就會報錯, ...
  • .NET Core 概述 .NET Core是一個免費的、開源的、跨平臺的、廣泛使用的Web框架;它是由微軟維護的。社區廣泛參與支持的一個框架。.NET Core可以運行在:Windows、MacOS以及Linux操作系統上。 .Net Core可以用來開發各種不同的應用程式,例如:移動端、桌面端、 ...
  • 一、環境搭建 1.1、由於RabbitMQ是使用Erlang語言開發的,因此要安裝Erlang運行時環境,下載地址:Erlang官網下載 CSDN分享下載 1.2、去RabbitMQ官網下載RabbitMQ Server服務端程式,選擇合適的平臺版本下載並安裝。 RabbitMQ安裝時,會自動在Wi ...
  • 我在面試別人的時候,經常會問對方,如何設計一個秒殺系統?回答的好的同學並不多,這裡我簡要說一下考察這個問題的目的.秒殺系統,那麼顧名思義就是搶購,庫存有限情況下的競爭問題,其實就是一個高併發的處理. 首先我們模擬不做併發處理的情況: 比如我們用戶一個庫存表 stock,庫存數量5 我們對外提供了一個 ...
  • 本文介紹通過C# 編程如何在PPT幻燈片中添加超鏈接的方法,添加鏈接時,可給文本或者圖片添加超鏈接,鏈接對象可指向網頁地址、郵件地址、指定幻燈片等,此外,也可以參考文中編輯、刪除幻燈片中已有超鏈接的方法。 程式使用類庫:Free Spire.Presentation for .NET (免費版) d ...
  • 如何處理幾十萬條併發數據? 答:用存儲過程或事務。取得最大標識的時候同時更新..註意主鍵不是自增量方式這種方法併發的時候是不會有重覆主鍵的..取得最大標識要有一個存儲過程來獲取. 2.寫出一條Sql語句,取出表A中第31到第40記錄(SQLServer,以自動增長的ID作為主鍵,註意:數據不是連續的 ...
  • 有時我們臨時需要一個 JSON 字元串,直接拼接肯定不是好方法,但又懶得去定義一個類,這是用 就會非常的方便。 但是在 中添加數組卻經常被坑。 輸出結果: 非常正確,但如果把 換成 就不對了。 這麼寫會報: Could not determine JSON object type for type ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...