Skip to contentSkip to navigationSkip to topbar
Rate this page:
On this page

Lookup v1 Quickstart


(warning)

Warning

Version 2 of the Lookup API is now available! Lookup v2 has an improved developer experience and exciting features, such as Twilio Regions support and these new data packages:

  • Line Type Intelligence : Get the line type of a phone number including mobile, landline, fixed VoIP, non-fixed VoIP, toll-free, and more.
  • SIM Swap : Get information on the last SIM change for a mobile phone number.
  • Call Forwarding : Get the unconditional call forwarding status of a mobile phone number.
  • Identity Match : Get confirmation of ownership for a mobile phone number by comparing user-provided information against authoritative phone-based data sources.

You are currently viewing Version 1 content. Lookup v1 will be maintained for the time being, but any new features and development will be on v2. We strongly encourage you to do any new development with Lookup v2. Check out the migration guide(link takes you to an external page) or the API v2 Reference for more information.


How to look up a Phone Number

how-to-look-up-a-phone-number page anchor

What is Lookup?

what-is-lookup page anchor

Lookup allows you to systematically ascertain information about phone numbers. With Lookup, you can identify local-friendly number formats and reduce the likelihood of undelivered messages.

First, decide what you'd like to know about your numbers. Format lookups are free and allow you to identify and adjust international phone numbers into E.164 format for optimal message deliverability. Carrier lookups cost $0.005 per lookup and allow you to identify both the phone type (mobile, landline or VoIP) and the carrier behind the phone number.

Let's look at the details:

  • First log into your Twilio Account . On the Dashboard there is a section labeled "API Credentials" . There you will find your Account SID and Auth Token. You'll need these to authenticate your request.
  • To perform a Lookup, we'll be making a HTTP GET request to the lookup subdomain. lookups.twilio.com/v1/PhoneNumbers/{PhoneNumber}
  • We will need to include the phone number we want to look up.
  • We may then specify any additional information as GET parameters.

Let's try this out by using curl to make the following request in our terminal:


_10
curl -XGET "https://lookups.twilio.com/v1/PhoneNumbers/5108675309?CountryCode=US&Type=carrier" \
_10
-u '{AccountSid}:{AuthToken}'

Now we want to integrate Lookup with our application. Let's try it out with our helper library.

You may want to use Format Lookup in order to reformat international numbers given to you by your customers in local format. In this case, you need to specify the number and the country you believe the phone number is from. Note that this lookup is free.

The Twilio helper libraries assist with this. Open a new file and add the following lines:

Lookup with National Formatted Number

lookup-with-national-formatted-number page anchor
Node.js
Python
C#
Java
Go
PHP
Ruby
twilio-cli
curl

_18
// Download the helper library from https://www.twilio.com/docs/node/install
_18
const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";
_18
_18
// Find your Account SID and Auth Token at twilio.com/console
_18
// and set the environment variables. See http://twil.io/secure
_18
const accountSid = process.env.TWILIO_ACCOUNT_SID;
_18
const authToken = process.env.TWILIO_AUTH_TOKEN;
_18
const client = twilio(accountSid, authToken);
_18
_18
async function fetchPhoneNumber() {
_18
const phoneNumber = await client.lookups.v1
_18
.phoneNumbers("+15108675310")
_18
.fetch({ countryCode: "US" });
_18
_18
console.log(phoneNumber.callerName);
_18
}
_18
_18
fetchPhoneNumber();

Output

_10
{
_10
"caller_name": null,
_10
"carrier": null,
_10
"add_ons": null,
_10
"country_code": "US",
_10
"national_format": "(510) 867-5310",
_10
"phone_number": "+15108675310",
_10
"url": "https://lookups.twilio.com/v1/PhoneNumbers/+15108675310"
_10
}

You'll want to include the country code of the phone number that you would like formatted. If not included, the country code will default to the US.

You may also want to do a lookup to determine the phone number type and carrier for your phone number. Note that this costs $0.005 per lookup.

To do this lookup, you'll want to include the carrier parameter. Similar to the code above, we can make this request with the following snippet:

Lookup with National Formatted Number

lookup-with-national-formatted-number-1 page anchor
Node.js
Python
C#
Java
Go
PHP
Ruby
twilio-cli
curl

_21
// Download the helper library from https://www.twilio.com/docs/node/install
_21
const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";
_21
_21
// Find your Account SID and Auth Token at twilio.com/console
_21
// and set the environment variables. See http://twil.io/secure
_21
const accountSid = process.env.TWILIO_ACCOUNT_SID;
_21
const authToken = process.env.TWILIO_AUTH_TOKEN;
_21
const client = twilio(accountSid, authToken);
_21
_21
async function fetchPhoneNumber() {
_21
const phoneNumber = await client.lookups.v1
_21
.phoneNumbers("(510)867-5310")
_21
.fetch({
_21
countryCode: "US",
_21
type: ["carrier"],
_21
});
_21
_21
console.log(phoneNumber.carrier);
_21
}
_21
_21
fetchPhoneNumber();

Output

_15
{
_15
"caller_name": null,
_15
"carrier": {
_15
"error_code": null,
_15
"mobile_country_code": "310",
_15
"mobile_network_code": "456",
_15
"name": "verizon",
_15
"type": "mobile"
_15
},
_15
"country_code": "US",
_15
"national_format": "(510) 867-5310",
_15
"phone_number": "(510)867-5310",
_15
"add_ons": null,
_15
"url": "https://lookups.twilio.com/v1/PhoneNumbers/+15108675310"
_15
}

Now you're ready to look up your customers' phone numbers and reach them in the most appropriate ways!


Rate this page: