PowerShell - 如何在 REST 调用的 JSON 字符串中转义 {}

Nea*_*ers 3 powershell

我正在读取 HTML 文件,需要将其作为字符串参数传递给 JSON 调用。HTML 中有用于 css/样式的大括号。我正在看这个问题,但我的问题更多的是围绕 JSON 特殊字符,其中一个是其他转义字符。该文件还可能包含 [] 字符。

$HtmlFromFile2 = @"
<html>
    <style type="text/css">.LetterList {font-family:"arial"}</style>
    <body>
        To [firstname]:
        This is a normal body with special JSON characters. 
    </body>
</html>
"@
$HtmlFromFile2Stripped = $HtmlFromFile2.Replace("`r", "").Replace("`n", "").Replace("`t","") 
#$HtmlFromFileFixed = % { [System.Text.RegularExpressions.Regex]::Unescape($HtmlFromFile2Stripped) }
$HtmlFromFileFixed = $HtmlFromFile2Stripped.Replace("{","\{").Replace("}","\}")

Write-Host "After RegEx Fix"
Write-Host $HtmlFromFileFixed 

$templateID = "Test_Temp7"


$body = @"
{   "uuid": "$templateID",
    "subject": "My Email Subject",
    "body": "$HtmlFromFileFixed"
}
"@

# This also tests if our JSON is "well-formed", on extra or missing commas, braces, brackets, etc... 
$bodyJSON = ConvertFrom-Json $body 

# Write-Host $body

$params = @{
    Uri         = 'https://stage-tms.demo.com/templates/email'
    Headers     = $headers
    Method      = 'POST'
    Body        = "$body"
    ContentType = 'application/json'
}

#Invoke-RestMethod @params
Run Code Online (Sandbox Code Playgroud)

我使用 Convert-FromJSON 作为测试。当它起作用时,Invoke-RestMethod 通常就会起作用。当 Convert-FromJSON 失败时,Invoke-RestMethod 将返回 http statsu=400 和 statusDescription="Bad Request"。

当前错误:

ConvertFrom-Json : Invalid object passed in, ':' or '}' expected. (137): {   "uuid": "FEMAImport_Home_Test_Temp7",
    "subject": "SBA Disaster Loan Assistance TestText",
    "body": "<html>    <style type="text/css">.sbaLetterList \{font-family:"arial"\}</style><body>    This is a 
normal body with special JSON characters. </body></html>"
}
At C:\Scripts\TestJSONEscapeBraces.ps1:38 char:13
+ $bodyJSON = ConvertFrom-Json $body
+             ~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : NotSpecified: (:) [ConvertFrom-Json], ArgumentException
    + FullyQualifiedErrorId : System.ArgumentException,Microsoft.PowerShell.Commands.ConvertFromJsonCommand
Run Code Online (Sandbox Code Playgroud)

更新1: 我做了更多测试。我最终得到了太多有效和无效的排列。我无法包含我正在使用的整个 HTML 文件;我需要一种技术来隔离错误并识别它们。我希望 ConvertFrom-JSON 能为我做到这一点。

从下面,您可以看到我正在尝试的不同文件。第一个文件(真实文件和较大的文件)在 ConvertFrom-JSON 和 REST/Post 上均失败。另外两个文件现在正在工作。

 $HtmlBodyFilename = "$PSScriptRoot\Emailbody_Home.html" 
#$HtmlBodyFilename = "$PSScriptRoot\Emailbody_Home_SimpleTest.html" 
#$HtmlBodyFilename = "$PSScriptRoot\Emailbody_Home_SimpleTestWithBraces.html" 
    $HtmlFromFile = Get-Content $HtmlBodyFilename -Raw   #the -Raw option gets a string instead of an array of lins 
    $HtmlFromFileStripped = $HtmlFromFile.Replace("`r", "").Replace("`n", "").Replace("`t","") 
Run Code Online (Sandbox Code Playgroud)

我现在可以读取和处理一个带有花括号的简单的小测试文件。但是当我指向磁盘上的真实 HTML 文件时,我收到错误,并且不知道如何隔离它。我可能假设它是花括号。

如果我使用 ConvertFrom-JSON 和真实的 HTML 文件,我会得到: ConvertFrom-Json :传入的对象无效,预期为 ':' 或 '}'。(143):{“uuid”:“FEMAImport_HomeFile_Test_Temp3”,“主题”:等等...

现在,如果我删除“ConvertFrom-JSON”并使用真正的 HTML 文件,我会从 SOAP 请求中收到此错误:“请求已中止:连接意外关闭。” 当然,一个区别是文件要大得多,大约 83KB。

在此之前,我收到过很多 400“Bad Request”错误,这是一个无用的错误。我需要知道该请求有什么问题。

mar*_*sze 6

让 Powershell 为您完成所有工作,不要自己构建 JSON 字符串,而是使用对象:

$body = ConvertTo-Json @{
    uuid = $templateID
    subject = "My Email Subject"
    body = Get-Content $HtmlBodyFilename -Raw
}
Run Code Online (Sandbox Code Playgroud)

所有特殊字符都会自动转义。

感谢@Hazrelle,当然在这种情况下你甚至不需要转换任何东西,因为Invoke-WebRequest它将为你做:

$params = @{
    Uri         = 'https://stage-tms.demo.com/templates/email'
    Headers     = $headers
    Method      = 'POST'
    Body        = @{
        uuid = $templateID
        subject = "My Email Subject"
        body = Get-Content $HtmlBodyFilename -Raw
    }
    ContentType = 'application/json'
}
Run Code Online (Sandbox Code Playgroud)