Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Untuk menunjukkan cara mengatur integrasi kustom Lambda, kami membuat API Gateway API untuk mengekspos GET /greeting?greeter={name}
metode untuk menjalankan fungsi Lambda. Gunakan salah satu contoh fungsi Lambda berikut untuk API Anda.
Gunakan salah satu contoh fungsi Lambda berikut:
export const handler = function(event, context, callback) { var res ={ "statusCode": 200, "headers": { "Content-Type": "*/*" } }; if (event.greeter==null) { callback(new Error('Missing the required greeter parameter.')); } else if (event.greeter === "") { res.body = "Hello, World"; callback(null, res); } else { res.body = "Hello, " + event.greeter +"!"; callback(null, res); } };
Fungsi merespons dengan pesan "Hello, {name}!"
jika nilai greeter
parameter adalah string yang tidak kosong. Ia mengembalikan pesan "Hello, World!"
jika greeter
nilai adalah string kosong. Fungsi mengembalikan pesan kesalahan "Missing the required greeter
parameter."
jika parameter penyambut tidak diatur dalam permintaan masuk. Kami menamai fungsinyaHelloWorld
.
Anda dapat membuatnya di konsol Lambda atau dengan menggunakan. AWS CLI Pada bagian ini, kami mereferensikan fungsi ini menggunakan ARN berikut:
arn:aws:lambda:us-east-1:123456789012:function:HelloWorld
Dengan fungsi Lambda diatur di backend, lanjutkan untuk mengatur API.
Untuk mengatur integrasi kustom Lambda menggunakan AWS CLI
-
Gunakan create-rest-apiperintah berikut untuk membuat API:
aws apigateway create-rest-api --name 'HelloWorld (AWS CLI)'
Outputnya akan terlihat seperti berikut:
{ "name": "HelloWorld (AWS CLI)", "id": "te6si5ach7", "rootResourceId" : "krznpq9xpg", "createdDate": 1508461860 }
Anda menggunakan API
id
(te6si5ach7
) danrootResourceId
(krznpq9xpg
) di seluruh contoh ini. -
Gunakan perintah create-resource berikut untuk membuat API Gateway Resource dari:
/greeting
aws apigateway create-resource \ --rest-api-id te6si5ach7 \ --parent-id krznpq9xpg \ --path-part greeting
Outputnya akan terlihat seperti berikut:
{ "path": "/greeting", "pathPart": "greeting", "id": "2jf6xt", "parentId": "krznpq9xpg" }
Anda menggunakan
id
nilaigreeting
sumber daya (2jf6xt
) untuk membuat metode pada/greeting
sumber daya di langkah berikutnya. -
Gunakan perintah put-method berikut untuk membuat permintaan metode API dari:
GET /greeting?greeter={name}
aws apigateway put-method --rest-api-id te6si5ach7 \ --resource-id 2jf6xt \ --http-method GET \ --authorization-type "NONE" \ --request-parameters method.request.querystring.greeter=false
Outputnya akan terlihat seperti berikut:
{ "apiKeyRequired": false, "httpMethod": "GET", "authorizationType": "NONE", "requestParameters": { "method.request.querystring.greeter": false } }
Metode API ini memungkinkan klien untuk menerima salam dari fungsi Lambda di backend.
greeter
Parameternya opsional karena backend harus menangani penelepon anonim atau penelepon yang diidentifikasi sendiri. -
Gunakan put-method-responseperintah berikut untuk mengatur
200 OK
respon terhadap permintaan metodeGET /greeting?greeter={name}
:aws apigateway put-method-response \ --rest-api-id te6si5ach7 \ --resource-id 2jf6xt \ --http-method GET \ --status-code 200
-
Gunakan perintah put-integration berikut untuk mengatur integrasi
GET /greeting?greeter={name}
metode dengan fungsi Lambda, bernama.HelloWorld
Fungsi menanggapi permintaan dengan pesan"Hello, {name}!"
, jikagreeter
parameter disediakan, atau"Hello, World!"
, jika parameter string query tidak diatur.aws apigateway put-integration \ --rest-api-id te6si5ach7 \ --resource-id 2jf6xt \ --http-method GET \ --type AWS \ --integration-http-method POST \ --uri arn:aws:apigateway:us-east-1:lambda:path/2015-03-31/functions/arn:aws:lambda:us-east-1:123456789012:function:HelloWorld/invocations \ --request-templates '{"application/json":"{\"greeter\":\"$input.params('greeter')\"}"}' \ --credentials arn:aws:iam::123456789012:role/apigAwsProxyRole
Template pemetaan yang disediakan di sini menerjemahkan parameter string
greeter
kueri kegreeter
properti payload JSON. Ini diperlukan karena input ke fungsi Lambda harus diekspresikan dalam tubuh.penting
Untuk integrasi Lambda, Anda harus menggunakan metode HTTP
POST
untuk permintaan integrasi, sesuai dengan spesifikasi tindakan layanan Lambda untuk pemanggilan fungsi.uri
Parameternya adalah ARN dari tindakan pemanggilan fungsi.Outputnya akan terlihat seperti berikut:
{ "passthroughBehavior": "WHEN_NO_MATCH", "cacheKeyParameters": [], "uri": "arn:aws:apigateway:us-east-1:lambda:path/2015-03-31/functions/arn:aws:lambda:us-east-1:123456789012:function:HelloWorld/invocations", "httpMethod": "POST", "requestTemplates": { "application/json": "{\"greeter\":\"$input.params('greeter')\"}" }, "cacheNamespace": "krznpq9xpg", "credentials": "arn:aws:iam::123456789012:role/apigAwsProxyRole", "type": "AWS" }
Peran IAM
apigAwsProxyRole
harus memiliki kebijakan yang memungkinkanapigateway
layanan untuk menjalankan fungsi Lambda. Alih-alih menyediakan peran IAMcredentials
, Anda dapat memanggil perintah add-permission untuk menambahkan izin berbasis sumber daya. Beginilah cara konsol API Gateway menambahkan izin ini. -
Gunakan put-integration-responseperintah berikut untuk mengatur respons integrasi untuk meneruskan output fungsi Lambda ke klien sebagai respons
200 OK
metode:aws apigateway put-integration-response \ --rest-api-id te6si5ach7 \ --resource-id 2jf6xt \ --http-method GET \ --status-code 200 \ --selection-pattern ""
Dengan mengatur pola pilihan ke string kosong,
200 OK
responsnya adalah default.Outputnya akan terlihat seperti berikut:
{ "selectionPattern": "", "statusCode": "200" }
-
Gunakan perintah create-deployment berikut untuk men-deploy API ke tahap:
test
aws apigateway create-deployment \ --rest-api-id te6si5ach7 \ --stage-name test
-
Uji API menggunakan perintah cURL berikut di terminal:
curl -X GET 'https://te6si5ach7.execute-api.us-west-2.amazonaws.com/test/greeting?greeter=me' \ -H 'authorization: AWS4-HMAC-SHA256 Credential={access_key}/20171020/us-west-2/execute-api/aws4_request, SignedHeaders=content-type;host;x-amz-date, Signature=f327...5751'