【.net core】yisha框架使用nginx代理swagger接口无法访问问题

后端代码配置

cs 复制代码
#在StartUp.cs文件中Configure方法中增加以下代码
app.UseSwagger(c =>
            {
                //代理路径访问
                c.PreSerializeFilters.Add((doc, item) =>
                {
                    //根据代理服务器提供的协议、地址和路由,生成api文档服务地址
                    doc.Servers = new List<OpenApiServer>
                    {
new OpenApiServer
                        {
                            //此处等同于设置接口访问路径前缀
                            //以192.168.1.33:5001/User/Login接口为例,以下代码生成内容为
                            //http://192.168.1.33:50001/oaapi/User/Login
                            //item.Scheme表示协议类型
                            //item.Host.Value表示IP地址/域名
                            //item.Headers["X-Forwarded-Port"]为nginx中配置的proxy_set_header X-Forwarded-Port $server_port内容
                            //item.Headers["X-Forwarded-Prefix"]为nginx中配置的proxy_set_header X-Forwarded-Prefix oaapi内容
                            //如果nginx配置的请求头中存在X-Forwarded-Port,则增加X-Forwarded-Port端口内容,否则则不增加
                            //如果nginx配置的请求头中存在X-Forwarded-Prefix,则增加X-Forwarded-Prefix虚拟路径内容,否则则不增加
                            Url = @$"{item.Scheme}://{item.Host.Value}
                                    {(string.IsNullOrEmpty(item.Headers["X-Forwarded-Port"].ToString() ) ? "":":" + item.Headers["X-Forwarded-Port"])}
                                    { (string.IsNullOrEmpty(item.Headers["X-Forwarded-Prefix"].ToString()) ? "" : "/" + item.Headers["X-Forwarded-Prefix"])}"
                        }
                    };
                });
                //固定路径访问
                //c.RouteTemplate = "api-doc/{documentName}/swagger.json";
            });
            app.UseSwaggerUI(c =>
            {
                //代理路径访问
                c.ShowExtensions();
                c.ValidatorUrl(null);
                //GlobalContext.SystemConfig.VirtualDirectory为appsettings中设置的VirtualDirectory内容,如无代理则设置改字段为空
                c.SwaggerEndpoint($"{GlobalContext.SystemConfig.VirtualDirectory}/swagger/{"v1"}/swagger.json", "和田玖信OA办公系统 Api v1");
                c.RoutePrefix = string.Empty;

                c.DocExpansion(DocExpansion.None);
                //固定路径访问
                //c.RoutePrefix = "api-doc";
                //c.SwaggerEndpoint("swagger/v1/swagger.json", "和田玖信OA办公系统 Api v1");
            });

Nginx配置

python 复制代码
#nginx代理设置
server {
		listen       50001;#代理后访问端口
		server_name  192.168.1.33;#服务器地址(IP/域名)
		location /oaapi/ {
				proxy_pass http://192.168.1.33:5001/;#需要代理的地址
                #配置代理header(请求头)内容
				proxy_set_header Upgrade $http_upgrade;
                proxy_set_header Connection keep-alive;
                proxy_set_header Host $host;
                proxy_set_header X-Forwarded-Proto $scheme;
                proxy_set_header X-Forwarded-Host $host;
                proxy_set_header X-Forwarded-Port $server_port;
                proxy_cache_bypass $http_upgrade;
 
                proxy_set_header X-Forwarded-Prefix oaapi;     #------其中oaapi可以更换任何路由,即为代理路径内容
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-For $remote_addr;
		}
	}
相关推荐
GDAL3 分钟前
深入理解 NJS 全局对象:掌控运行时的核心工具
nginx·njs
罗马苏丹默罕默德2 小时前
Ubuntu下部署.NetCore WebApi的方法
数据库·ubuntu·.netcore
GDAL2 小时前
精通 NJS HTTP 请求对象:全方位掌控 NGINX 请求生命周期
nginx·njs
飞翔沫沫情2 小时前
Nginx运维维护规范及全配置详解【持续更新】
nginx·nginx 配置·nginx 操作手册·nginx 使用规范·nginx 日志规范·nginx 配置文件说明
deriva3 小时前
nginx如何将某域名/二级站点/代理到二级站点?以ChirpStack实战为例
运维·nginx
睡不醒的猪儿14 小时前
nginx常见的优化配置
运维·nginx
root666/1 天前
【后端开发-nginx】proxy_pass和proxy_redirect参数作用
运维·nginx
工具罗某人1 天前
docker快速部署kafka
java·nginx·docker
864记忆2 天前
Qt创建连接注意事项
数据库·qt·nginx
lingxiao168882 天前
WebApi详解+Unity注入--中篇:.net core的WebAPI
unity·c#·.netcore