首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在powershell中使用Freshdesk API

在powershell中使用Freshdesk API
EN

Stack Overflow用户
提问于 2018-04-13 16:51:59
回答 2查看 1.8K关注 0票数 1

我创建了一个powershell表单,供用户提交票证请求。我正试着让它用他们的api发送到freshdesk。下面是我从各个论坛拼凑而成的代码。我一直收到错误“请求体有无效的json格式”。

更新:更好地查看代码简单帮助表,任何帮助都将不胜感激。

代码语言:javascript
复制
function sendRequest()
{
# API Key
$FDApiKey="apikey"
#################################################

# Force TLS1.2 as Powershell defaults to TLS 1.0 and Freshdesk will fail 
connections
[Net.ServicePointManager]::SecurityProtocol = 
[Net.SecurityProtocolType]::TLS12

# Prep
$pair = "$($FDApiKey):$($FDApiKey)"
$bytes = [System.Text.Encoding]::ASCII.GetBytes($pair)
$base64 = [System.Convert]::ToBase64String($bytes)
$basicAuthValue = "Basic $base64"
$FDHeaders = @{ Authorization = $basicAuthValue }
##################################################

# The Doing part
#$FDBaseEndpointSummary =  
"https://clasd.freshdesk.com/helpdesk/api/v2/tickets"
#$FDContactData = Invoke-RestMethod -uri $FDBaseEndpointSummary -Headers 
$FDHeaders -Method Post -ContentType application/json 

$ticketArgs = @{
  email = '$email.Text'
  subject = '$subject.Text'
  description = '$description.Text'
  status = '2'
  type = '$request.Text'
  priority = '1'
  } 
 $json =   
     @{email='$email.Text';description='$description.Text'
    ;subject='$subject.Text';status='2';priority='1';type='$request.Text'}
    Invoke-WebRequest -uri 'https://clasd.freshdesk.com/api/v2/tickets' 
   -Headers $FDHeaders -Method Post -Body $json -ContentType 
    application/json
    #Invoke-WebRequest "https://clasd.freshdesk.com/api/v2/tickets/" - 
    Headers $FDHeaders  -ContentType "application/json" -Method Post 
    -Body " 
    { 'description':'$description.Text','email':'$email.Text', 
    'subject':'$subject.Text','type':'$request.Text','priority':'1',
    'status':'2' }" 
    #Invoke-WebRequest -Headers $FDHeaders  
     -ContentType "application/json" -Body "{ 
     'description':'$description.Text','email':'$email.Text',      
     'subject':'$subject.Text','type':'$request.Text','priority':'1',
     'status':'2' }" -method Post 
     'https://clasd.freshdesk.com/api/v2/tickets/'
      }
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-04-16 19:32:31

我能够通过添加一个-Body来解决所有问题($Body =-JSON)

代码语言:javascript
复制
$Body = @{
description = $description.Text
email = $email.Text
subject = $subject.Text
type = $request.Text
priority = 1
status = 2
}

Invoke-WebRequest "https://clasd.freshdesk.com/api/v2/tickets/" -Headers 
$FDHeaders  -ContentType "application/json" -Method Post -Body ($Body | 
ConvertTo-JSON)
票数 0
EN

Stack Overflow用户

发布于 2018-04-13 18:40:34

下面是我的意思--参见线程末尾的脚本。

是您要调用的api:属性

代码语言:javascript
复制
function sendRequest()
{
# API Key
$FDApiKey="apikey"
#################################################

# Force TLS1.2 as Powershell defaults to TLS 1.0 and Freshdesk will fail 
connections
[Net.ServicePointManager]::SecurityProtocol = 
[Net.SecurityProtocolType]::TLS12

# Prep
$pair = "$($FDApiKey):$($FDApiKey)"
$bytes = [System.Text.Encoding]::ASCII.GetBytes($pair)
$base64 = [System.Convert]::ToBase64String($bytes)
$basicAuthValue = "Basic $base64"
$FDHeaders = @{ Authorization = $basicAuthValue }
##################################################

# The Doing part
#$FDBaseEndpointSummary =  
"https://clasd.freshdesk.com/helpdesk/api/v2/tickets"
#$FDContactData = Invoke-RestMethod -uri $FDBaseEndpointSummary -Headers $FDHeaders -Method Post -ContentType application/json 

$ticketArgs = @{
  email = "$(email.Text)"
  subject = "$(subject.Text)"
  description = "$(description.Text)"
  status = '2'
  type = "$($request.Text)"
  priority = '1'
  } 
 $json =   
     @{email="$(email.Text)";description="$(description.Text)"
    ;subject="$(subject.Text)";status='2';priority='1';type="$($request.Text)"}

$jasonPayload = $json | convertto-json

Invoke-WebRequest -uri 'https://clasd.freshdesk.com/api/v2/tickets' -Headers $FDHeaders -Method Post -Body $jsonPayload -ContentType application/json 

#Invoke-WebRequest "https://clasd.freshdesk.com/api/v2/tickets/" -Headers $FDHeaders  -ContentType "application/json" -Method Post -Body "{ 'description':"$(description.Text)",'email':"$(email.Text)",'subject':"$(subject.Text)",'type':'$request.Text','priority':'1','status':'2' }" 

#Invoke-WebRequest -Headers $FDHeaders -ContentType "application/json" -Body "{'description':"$(description.Text)",'email':"$(email.Text)",'subject':"$(subject.Text)",'type':'$request.Text','priority':'1','status':'2' }" -method Post 'https://clasd.freshdesk.com/api/v2/tickets/'
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49821798

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档