前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >CA1054:URI 参数不应为字符串

CA1054:URI 参数不应为字符串

作者头像
呆呆
发布2022-01-10 09:28:58
5660
发布2022-01-10 09:28:58
举报
文章被收录于专栏:centosDai

规则 ID

CA1054

类别

设计

修复是中断修复还是非中断修复

重大

原因

类型声明一个方法,该方法具有名称中包含“uri”、“Uri”、“urn”、“Urn”、“url”或“Url”的字符串参数,且类型未声明采用 System.Uri 参数的相应重载。

默认情况下,此规则仅查看外部可见的类型,但这是可配置的。

规则说明

此规则根据 Camel 大小写约定将参数名称拆分为标记,并检查每个标记是否等于“uri”、“Uri”、“urn”、“Urn”、“url”或“Url”。 如果存在匹配项,此规则假定该参数表示统一资源标识符 (URI)。 URI 的字符串表示形式容易导致分析和编码错误,并且可造成安全漏洞。 如果某方法采用 URI 的字符串表示形式,则应提供采用 Uri 类的实例的相应重载,该类以安全的方式提供这些服务。

如何解决冲突

若要解决此规则的冲突,请将参数更改为 Uri 类型;这是一项中断性变更。 或者,提供采用 Uri 参数的方法的重载;这是一项非中断性变更。

何时禁止显示警告

如果该参数不表示 URL,则可以安全地禁止显示此规则的警告。

配置代码以进行分析

使用下面的选项来配置代码库的哪些部分要运行此规则。

包含特定的 API 图面

你可以仅为此规则、为所有规则或为此类别中的所有规则配置此选项(设计)。 有关详细信息,请参阅代码质量规则配置选项。

包含特定的 API 图面

你可以根据代码库的可访问性,配置要针对其运行此规则的部分。 例如,若要指定规则应仅针对非公共 API 图面运行,请将以下键值对添加到项目中的 .editorconfig 文件:

dotnet_code_quality.CAXXXX.api_surface = private, internal

示例

下面的示例显示了一个与此规则冲突的 ErrorProne 类型,以及一个符合此规则的 SaferWay 类型。

public class ErrorProne

{

// Violates rule UriPropertiesShouldNotBeStrings.

public string SomeUri { get; set; }

// Violates rule UriParametersShouldNotBeStrings.

public void AddToHistory(string uriString) { }

// Violates rule UriReturnValuesShouldNotBeStrings.

public string GetRefererUri(string httpHeader)

{

return "http://www.adventure-works.com";

}

}

public class SaferWay

{

// To retrieve a string, call SomeUri.ToString().

// To set using a string, call SomeUri = new Uri(string).

public Uri SomeUri { get; set; }

public void AddToHistory(string uriString)

{

// Check for UriFormatException.

AddToHistory(new Uri(uriString));

}

public void AddToHistory(Uri uriType) { }

public Uri GetRefererUri(string httpHeader)

{

return new Uri("http://www.adventure-works.com");

}

}

Imports System

Namespace ca1054

Public Class ErrorProne

' Violates rule UriPropertiesShouldNotBeStrings.

Property SomeUri As String

' Violates rule UriParametersShouldNotBeStrings.

Sub AddToHistory(uriString As String)

End Sub

' Violates rule UriReturnValuesShouldNotBeStrings.

Function GetRefererUri(httpHeader As String) As String

Return "http://www.adventure-works.com"

End Function

End Class

Public Class SaferWay

' To retrieve a string, call SomeUri.ToString().

' To set using a string, call SomeUri = New Uri(string).

Property SomeUri As Uri

Sub AddToHistory(uriString As String)

' Check for UriFormatException.

AddToHistory(New Uri(uriString))

End Sub

Sub AddToHistory(uriString As Uri)

End Sub

Function GetRefererUri(httpHeader As String) As Uri

Return New Uri("http://www.adventure-works.com")

End Function

End Class

End Namespace

相关规则

CA1056:URI 属性不应是字符串

CA1055:URI 返回值不应是字符串

CA2234:传递 System.Uri 对象,而不传递字符串

本文系外文翻译,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系外文翻译前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档