- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在部署应用程序时遇到问题。我会尽力提供尽可能多的信息。
API 项目同时使用了 Swagger via Swashbuckle 和 CaSTLe Windsor。
当通过 SwaggerConfig.cs 启用 Swagger 时
我们得到以下异常:
[assembly: PreApplicationStartMethod(typeof(SwaggerConfig), "Register")]
Method not found: 'Void Swashbuckle.Application.SwaggerDocsConfig.RootUrl(System.Func`2<System.Net.Http.HttpRequestMessage,System.String>)'.
这是完整的注册调用,以防相关
GlobalConfiguration.Configuration
.EnableSwagger(c =>
{
c.RootUrl(req => req.RequestUri.GetLeftPart(UriPartial.Authority) + "/api");
c.MultipleApiVersions((api, v) => true,
vc =>
{
vc.Version("mobile", "Mobile");
vc.Version("web", "Web");
});
c.UseFullTypeNameInSchemaIds();
c.DescribeAllEnumsAsStrings();
c.DocumentFilter<VersionFilter>();
})
.EnableSwaggerUi(c =>
{
c.EnableDiscoveryUrlSelector();
});
如果我们禁用 swagger(通过删除程序集属性),应用程序将在 CaSTLe Windsor 启动时开始失败,并出现以下错误:
Method 'Create' in Type 'XXX.XXX.XXX.CastleWindsor.WindsorCompositionRoot' from assembly 'xxx.xxx.Backend, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null' does not have an implementation.'
这是 WindsorConfig.cs 的 Configure() 方法
public static void Configure()
{
WindsorConfig.Container = new WindsorContainer();
WindsorConfig.Container.Install(FromAssembly.This());
System.Web.Http.GlobalConfiguration.Configuration.Services.Replace(typeof(IHttpControllerActivator), new WindsorCompositionRoot(WindsorConfig.Container));
}
当我们将解决方案中的共享库从 PCL 升级到 .net standard 2 时,出现了此问题。这反过来意味着我们必须将解决方案中的所有其他项目升级到.net 4.7.1(解决方案中有一个 UWP 应用程序,这是我们最初的升级目标,这意味着我们必须升级库,但我离题了) ,总而言之,这个问题发生在 4.7.1 升级上。
应用程序通过 Bamboo w/msbuild 和 msdeploy 部署到 Azure。我们确信二进制文件和 web.config 与开发同步,因为我们已经通过 FTP 手动部署了它们。在重新上传之前,我通过 FTP 删除了所有二进制文件,以确保不存在遗留程序集。
我已验证 Kudu 中的 Azure 应用程序显示正确的版本以支持 4.7.1,如下所述:https://github.com/Azure/app-service-announcements/issues/63
未运行的应用程序将部署到 Azure 中应用程序服务的虚拟目录 (/api) 中。主网站(位于/)是静态的,并使用 Angular 访问 API。
我已经确认/和/api 项目中的 web.config 都显示
<compilation targetFramework="4.7.1" />
<httpRuntime targetFramework="4.7.1" />
软件包版本如下(我们在目标框架升级后执行了nuget重新安装):
<package id="Castle.Core" version="3.3.0" targetFramework="net471" />
<package id="Castle.Windsor" version="3.3.0" targetFramework="net471" />
<package id="Castle.Windsor.Lifestyles" version="0.4.0" targetFramework="net471" />
<package id="Swashbuckle" version="5.3.2" targetFramework="net471" />
<package id="Swashbuckle.Core" version="5.3.2" targetFramework="net471" />
之前,当我尝试升级到 4.7.1(用于另一个依赖项)时,我在开发环境中遇到了这个问题,但这次开发工作正常,没有错误,只是现在部署到 Azure 时才失败。此应用服务的 Azure 门户中的 .net 框架版本显示为 4.7
现在,我认为问题实际上并不是我们用来初始化 Swagger 和/或 CaSTLe Windsor 的代码,它更可能与框架版本或不匹配的程序集版本有关,因为该应用程序正在我的计算机上运行开发机器没有错误,但我已经不知道接下来要尝试什么了。
最佳答案
我发现了这个问题https://forums.asp.net/t/2137242.aspx通过搜索温莎错误,System.Web.Http.Dispatcher.IHttpControllerActivator
无法实例化并出现错误 Method 'Create' in type 'MyType' from assembly 'MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null' does not have an implementation.
这让我检查System.Net.Http
已部署的版本。 System.Net.Http
是4.2.0.0
在本地,此 DLL 已部署到 Azure,但运行时实际上似乎使用了不同的版本。
奇怪的是,当我从bin文件夹中删除System.Net.Http的部署版本时,错误提示:'System.Net.Http, Version=4.2.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a
因此,无论 bin 文件夹中的版本如何(也是 4.2.0.0),这都是 Azure 提供的程序集版本。
我为 System.Net.Http 添加了绑定(bind)重定向,应用程序现在正常启动
<dependentAssembly>
<assemblyIdentity name="System.Net.Http" publicKeyToken="b03f5f7f11d50a3a" culture="neutral"/>
<bindingRedirect oldVersion="0.0.0.0-4.2.0.0" newVersion="4.2.0.0"/>
</dependentAssembly>
关于c# - 来自 Swagger 和 CaSTLeWindsor 的 Azure 运行时错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51014010/
我试图在我的微服务项目中生成一个单一的 swagger,在 Api 网关中将所有服务 swagger 聚合成一个单一的服务。为了实现这一点,我正在学习下一个教程 https://objectpartn
我的任务是将 Swagger 安装到 Web API 项目中。 已安装:来自 nuget 的最新版本的 Swashbuckle。 (Swashbuckle.Core.Net45 和 Swashbuck
我正在编写一个 swagger 规范,并且我有三个独立的端点。我如何在文档中将它们分开?我想明确区分示例:用户、帖子和其他。所以每个人都会有一个 CRUD 描述并显示在 swagger UI 中,它看
我试图在 Swagger 中定义一个查询参数,其中包含来自预定义项目集的逗号分隔字符串,例如 ?fruits=Apples,Oranges,Bananas但我从 swagger 编辑器收到以下错误 s
我正在使用 go-swagger 来生成 API 服务器。我注意到从 swagger.yml 生成的 json 被保存在 restapi/embedded_spec.go 中. 公开该 JSON 规范
我使用的是 springfox 版本 2.9.2 和 swagger 注释 1.5.x。 ApiModel 注释支持鉴别器、子类型和父属性,这些是使多态性工作所需的,但我没有看到生成的正确的 apid
我正在尝试使用本地 swagger.json 文件在 swagger 文档中显示。 我的 swagger.json 文件位于/home/user1/swagger-ui/dist/swagger.js
我们有一些数字字段,由于遗留原因,它们具有隐式长度限制。 给定一个长度限制为 5 的数字字段,显而易见的方法是将最大值设置为 99999,但是有没有办法在 swagger 规范中指定 1.111 可以
我们的项目为单个 API 使用多个 swagger 文件,但看起来 swagger-codegen 只接受一个。在这种情况下,我们如何使用 swagger-codegen 生成代码? 最佳答案 您可以
我正在尝试使用 https://github.com/swagger-api/swagger-codegen 生成 nodejs 客户端 sdk这是我使用的命令 swagger-codegen gen
我定义了一个以 MyObject 作为参数的路径。 MyObject 具有猫和狗的属性。这些有默认值。 在 swagger-editor 中,该示例不显示默认值,但试用确实创建了一个具有正确默认值的
我最近从 Swashbuckle 过渡到 Swagger-Net .进行更改后我遇到的一个问题是,现在我无法调用需要在 Authorization header 中发送 token 的 API。下面是
正在使用 AspNetCore 为使用 IIS 托管的 Web 应用程序设置 swagger。 .json 页面加载并且似乎可以很好地接触所有 API,但是当导航到 {localhost}/swagg
我想将任何复杂的 swagger-API-document(swagger.json) 解析为 Java 对象。 可能是列表> 有哪些可用选项? 我正在尝试使用 io.swagger.parser.S
我要将我的 API 服务器集成到 Google Cloud Endpoints。 到目前为止,Google Cloud Endpoints 支持 swagger 2.0。 但是我的依赖项/库现在是 u
我是 swagger 的新手,发现有两个用于 swagger 注释的包:io.swagger.annotations 和 com.wordnik.swagger.annotations。我想知道它们之
好的,我有许多 io.swagger.models.Swagger 对象,我已将它们合并到一个新的 super Swagger 中。现在我想要 super html。我怎样才能得到这个?请注意,为了获
我们当前的部署模式要求我手动编写 swagger json 输出,该输出将由我公司使用的基于 Swagger 的 UI 使用。我希望我正在编写的 json 能够提供“默认”值来填充所有输入字段(包括
我有以下 HTTP 触发的 Azure 函数。我已经使用此链接为我的端点设置了 Swagger here .以下 API 需要一组查询字符串参数,即 "name"、"email"、"phone",因此
我正在努力让 Swagger 正确呈现我的 ServiceStack 服务。 我希望看到一个 UserId 字符串作为表单参数,一个 PrivateCustomer 对象作为主体参数,但是尽管 Use
我是一名优秀的程序员,十分优秀!