Amazon Rekognition
Developer Guide

Searching for a Face Using its Face ID

You can use the SearchFaces operation to search for faces in a collection that match a supplied face ID.

The following procedures show how you can use the operation with the AWS CLI, the AWS SDK for Java.

The face ID is returned in the IndexFaces operation response when the face is detected and added to a collection. For more information, see Storing Faces in a Face Collection.

For more information, see Managing Collections.

To search for a face in a collection using its face ID (AWS CLI)

  1. On the command line, type the following command. Replace faceid with the face identifier you want to search for and replace collection-id with the collection you want to search in.

    aws rekognition search-faces \ --face-id face-id \ --collection-id "collection-id" \ --region us-east-1 \ --profile adminuser
  2. To run the command, choose Enter. The JSON output for the SearchFaces operation is displayed.

To search for a face in a collection using its face ID (AWS SDK for Java)

  • To search for a face in a collection using its face ID, use the following AWS SDK for Java example code.

    package com.amazonaws.samples; import java.util.List; import com.amazonaws.AmazonClientException; import com.amazonaws.auth.AWSCredentials; import com.amazonaws.auth.AWSStaticCredentialsProvider; import com.amazonaws.auth.profile.ProfileCredentialsProvider; import com.amazonaws.regions.Regions; import; import; import; import; import; import com.fasterxml.jackson.databind.ObjectMapper; public class SearchFaceMatchingId { public static final String collectionId = "exampleCollection"; public static final String bucket = "photo-label-detect"; public static final String faceId = "3689c89f-08a6-527d-8dc8-ea2d48cebb58"; public static void main(String[] args) throws Exception { AWSCredentials credentials; try { credentials = new ProfileCredentialsProvider("AdminUser").getCredentials(); } catch (Exception e) { throw new AmazonClientException( "Cannot load the credentials from the credential profiles file. " + "Please make sure that your credentials file is at the correct " + "location (/Users/userid/.aws/credentials), and is in a valid format.", e); } AmazonRekognition amazonRekognition = AmazonRekognitionClientBuilder .standard() .withRegion(Regions.US_WEST_2) .withCredentials(new AWSStaticCredentialsProvider(credentials)) .build(); ObjectMapper objectMapper = new ObjectMapper(); // Search collection for faces matching the face id. SearchFacesRequest searchFacesRequest = new SearchFacesRequest() .withCollectionId(collectionId) .withFaceId(faceId) .withFaceMatchThreshold(70F) .withMaxFaces(2); SearchFacesResult searchFacesByImageResult = amazonRekognition.searchFaces(searchFacesRequest); System.out.println("Face matching faceId " + faceId); List < FaceMatch > faceImageMatches = searchFacesByImageResult.getFaceMatches(); for (FaceMatch face: faceImageMatches) { System.out.println(objectMapper.writerWithDefaultPrettyPrinter() .writeValueAsString(face)); System.out.println(); } } }