다음을 통해 공유


로캘별 문자열을 하드코드하지 마십시오.

업데이트: 2007년 11월

TypeName

DoNotHardcodeLocaleSpecificStrings

CheckId

CA1302

범주

Microsoft.Globalization

변경 수준

주요 변경 아님

원인

메서드에서 특정 시스템 폴더 경로의 일부를 나타내는 문자열 리터럴을 사용합니다.

규칙 설명

System.Environment.SpecialFolder 열거형에는 특수 시스템 폴더를 참조하는 멤버가 포함되어 있습니다. 이들 폴더의 위치는 운영 체제에 따라 값이 다를 수 있으며, 사용자가 위치 일부를 변경할 수 있고, 위치는 지역화됩니다. 특수 폴더의 예로는 Windows XP의 "C:\WINDOWS\system32", Windows 2000의 "C:\WINNT\system32"에 해당하는 시스템 폴더를 들 수 있습니다. Environment.GetFolderPath 메서드는 Environment.SpecialFolder 열거형과 연관된 위치를 반환합니다. GetFolderPath에서 반환하는 위치는 지역화되므로 현재 실행되고 있는 컴퓨터에 적합합니다.

이 규칙은 GetFolderPath 메서드를 사용하여 검색한 폴더 경로를 구분된 디렉터리 수준으로 토큰화합니다. 각 문자열 리터럴을 토큰에 비교하여 일치하는 것이 있으면 메서드가 해당 토큰에 연결된 시스템 위치를 참조하는 문자열을 구성하고 있는 것으로 간주됩니다. 이식성과 지역화 가능성을 위해서는 문자열 리터럴을 사용하는 대신 GetFolderPath 메서드를 사용하여 특수 시스템 폴더의 위치를 검색합니다.

위반 문제를 해결하는 방법

이 규칙 위반 문제를 해결하려면 GetFolderPath 메서드를 사용하여 위치를 검색합니다.

경고를 표시하지 않는 경우

문자열 리터럴이 Environment.SpecialFolder 열거형과 연결된 시스템 위치 중 하나를 참조하는 데 사용되지 않는 경우에는 이 규칙에서 경고를 표시하지 않아도 안전합니다.

예제

다음 예제에서는 공통 응용 프로그램 데이터 폴더에 대한 경로를 만들며 그 결과 이 규칙으로부터 세 개의 경고가 생성됩니다. 그런 다음 GetFolderPath 메서드를 사용하여 경로를 검색합니다.

Imports System

Namespace GlobalizationLibrary

   Class WriteSpecialFolders

      Shared Sub Main()

         Dim string0 As String = "C:"

         ' Each of the following three strings violates the rule.
         Dim string1 As String = "\Documents and Settings"
         Dim string2 As String = "\All Users"
         Dim string3 As String = "\Application Data"
         Console.WriteLine(string0 & string1 & string2 & string3)

         ' The following statement satisfies the rule.
         Console.WriteLine(Environment.GetFolderPath( _ 
            Environment.SpecialFolder.CommonApplicationData))

      End Sub

   End Class

End Namespace
using System;

namespace GlobalizationLibrary
{
   class WriteSpecialFolders
   {
      static void Main()
      {
         string string0 = "C:";

         // Each of the following three strings violates the rule.
         string string1 = @"\Documents and Settings";
         string string2 = @"\All Users";
         string string3 = @"\Application Data";
         Console.WriteLine(string0 + string1 + string2 + string3);

         // The following statement satisfies the rule.
         Console.WriteLine(Environment.GetFolderPath(
            Environment.SpecialFolder.CommonApplicationData));
      }
   }
}