1

我有一个在用户单击表单上的“提交”时触发的函数。除custom_fields外,所有内容都将提交给 freshdesk 。

我正在使用带有控制器的 Angular 1.4,所以 ctrl 是我的控制器。这是我的代码:

   function postTicket() {
  var formdata = new FormData();

  var customFields = {
    "serial_number": ctrl.newTicket.serialnumber
  };
  customFields = JSON.stringify(customFields);


  formdata.append('description', ctrl.newTicket.description);
  formdata.append('subject', ctrl.newTicket.subject);
  formdata.append('type', ctrl.newTicket.type);
  formdata.append('email', ctrl.newTicket.email);
  formdata.append('custom_fields', customFields);
  formdata.append('status', 2); // open
  formdata.append('priority', 1); // low

  supportResource.postTicket(formdata).then(
    results => {
      console.log('it worked! ', results);
      ctrl.formSent = true;
    },
    error => {
      console.log('something went wrong. ', error);
    });
}

这是 supportResource 代码:

function postTicket(ticket) {
  return $q(function(fulfill, reject) {
    $http({
      url: `https://${MYACCOUNT}.freshdesk.com/api/v2/tickets`,
      method: 'POST',
      headers: {
        'Authorization': 'Basic ' + btoa(MYKEY),
        'Content-Type': undefined
      },
      data: ticket
    }).then(
      results => {
        fulfill(results.data);
      },
      error => reject(error));
  });
}

我得到以下错误:“值集是字符串类型。它应该是一个键/值对” 在此处输入图像描述

我已经按照这里的例子: https ://github.com/freshdesk/fresh-samples/blob/master/jquery/create_ticket_with_attachment.html

我也看到了这个: https: //support.freshdesk.com/support/solutions/articles/216548-create-and-update-tickets-with-custom-fields-using-api

但这个例子是使用 CURL,我不知道如何使用 FormData() http://developer.mozilla.org/en-US/docs/Web/API/FormData发送数据

4

1 回答 1

1

我想在这里分享解决方案,以防其他人遇到这个问题。这特定于freshdesk API 以及它如何期望数据。Form-data 的语法非常简单:

句法

此方法有两个版本:两个参数版本和三个参数版本:

  • formData.append(名称,值);
  • formData.append(名称,值,文件名);

因此,通过将名称从字符串更改为将 custom_field 名称引用为关联数组,如下所示:custom_fields[serial_number]API 了解正在使用的键,并能够读取表单数据

function postTicket() {
  var formdata = new FormData();

  formdata.append('description', ctrl.newTicket.description);
  formdata.append('subject', ctrl.newTicket.subject);
  formdata.append('type', ctrl.newTicket.type);
  formdata.append('email', ctrl.newTicket.email);
  formdata.append('custom_fields[serial_number]', ctrl.newTicket.serialnumber);
  formdata.append('status', 2); // open
  formdata.append('priority', 1); // low

  supportResource.postTicket(formdata).then(
    results => {
      console.log('it worked! ', results);
      ctrl.formSent = true;
    },
    error => {
      console.log('something went wrong. ', error);
    });
}
于 2017-06-26T19:24:29.333 回答