全部产品
云市场

Go SDK

更新时间:2018-11-17 14:15:49

下载地址

IMM Service 的 Go SDK 让开发人员可以非常方便地使用 Go 操作阿里云智能媒体管理服务。 已经开源到github

操作步骤

为快速开始使用 IMM Service Go SDK,请按照如下步骤进行。

步骤 1 创建阿里云账号

具体方法请参考 阿里云账号注册流程

为了更好地使用阿里云服务,建议尽快完成实名认证,否则部分阿里云服务将无法使用。具体实名认证流程,请参考 这里

步骤 2 获取阿里云访问密钥

为了使用 IMM Service Go SDK,您必须申请阿里云的 访问密钥。

登录阿里云 密钥管理页面。选择一对用于 SDK 的访问密钥对。如果没有,请创建一对新访问密钥,且保证它处于启用状态。有关如何创建访问密钥,参见 创建访问密钥

该密钥对会在下面的步骤使用,且需要保管好,不能对外泄露。另外,您可以参考 SDK 配置了解更多 SDK 如何使用访问密钥的信息。

步骤 3 创建项目

可以使用 Go SDK 创建,也可以在控制台上创建好项目(Project)。有关如何创建 Project ,参见 创建项目

步骤 4 安装 Imm Service Go SDK

go get github.com/aliyun/alibaba-cloud-sdk-go

安装过程中会出现

can’t load package: package github.com/aliyun/alibaba-cloud-sdk-go: no Go files in /Users/zouyongbo/Projects/go-deps/src/github.com/aliyun/alibaba-cloud-sdk-go

忽略该错误。

步骤 5 使用 Go SDK

以下这个代码示例展示了调用阿里云 Go SDK 的3个主要步骤:

  1. 创建 Client 实例。在创建 Client 实例时,您需要获取 Region ID、AccessKey ID 和 AccessKey Secret。
  2. 创建 API 请求并设置参数。
  3. 发起请求并处理应答或异常。

下面的 demo 以文档转换为例,展示了如何使用 Go SDK

5.1 调用请求

  1. package main
  2. import (
  3. "fmt"
  4. "time"
  5. "github.com/aliyun/alibaba-cloud-sdk-go/services/imm"
  6. )
  7. func main() {
  8. // Create an IMM client
  9. immClient, err := imm.NewClientWithAccessKey(
  10. "cn-shanghai", // Your Region ID
  11. "xxxxxxxxxxx", // Your AccessKey ID
  12. "xxxxxxxxxxx") // Your AccessKey Secret
  13. if err != nil {
  14. // Handle exceptions
  15. panic(err)
  16. }
  17. //项目名称,请确保您已经创建该项目
  18. projectName := "imm-go-sdk-doc-demo"
  19. // 提交文档转换任务
  20. req2 := imm.CreateCreateOfficeConversionTaskRequest()
  21. req2.Project = projectName
  22. req2.SrcUri = "oss://your-bucket-name/your-path/your-doc.doc"
  23. req2.TgtType = "vector"
  24. req2.TgtUri = "oss://your-bucket-name/your-path/your-doc-output"
  25. response2, err := immClient.CreateOfficeConversionTask(req2)
  26. if err != nil {
  27. // Handle exceptions
  28. panic(err)
  29. }
  30. fmt.Println(response2)
  31. // 等待任务完成
  32. maxGetCount := 30
  33. getInternval := time.Second
  34. getCount := 0
  35. req3 := imm.CreateGetOfficeConversionTaskRequest()
  36. req3.Project = projectName
  37. req3.TaskId = response2.TaskId
  38. for {
  39. time.Sleep(getInternval)
  40. response3, err := immClient.GetOfficeConversionTask(req3)
  41. if err != nil {
  42. // Handle exceptions
  43. panic(err)
  44. }
  45. fmt.Println(response3)
  46. if response3.Status != "Running" {
  47. break
  48. }
  49. getCount++
  50. if getCount >= maxGetCount {
  51. fmt.Println("OfficeConversion Timeout for 30 seconds")
  52. break
  53. }
  54. }
  55. }

5.2 文档转换任务返回状态

Running 状态结果返回如下:

  1. {
  2. "NotifyTopicName": "",
  3. "FailDetail": {
  4. "Code": ""
  5. },
  6. "TaskId": "ee52a217-234a-4922-8bd5-fcce5584c0e7",
  7. "NotifyEndpoint": "",
  8. "PageCount": 0,
  9. "Status": "Running",
  10. "TgtType": "png",
  11. "FinishTime": "",
  12. "CreateTime": "2018-07-21T15:37:28.539Z",
  13. "RequestId": "4153D465-45D3-4457-A273-DED40505CAD5",
  14. "SrcUri": "oss://your-bucket-name/your-path/your-doc.doc",
  15. "Percent": 0,
  16. "TgtUri": "oss://your-bucket-name/your-path/your-doc-output"
  17. }

Finished 状态结果返回如下:

  1. {
  2. "NotifyTopicName": "",
  3. "FailDetail": {
  4. "Code": "NoError"
  5. },
  6. "TaskId": "ee52a217-234a-4922-8bd5-fcce5584c0e7",
  7. "NotifyEndpoint": "",
  8. "PageCount": 32,
  9. "Status": "Finished",
  10. "TgtType": "png",
  11. "FinishTime": "2018-07-21T15:37:32.419Z",
  12. "CreateTime": "2018-07-21T15:37:28.539Z",
  13. "RequestId": "CACA2EC6-98FC-457A-810F-4035DD32A43B",
  14. "SrcUri": "oss://your-bucket-name/your-path/your-doc.doc",
  15. "Percent": 100,
  16. "TgtUri": "oss://your-bucket-name/your-path/your-doc-output"
  17. }

Failed 状态结果返回如下:

  1. {
  2. "NotifyTopicName": "",
  3. "FailDetail": {
  4. "Code": "FailedToDownloadSrcFile"
  5. },
  6. "TaskId": "1c8d3a19-9f28-433f-be13-8e42b8851ef3",
  7. "NotifyEndpoint": "",
  8. "PageCount": 0,
  9. "Status": "Failed",
  10. "TgtType": "png",
  11. "FinishTime": "",
  12. "CreateTime": "2018-07-21T15:47:53.865Z",
  13. "RequestId": "453B7362-D404-47A3-88A7-BE14F494812C",
  14. "SrcUri": "oss://your-bucket-name/your-path/your-doc.doc",
  15. "Percent": 0,
  16. "TgtUri": "oss://your-bucket-name/your-path/your-doc-output"
  17. }

若在使用中有疑问,请参考 FAQ,或者进入 钉钉用户群 实时交流。