我正在读取 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”错误,这是一个无用的错误。我需要知道该请求有什么问题。
让 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)
| 归档时间: |
|
| 查看次数: |
1155 次 |
| 最近记录: |