MifareSam

EMDK For Android 2.3

Provides access to MIFARE SAM properties and I/O operations on an SAM object. This class encapsulates all the methods required for authenticating the host with MiFare SAM.

Example Usage:




public class MainActivity extends Activity implements EMDKListener {

SecureNfcManager secureNfcManager;
EMDKManager emdkManager;
SamType samType;
MifareSam mifareSam;


protected void onCreate(Bundle savedInstanceState) {

EMDKResults results = EMDKManager.getEMDKManager(
getApplicationContext(), this);
}


public void onOpened(EMDKManager emdkManager) {

this.emdkManager = emdkManager;

this.secureNfcManager = (secureNfcManager) this.emdkManager
.getInstance(FEATURE_TYPE.SECURENFC);

if (this.secureNfcManager != null) {

samType = secureNfcManager.getAvailableSam();

if (samType.equals(SamType.MIFARE)) {
mifareSam = (MifareSam) secureNfcMgr
.getSamInstance(samType);
if (mifareSam != null) {
try {
SamMode samMode = mifareSam.connect();

mifareSam.authenticateSam(authKey, samKey, null);

mifareSam.close();
} catch (MifareSamException e) {
e.printStackTrace();
}
}
}
}
}


public void onDestroy() {
if (this.emdkManager != null)
this.emdkManager.release();
}


public void onClosed() {
this.emdkManager.release();
}

}

Public Methods

connect

public SamMode connect()

Connects to the SAM to perform I/O operations. Application must call close() when I/O operations are complete.

Returns:

com.symbol.emdk.securenfc.MifareSam.SamMode

Throws:

com.symbol.emdk.securenfc.MifareSamException

The exception will be thrown if it fails to establish connection with the SAM.

getSamInfo

public SamInfo getSamInfo()

Returns manufacturing related information of the MIFARESAM.

Returns:

com.symbol.emdk.securenfc.MifareSam.SamInfo

Throws:

com.symbol.emdk.securenfc.MifareSamException

The exception will be thrown if it fails to return manufacturing related information of the SAM.

authenticateSam

public void authenticateSam(byte authKey, SamKey samKey, MifareSam.AdditionalAuthData additionalAuthData)

Performs the SAM authentication. If the SAM is in AV1 mode, performs mutual 3-pass authentication between host system and MIFARE SAM AV1 or MIFARE SAM AV2 set in AV1 compatibility mode. If the SAM is in AV2 mode, performs mutual authentication between host system and MIFARE SAM AV2 set in AV2 mode.

Parameters:

authKey - Authentication key to be used.

samKey - SAM key to be used for authentication

additionalAuthData - Additional authentication data.

Returns:

void

Throws:

com.symbol.emdk.securenfc.MifareSamException

The exception will be thrown if it fails to authenticate the SAM.

close

public void close()

Close with the SAM to perform I/O operations.

Returns:

void

Throws:

com.symbol.emdk.securenfc.MifareSamException

The exception will be thrown if it fails to close the connection with the SAM.

Public Fields

TAG

Type:

java.lang.String

Public Enums

MifareSam.ProtectionMode

Protection mode

Values:

  • PLAIN -No protection

  • MAC -MAC protection. Not Supported.

  • FULL -Full protection (MACing and encryption). Not Supported.

MifareSam.SamMode

SAM modes

Values:

  • AV1 -MIFARE SAM is in AV1 mode

  • AV2 -MIFARE SAM is in AV2 mode

  • UNDEFINED -MIFARE SAM is in invalid mode