Sample code for 30+ languages & platforms
Chilkat2-Python

Client Certificate in REST (USB Token or Smartcard)

See more REST Examples

Demonstrates how to use a client certificate with a REST connection where the certificate and private key are located on a USB token or smart card.

Chilkat Chilkat2-Python Downloads

Chilkat2-Python
import sys
import chilkat2

success = False

# This example requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.

# This example shows how to use the Chilkat socket object's connection.
rest = chilkat2.Rest()
socket = chilkat2.Socket()

# Set the certificate to be used for mutual TLS authentication
cert = chilkat2.Cert()

# If the smartcard or token requires a PIN...
cert.SmartCardPin = "000000"

success = cert.LoadFromSmartcard("")
if (success != True):
    print(cert.LastErrorText)
    sys.exit()

success = socket.SetSslClientCert(cert)
if (success != True):
    print(socket.LastErrorText)
    sys.exit()

# Establish the connection using the socket object (with client certificate authentication).
bTls = True
port = 443
maxWaitMs = 5000
success = socket.Connect("www.example.com",port,bTls,maxWaitMs)
if (success != True):
    print("Connect Failure Error Code: " + str(socket.ConnectFailReason))
    print(socket.LastErrorText)
    sys.exit()

bAutoReconnect = True

# Use the connection:
success = rest.UseConnection(socket,bAutoReconnect)
if (success != True):
    print(rest.LastErrorText)
    sys.exit()

# At this point we are connected and can make REST calls...
# For example..
responseJson = rest.FullRequestNoBody("GET","/someQuery")
if (rest.LastMethodSuccess != True):
    print(rest.LastErrorText)
    sys.exit()