<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java_Tutorial%2FSecurity%2FProvider</id>
		<title>Java Tutorial/Security/Provider - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java_Tutorial%2FSecurity%2FProvider"/>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java_Tutorial/Security/Provider&amp;action=history"/>
		<updated>2026-04-10T19:21:00Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://jexp.ru/index.php?title=Java_Tutorial/Security/Provider&amp;diff=4332&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java_Tutorial/Security/Provider&amp;diff=4332&amp;oldid=prev"/>
				<updated>2010-06-01T05:01:43Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 05:01, 1 июня 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	<entry>
		<id>http://jexp.ru/index.php?title=Java_Tutorial/Security/Provider&amp;diff=4331&amp;oldid=prev</id>
		<title> в 17:44, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java_Tutorial/Security/Provider&amp;diff=4331&amp;oldid=prev"/>
				<updated>2010-05-31T17:44:27Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==  extends java.security.Provider ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.security.AccessController;&lt;br /&gt;
import java.security.PrivilegedAction;&lt;br /&gt;
public final class ECCProvider extends java.security.Provider {&lt;br /&gt;
  private static final String INFO = &amp;quot;jexp&amp;quot;s provider&amp;quot;;&lt;br /&gt;
  public ECCProvider() {&lt;br /&gt;
    super(&amp;quot;jexp&amp;quot;, 1.0, INFO);&lt;br /&gt;
    AccessController.doPrivileged(new PrivilegedAction() {&lt;br /&gt;
      public Object run() {&lt;br /&gt;
        put(&amp;quot;KeyFactory.ECC&amp;quot;, &amp;quot;com.jexpKeyFactory&amp;quot;);&lt;br /&gt;
        put(&amp;quot;KeyPairGenerator.ECC&amp;quot;, &amp;quot;com.jexpKeyPairGenerator&amp;quot;);&lt;br /&gt;
        return null;&lt;br /&gt;
      }&lt;br /&gt;
    });&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  extends Provider ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.security.Provider;&lt;br /&gt;
public class YourOwnProvider extends Provider {&lt;br /&gt;
  public YourOwnProvider() {&lt;br /&gt;
    super(&amp;quot;YourOwn&amp;quot;, 1.0, &amp;quot;YourOwn Security Provider v1.0&amp;quot;);&lt;br /&gt;
    put(&amp;quot;KeyGenerator.XOR&amp;quot;, &amp;quot;yourPackageName.XORKeyGenerator&amp;quot;);&lt;br /&gt;
    put(&amp;quot;KeyPairGenerator.YourOwn&amp;quot;, &amp;quot;yourPackageName.YourOwnKeyPairGenerator&amp;quot;);&lt;br /&gt;
    put(&amp;quot;KeyFactory.YourOwn&amp;quot;, &amp;quot;yourPackageName.YourOwnKeyFactory&amp;quot;);&lt;br /&gt;
    put(&amp;quot;MessageDigest.YourOwn&amp;quot;, &amp;quot;yourPackageName.YourOwnMessageDigest&amp;quot;);&lt;br /&gt;
    put(&amp;quot;Signature.YourOwnwithSHA&amp;quot;, &amp;quot;yourPackageName.YourOwnSignature&amp;quot;);&lt;br /&gt;
    put(&amp;quot;Cipher.XOR&amp;quot;, &amp;quot;yourPackageName.XORCipher&amp;quot;);&lt;br /&gt;
    put(&amp;quot;KeyManagerFactory.YourOwn&amp;quot;, &amp;quot;yourPackageName.SSLKeyManagerFactory&amp;quot;);&lt;br /&gt;
    put(&amp;quot;Alg.Alias.MessageDigest.SHA-1&amp;quot;, &amp;quot;SHA&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public static final synchronized void verifyForJCE() {&lt;br /&gt;
    throw new SecurityException(&amp;quot;Can&amp;quot;t verify for JCE&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Get a Provider ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.security.Key;&lt;br /&gt;
import java.security.Provider;&lt;br /&gt;
import java.security.SecureRandom;&lt;br /&gt;
import java.security.Security;&lt;br /&gt;
import javax.crypto.Cipher;&lt;br /&gt;
public final class MainClass {&lt;br /&gt;
  String providerName = &amp;quot;Rot13Provider&amp;quot;;&lt;br /&gt;
  String algorithmName = &amp;quot;ROT13&amp;quot;;&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Provider p = Security.getProvider(&amp;quot;Rot13Provider&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;Provider name: &amp;quot; + p.getName());&lt;br /&gt;
    System.out.println(&amp;quot;Provider version: &amp;quot; + p.getVersion());&lt;br /&gt;
    System.out.println(&amp;quot;Provider information: &amp;quot; + p.getInfo());&lt;br /&gt;
    Cipher cipher = Cipher.getInstance(&amp;quot;ROT13&amp;quot;, &amp;quot;Rot13Provider&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;Cipher: &amp;quot; + cipher.getAlgorithm());&lt;br /&gt;
    String testString = &amp;quot;This is a test!&amp;quot;;&lt;br /&gt;
    cipher.init(Cipher.ENCRYPT_MODE, (Key) null, new SecureRandom());&lt;br /&gt;
    byte[] b1 = cipher.doFinal(testString.getBytes());&lt;br /&gt;
    cipher.init(Cipher.DECRYPT_MODE, (Key) null, new SecureRandom());&lt;br /&gt;
    byte[] b2 = cipher.doFinal(b1);&lt;br /&gt;
    System.out.println(&amp;quot;Decrypted data as a String: &amp;quot; + new String(b2));&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Get cryptographic security providers ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.security.Provider;&lt;br /&gt;
import java.security.Security;&lt;br /&gt;
import java.util.HashSet;&lt;br /&gt;
import java.util.Set;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) {&lt;br /&gt;
    Set&amp;lt;Object&amp;gt; result = new HashSet&amp;lt;Object&amp;gt;();&lt;br /&gt;
    Provider[] providers = Security.getProviders();&lt;br /&gt;
    for (Provider provider : providers) {&lt;br /&gt;
      Set&amp;lt;Object&amp;gt; keys = provider.keySet();&lt;br /&gt;
      for (Object key : keys) {&lt;br /&gt;
        String data = (String) key;&lt;br /&gt;
        data = data.split(&amp;quot; &amp;quot;)[0];&lt;br /&gt;
        if (data.startsWith(&amp;quot;Alg.Alias&amp;quot;)) {&lt;br /&gt;
          data = data.substring(10);&lt;br /&gt;
        }&lt;br /&gt;
        data = data.substring(0, data.indexOf(&amp;quot;.&amp;quot;));&lt;br /&gt;
        result.add(data);&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    for (Object o : result) {&lt;br /&gt;
      System.out.println(&amp;quot;Service Type = &amp;quot; + o);&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Get Provider Info ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.security.Provider;&lt;br /&gt;
import java.security.Security;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
  public static void main(String[] args) {&lt;br /&gt;
    System.out.println(&amp;quot;Providers installed on your system:&amp;quot;);&lt;br /&gt;
    Provider[] providerList = Security.getProviders();&lt;br /&gt;
    for (int i = 0; i &amp;lt; providerList.length; i++) {&lt;br /&gt;
      System.out.println(&amp;quot;[&amp;quot; + (i + 1) + &amp;quot;] - Provider name: &amp;quot; + providerList[i].getName());&lt;br /&gt;
      System.out.println(&amp;quot;Provider version number: &amp;quot; + providerList[i].getVersion());&lt;br /&gt;
      System.out.println(&amp;quot;Provider information:\n&amp;quot; + providerList[i].getInfo());&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
/*Providers installed on your system:&lt;br /&gt;
[1] - Provider name: SUN&lt;br /&gt;
Provider version number: 1.6&lt;br /&gt;
Provider information:&lt;br /&gt;
SUN (DSA key/parameter generation; DSA signing; SHA-1, MD5 digests; SecureRandom; X.509 certificates; JKS keystore; PKIX CertPathValidator; PKIX CertPathBuilder; LDAP, Collection CertStores, JavaPolicy Policy; JavaLoginConfig Configuration)&lt;br /&gt;
[2] - Provider name: SunRsaSign&lt;br /&gt;
Provider version number: 1.5&lt;br /&gt;
Provider information:&lt;br /&gt;
Sun RSA signature provider&lt;br /&gt;
[3] - Provider name: SunJSSE&lt;br /&gt;
Provider version number: 1.6&lt;br /&gt;
Provider information:&lt;br /&gt;
Sun JSSE provider(PKCS12, SunX509 key/trust factories, SSLv3, TLSv1)&lt;br /&gt;
[4] - Provider name: SunJCE&lt;br /&gt;
Provider version number: 1.6&lt;br /&gt;
Provider information:&lt;br /&gt;
SunJCE Provider (implements RSA, DES, Triple DES, AES, Blowfish, ARCFOUR, RC2, PBE, Diffie-Hellman, HMAC)&lt;br /&gt;
[5] - Provider name: SunJGSS&lt;br /&gt;
Provider version number: 1.0&lt;br /&gt;
Provider information:&lt;br /&gt;
Sun (Kerberos v5, SPNEGO)&lt;br /&gt;
[6] - Provider name: SunSASL&lt;br /&gt;
Provider version number: 1.5&lt;br /&gt;
Provider information:&lt;br /&gt;
Sun SASL provider(implements client mechanisms for: DIGEST-MD5, GSSAPI, EXTERNAL, PLAIN, CRAM-MD5; server mechanisms for: DIGEST-MD5, GSSAPI, CRAM-MD5)&lt;br /&gt;
[7] - Provider name: XMLDSig&lt;br /&gt;
Provider version number: 1.0&lt;br /&gt;
Provider information:&lt;br /&gt;
XMLDSig (DOM XMLSignatureFactory; DOM KeyInfoFactory)&lt;br /&gt;
[8] - Provider name: SunPCSC&lt;br /&gt;
Provider version number: 1.6&lt;br /&gt;
Provider information:&lt;br /&gt;
Sun PC/SC provider&lt;br /&gt;
[9] - Provider name: SunMSCAPI&lt;br /&gt;
Provider version number: 1.6&lt;br /&gt;
Provider information:&lt;br /&gt;
Sun&amp;quot;s Microsoft Crypto API provider&lt;br /&gt;
*/&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Listing All Available Cryptographic Services ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.security.Provider;&lt;br /&gt;
import java.security.Security;&lt;br /&gt;
import java.util.HashSet;&lt;br /&gt;
import java.util.Iterator;&lt;br /&gt;
import java.util.Set;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] argv) throws Exception {&lt;br /&gt;
    Set result = new HashSet();&lt;br /&gt;
    Provider[] providers = Security.getProviders();&lt;br /&gt;
    for (int i = 0; i &amp;lt; providers.length; i++) {&lt;br /&gt;
      Set keys = providers[i].keySet();&lt;br /&gt;
      for (Iterator it = keys.iterator(); it.hasNext();) {&lt;br /&gt;
        String key = (String) it.next();&lt;br /&gt;
        key = key.split(&amp;quot; &amp;quot;)[0];&lt;br /&gt;
        if (key.startsWith(&amp;quot;Alg.Alias.&amp;quot;)) {&lt;br /&gt;
          // Strip the alias&lt;br /&gt;
          key = key.substring(10);&lt;br /&gt;
        }&lt;br /&gt;
        int ix = key.indexOf(&amp;quot;.&amp;quot;);&lt;br /&gt;
        result.add(key.substring(0, ix));&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    System.out.println(result);&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
[KeyFactory, &lt;br /&gt;
TransformService, &lt;br /&gt;
CertPathBuilder, &lt;br /&gt;
Cipher, &lt;br /&gt;
SecureRandom, &lt;br /&gt;
Signature, &lt;br /&gt;
AlgorithmParameterGenerator, &lt;br /&gt;
KeyPairGenerator, &lt;br /&gt;
XMLSignatureFactory, &lt;br /&gt;
CertificateFactory, &lt;br /&gt;
MessageDigest, &lt;br /&gt;
KeyInfoFactory, &lt;br /&gt;
KeyAgreement, &lt;br /&gt;
CertStore, &lt;br /&gt;
Configuration, &lt;br /&gt;
SSLContext, &lt;br /&gt;
SaslServerFactory, &lt;br /&gt;
AlgorithmParameters, &lt;br /&gt;
TrustManagerFactory, &lt;br /&gt;
GssApiMechanism, &lt;br /&gt;
TerminalFactory, &lt;br /&gt;
Mac, &lt;br /&gt;
KeyGenerator, &lt;br /&gt;
Policy, &lt;br /&gt;
CertPathValidator, &lt;br /&gt;
SaslClientFactory, &lt;br /&gt;
SecretKeyFactory, &lt;br /&gt;
KeyManagerFactory, &lt;br /&gt;
KeyStore, &lt;br /&gt;
Provider]&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  List the available capabilities for ciphers, key agreement, macs, message digests, signatures and other objects in the BC provider. ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.security.Provider;&lt;br /&gt;
import java.security.Security;&lt;br /&gt;
import java.util.Iterator;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
  public static void main(String[] args) {&lt;br /&gt;
    Provider provider = Security.getProvider(&amp;quot;BC&amp;quot;);&lt;br /&gt;
    Iterator it = provider.keySet().iterator();&lt;br /&gt;
    while (it.hasNext()) {&lt;br /&gt;
      String entry = (String) it.next();&lt;br /&gt;
      if (entry.startsWith(&amp;quot;Alg.Alias.&amp;quot;)) {&lt;br /&gt;
        entry = entry.substring(&amp;quot;Alg.Alias.&amp;quot;.length());&lt;br /&gt;
      }&lt;br /&gt;
      System.out.println(entry);&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Return the available implementations for a service type ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.security.Provider;&lt;br /&gt;
import java.security.Security;&lt;br /&gt;
import java.util.HashSet;&lt;br /&gt;
import java.util.Iterator;&lt;br /&gt;
import java.util.Set;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] argv) throws Exception {&lt;br /&gt;
    Set result = new HashSet();&lt;br /&gt;
    String serviceType = &amp;quot;KeyFactory&amp;quot;;&lt;br /&gt;
    Provider[] providers = Security.getProviders();&lt;br /&gt;
    for (int i = 0; i &amp;lt; providers.length; i++) {&lt;br /&gt;
      Set keys = providers[i].keySet();&lt;br /&gt;
      for (Iterator it = keys.iterator(); it.hasNext();) {&lt;br /&gt;
        String key = (String) it.next();&lt;br /&gt;
        key = key.split(&amp;quot; &amp;quot;)[0];&lt;br /&gt;
        if (key.startsWith(serviceType + &amp;quot;.&amp;quot;)) {&lt;br /&gt;
          result.add(key.substring(serviceType.length() + 1));&lt;br /&gt;
        } else if (key.startsWith(&amp;quot;Alg.Alias.&amp;quot; + serviceType + &amp;quot;.&amp;quot;)) {&lt;br /&gt;
          result.add(key.substring(serviceType.length() + 11));&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    System.out.println(result);&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
[1.2.840.113549.1.3.1, &lt;br /&gt;
OID.1.2.840.113549.1.1, &lt;br /&gt;
1.2.840.113549.1.1, &lt;br /&gt;
OID.1.2.840.113549.1.3.1, &lt;br /&gt;
1.3.14.3.2.12, &lt;br /&gt;
DSA, DiffieHellman, RSA, DH, 1.2.840.10040.4.1]&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Security.getProviders() ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.security.Provider;&lt;br /&gt;
import java.security.Security;&lt;br /&gt;
import java.util.Enumeration;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
  public static void main(String args[]) throws Exception{&lt;br /&gt;
      Provider p[] = Security.getProviders();&lt;br /&gt;
      for (int i = 0; i &amp;lt; p.length; i++) {&lt;br /&gt;
        System.out.println(p[i]);&lt;br /&gt;
        for (Enumeration e = p[i].keys(); e.hasMoreElements();)&lt;br /&gt;
          System.out.println(&amp;quot;\t&amp;quot; + e.nextElement());&lt;br /&gt;
      }&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;/div&gt;</summary>
			</entry>

	</feed>