Windows에서 "큰따옴표 인수가 있는 exec": 탈출 수수께끼 공개
exec를 사용하여 Windows에서 find 명령을 실행하려고 할 때 패키지를 사용하는 경우 사용자는 이스케이프 관련 예상치 못한 문제에 직면하는 경우가 많습니다. 문제는 명령에 전달된 인수를 큰따옴표로 묶어 Windows에서 이를 잘못 해석할 때 발생합니다.
언급된 경우와 마찬가지로 실행 시:
out, err := exec.Command("find", `"SomeText"`).Output()
Windows에서는 이를 변환합니다. to:
find /SomeText"
오류가 발생합니다.
원인 공개: Windows의 이상한 탈출
이 시나리오의 비정형 탈출 동작은 다음과 같습니다. Windows는 다른 운영 체제와 다른 이스케이프 메커니즘을 사용한다는 사실에서 비롯됩니다. Windows에서는 큰따옴표가 특수 문자로 사용되며, 마주치면 다음 문자를 이스케이프하려고 시도합니다. 따라서 주어진 명령에서 Windows는 인수 내의 큰따옴표를 이스케이프 문자로 해석하여 예기치 않은 동작을 발생시킵니다.
퍼즐 해결: 정교한 솔루션
해결 이 문제에는 두 부분으로 구성된 솔루션이 필요합니다. 먼저, 기본 동작을 우회하여 SysProcAttr 필드를 사용하여 명령줄을 명시적으로 설정해야 합니다. 둘째, 적절한 이스케이프를 보장하기 위해 명령줄 문자열을 수동으로 구성해야 합니다.
다음은 이러한 조정 사항을 통합하는 업데이트된 코드 조각입니다.
<code class="go">package main import ( "fmt" "os/exec" "syscall" ) func main() { cmd := exec.Command(`find`) cmd.SysProcAttr = &syscall.SysProcAttr{} cmd.SysProcAttr.CmdLine = `find "SomeText" test.txt` out, err := cmd.Output() fmt.Printf("%s\n", out) fmt.Printf("%v\n", err) }</code>
이러한 수정 사항을 적용하면 find 명령이 다음과 같이 됩니다. Windows에서 올바르게 실행되어 의도한 대로 파일을 검색할 수 있습니다.
위 내용은 큰따옴표로 묶은 인수가 포함된 'exec'가 Windows에서 예기치 않은 동작을 일으키는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!