把Web Api OData移植到Asp.Net Core(5)-https

2023-11-03 18:10
文章标签 https web core 移植 api asp net odata

本文主要是介绍把Web Api OData移植到Asp.Net Core(5)-https,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

OData网站如果采用http明文传输,安全性很差,最好采用https加密传输。服务端要使用SSL证书。
在开发阶段,可以使用自签名SSL证书用于软件调试和测试。如果只有PC和移动客户端,可以在发布后继续使用自签名证书。如果有网页客户端,用户会在浏览器看到网站的证书信息,为了给用户一个安全的体验,必须购买正式的SSL证书。

1. 创建自签名SSL证书

如果网站部署在Windows Server,可以在IIS中直接创建自签名证书,非常简单。
Linux服务器创建自签名证书不像IIS这么方便。如果直接在Linux系统里创建自签名证书,需要下载,安装一堆东西,甚至可能还要重新编译,比较繁琐。其实,完全可以在Windows系统里创建自签名证书,然后拿到Linux系统去使用。
在以下网站下载openssl的Windows安装包。
https://slproweb.com/products/Win32OpenSSL.html
如果下载慢可以用迅雷。
这里写图片描述

下载后直接安装,全部默认好了。
然后以管理器权限打开控制台,输入以下命令创建自签名证书。如果提示密码,输入xxx,这个以后会用到。这个证书采用sha256算法,有效期365天。

C:\OpenSSL-Win64\bin\openssl req -x509 -sha256 -nodes -days 365 -newkey rsa:2048 -keyout myweb.key -out myweb.crt -subj /CN=*.myweb.com
C:\OpenSSL-Win64\bin\openssl pkcs12 -export -out myweb.pfx -inkey myweb.key -in myweb.crt

然后可以得到3个文件。后面要用到。
myweb.crt
myweb.key
myweb.pfx

2. 修改网站代码支持https

为了简单起见,直接修改Program.cs,整个网站都使用https传输。

    public static IWebHost BuildWebHost(string[] args) =>WebHost.CreateDefaultBuilder(args).UseKestrel(ConfigHttps)//必须指定端口,否则在Win10命令行运行端口是5000,在CentOS docker运行端口是80//.UseUrls("http://*:5000").UseStartup<Startup>().Build();private static void ConfigHttps(KestrelServerOptions options){options.Listen(IPAddress.Any, 5000, listenOptions =>{//填入pfx文件路径和指定的密码string pfxFile = Path.Combine(Directory.GetCurrentDirectory(), "myweb.pfx");listenOptions.UseHttps(pfxFile, "xxx");});}

给项目添加myweb.pfx,设置属性为【如果较新则复制】,生成操作为【内容】。重新发布网站。运行网站,访问https://localhost:5000/odata/Books,浏览器会提示网站不安全。
这里写图片描述

点击继续转到网页,浏览器地址栏提示证书错误,点击该信息会提示网站问题。
这里写图片描述

如果购买了正式的证书,浏览器地址栏会提示一把锁,例如访问百度网站:
这里写图片描述

3. docker网站采用SSL证书

修改nginx配置文件。需要用到2个证书文件。

server {listen 9000 ssl;ssl_certificate      myweb.crt;ssl_certificate_key  myweb.key;location / {proxy_pass https://odataweb-service:5000;proxy_http_version 1.1;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection keep-alive;proxy_set_header Host $host;proxy_cache_bypass $http_upgrade;}

修改docker-compose.yml文件。挂载当前目录下的2个证书文件给nginx容器使用。

version: '3'services:mysql-service:container_name: mysqlserviceimage: mysqlenvironment:- MYSQL_ROOT_PASSWORD=xxx
    volumes:- ./data:/var/lib/mysql
    restart: alwaysodataweb-service:container_name: odatawebserviceimage: odatawebimagebuild:context: ./odatawebdockerfile: Dockerfileenvironment:- ASPNETCORE_ENVIRONMENT=Development
    restart: alwaysdepends_on:- mysql-service
    links:- mysql-service
nginx-proxy:container_name: nginxproxyimage: nginx    ports:- "9000:9000"
    volumes:- ./nginx.conf:/etc/nginx/conf.d/default.conf
      - ./myweb.crt:/etc/nginx/myweb.crt
      - ./myweb.key:/etc/nginx/myweb.key
    restart: alwayslinks:- odataweb-service

然后把myweb.crt、myweb.key放在docker-compose.yml相同的目录下,在Linux系统里重新创建、运行容器。
访问https://192.168.80.134:9000/odata/Books,检查结果。

4. 客户端访问https网站

新建Winform项目WinODataClient。
OData Client Code Generator还没有发布支持VS2017的版本,改用Simple.OData.Client封装客户端对OData服务器的访问。
NuGet安装Simple.OData.V4.Client 4.29.0。
做一个简单的CURD测试。

    private Uri DataUri = new Uri("https://192.168.80.134:9000/odata");private ODataClientSettings settings;private void frmMain_Load(object sender, EventArgs e){//允许访问https网站,对http访问无干扰ServicePointManager.ServerCertificateValidationCallback = delegate { return true; };//初始化OData客户端settings = new ODataClientSettings(DataUri);settings.PayloadFormat = ODataPayloadFormat.Json;settings.RequestTimeout = TimeSpan.FromSeconds(30);btnRefresh.Click += async (ss, ee) =>{var client = new ODataClient(settings);var result = await client.For<Book>().FindEntriesAsync();var books = result.ToList();this.dataGridViewBook.DataSource = books;};btnQuery.Click += async (ss, ee) =>{var client = new ODataClient(settings);var query = client.For<Book>("Books");//query.Skip(2).Top(2);//分页query.OrderBy(x => x.Price);//排序query.Filter(x => x.Author == "金庸");//条件var result = await query.FindEntriesAsync();var books = result.ToList();this.dataGridViewBook.DataSource = books;};btnAdd.Click += async (ss, EnumerableExecutor) =>{var client = new ODataClient(settings);Book book = new Book() { Name = "绝绝代双骄", PublishDate = new DateTime(1957, 10, 1), Author = "古龙", Price = 10.5f };var result = await client.For<Book>().Set(book).InsertEntryAsync(true);};btnEdit.Click += async (ss, ee) =>{var client = new ODataClient(settings);var result = await client.For<Book>().Key(1).Set(new { Price = DateTime.Now.Second }).UpdateEntryAsync(true);};btnDel.Click += async (ss, ee) =>{var client = new ODataClient(settings);await client.For<Book>().Key(1).DeleteEntryAsync();};}

运行软件报错:
Unable to load OData adapter from assembly Simple.OData.Client.V4.Adapter
FileLoadException: 未能加载文件或程序集“Microsoft.OData.Edm, Version=6.17.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35”或它的某一个依赖项。找到的程序集清单定义与程序集引用不匹配。 (异常来自 HRESULT:0x80131040)
Simple.OData.Client 4.29.0版本要求的Microsoft.OData.Edm至少要6.17.0,但是NuGet安装的时候只安装了6.0.0,在NuGet管理器中把Microsoft.OData.Core升级到6.17.0,它会自动升级2个关联库Microsoft.OData.Edm和Microsoft.Spatial到6.17.0,然后再次运行没问题了。

这篇关于把Web Api OData移植到Asp.Net Core(5)-https的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/339952

相关文章

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

Java Web指的是什么

Java Web指的是使用Java技术进行Web开发的一种方式。Java在Web开发领域有着广泛的应用,主要通过Java EE(Enterprise Edition)平台来实现。  主要特点和技术包括: 1. Servlets和JSP:     Servlets 是Java编写的服务器端程序,用于处理客户端请求和生成动态网页内容。     JSP(JavaServer Pages)

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

2、PF-Net点云补全

2、PF-Net 点云补全 PF-Net论文链接:PF-Net PF-Net (Point Fractal Network for 3D Point Cloud Completion)是一种专门为三维点云补全设计的深度学习模型。点云补全实际上和图片补全是一个逻辑,都是采用GAN模型的思想来进行补全,在图片补全中,将部分像素点删除并且标记,然后卷积特征提取预测、判别器判别,来训练模型,生成的像

BUUCTF靶场[web][极客大挑战 2019]Http、[HCTF 2018]admin

目录   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 [web][HCTF 2018]admin 考点:弱密码字典爆破 四种方法:   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 访问环境 老规矩,我们先查看源代码

EasyPlayer.js网页H5 Web js播放器能力合集

最近遇到一个需求,要求做一款播放器,发现能力上跟EasyPlayer.js基本一致,满足要求: 需求 功性能 分类 需求描述 功能 预览 分屏模式 单分屏(单屏/全屏) 多分屏(2*2) 多分屏(3*3) 多分屏(4*4) 播放控制 播放(单个或全部) 暂停(暂停时展示最后一帧画面) 停止(单个或全部) 声音控制(开关/音量调节) 主辅码流切换 辅助功能 屏

9.8javaweb项目总结

1.主界面用户信息显示 登录成功后,将用户信息存储在记录在 localStorage中,然后进入界面之前通过js来渲染主界面 存储用户信息 将用户信息渲染在主界面上,并且头像设置跳转,到个人资料界面 这里数据库中还没有设置相关信息 2.模糊查找 检测输入框是否有变更,有的话调用方法,进行查找 发送检测请求,然后接收的时候设置最多显示四个类似的搜索结果

消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法

消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法   消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法 [转载]原地址:http://blog.csdn.net/x605940745/article/details/17911115 消除SDK更新时的“

【LabVIEW学习篇 - 21】:DLL与API的调用

文章目录 DLL与API调用DLLAPIDLL的调用 DLL与API调用 LabVIEW虽然已经足够强大,但不同的语言在不同领域都有着自己的优势,为了强强联合,LabVIEW提供了强大的外部程序接口能力,包括DLL、CIN(C语言接口)、ActiveX、.NET、MATLAB等等。通过DLL可以使用户很方便地调用C、C++、C#、VB等编程语言写的程序以及windows自带的大

FreeRTOS-基本介绍和移植STM32

FreeRTOS-基本介绍和STM32移植 一、裸机开发和操作系统开发介绍二、任务调度和任务状态介绍2.1 任务调度2.1.1 抢占式调度2.1.2 时间片调度 2.2 任务状态 三、FreeRTOS源码和移植STM323.1 FreeRTOS源码3.2 FreeRTOS移植STM323.2.1 代码移植3.2.2 时钟中断配置 一、裸机开发和操作系统开发介绍 裸机:前后台系