Linux下搭建Bouncycastle环境

Bouncycastle是一种Java平台开放源码的轻量级密码术包,可用来管理Android的证书。此次因为需要自己生成Https的证书,因此,专门学习了一下搭建Bouncycastle环境的方法,对学习过程记录如下:

一、环境

我使用的环境信息如下:

  • Linux版本:CentOS 5.8 64位操作系统
  • Java版本:1.6.0_35

二、搭建步骤

  1. 下载Bouncycastle的Jar包,官方网站地址是:Bouncycastle官网,网页上有两个可以下载的,一个是crypto-154.tar.gZ(文件较小,但是我下载了以后,出现无法解压的现象,windows和linux下均无法解压),另外一个是crypto-154.zip,推荐下载该版本,文件较大,可以直接解压得到jar文件夹,这里因为我的java版本是1.6的所以选择了bcprov-debug-jdk15on-154.jar

  2. 或者也可以直接点击下载 bcprov-jdk15on-146.jar

  3. 将下载得到的Jar包上传到linux服务器上,找到java的根目录,将其放在jre/lib/ext/目录下。如果找不到jre的路径,可以使用echo命令进行打印,echo $JAVA_HOME

    这里写图片描述

  4. 修改jre/lib/security/java.security文件,在其provider列表中添加一条:
    security.provider.10=org.bouncycastle.jce.provider.BouncyCastleProvider

    这里写图片描述

    安装到此结束

三、测试

新建Test.java文件,添加以下代码:

    import javax.crypto.Cipher;
    import javax.crypto.KeyGenerator;
    import javax.crypto.SecretKey;

    public class Test
    {
        public static final String stringToEncrypt = "Thisis a test.";

        public static void main(String[] args) throws Exception
        {
            System.out.print("Attemptingto get a Blowfish key...");
            KeyGenerator keyGenerator = KeyGenerator.getInstance("Blowfish");
            keyGenerator.init(128);
            SecretKey key = keyGenerator.generateKey();
            System.out.println("OK");
            System.out.println("Attemptingto get a Cipher and encrypt...");
            Cipher cipher = Cipher.getInstance("Blowfish/ECB/PKCS5Padding");
            cipher.init(Cipher.ENCRYPT_MODE, key);
            byte[] cipherText = cipher.doFinal(stringToEncrypt.getBytes("UTF8"));
            System.out.println("OK");
            System.out.println("Testcompleted successfully.");
        }
    }

当输出结果为下文时,代表搭建成功

Attemptingto get a Blowfish key...OK
Attemptingto get a Cipher and encrypt...
OK
Testcompleted successfully.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Bouncycastle官网是一个开源密码学软件库的官方网站,提供了大量关于Bouncycastle的信息,包括软件下载、文档、论坛及支持等。Bouncycastle是一个Java平台的密码学库,提供了一系列的密码学算法,包括对基本的加密和解密、数字签名、密钥交换协议、摘要算法和消息认证代码进行支持。 官网上有许多关于Bouncycastle的资讯,包括各个版本的下载、使用指南和安全警告等,用户可以通过官网快速地获取最新版软件的信息。此外,官网还提供了多种语言版本的教程和实例,方便开发者们学习和使用Bouncycastle的各种功能,以及解决以上出现的一些常见问题。 最后,官网还提供了论坛,使用户能够进行交流和讨论,分享他们的经验和评论。这不仅有助于解决一些技术问题,还能提高各类开发者的技术水平和学习能力。 综上所述,Bouncycastle官网是一个提供高质量密码学库软件的官方网站,不仅提供了软件下载和支持,还提供了丰富的教程和实例供用户学习和使用,并通过论坛促进用户之间的交流合作。 ### 回答2: Bouncy Castle是一个Java加密库,它具有许多加密算法,如DES,AES,RSA和DSA,以及一些安全协议和实用工具。 Bouncy Castle官网提供了关于该库的详细信息,包括使用该库进行加密和解密的示例代码以及其他相关资源。该网站还提供了下载库和API文档的链接。此外,Bouncy Castle官网还提供了用户论坛和电子邮件列表,可用于讨论该库的使用和开发。对于开发人员和安全专业人士而言,Bouncy Castle官网是一个非常有价值的资源。它为用户提供了高质量的加密库和对使用和开发该库的支持,使得开发人员能够更轻松地构建安全和可靠的应用程序。如果您是对加密感兴趣的开发人员或安全专业人士,Bouncy Castle官网将是一个不错的资源,值得您花时间来了解。 ### 回答3: Bouncy Castle是一个Java平台上的加密库,其目的是提供各种密码学算法和协议的实现。 Bouncy Castle官网提供了完整的文档和示例代码,以及非常详细的用户指南和API文档。此外,该网站还提供了对Bouncy Castle技术支持的常见问题解答。 Bouncy Castle加密库是由一个名为Legion of the Bouncy Castle的组织创建的,该组织致力于提供无偏见的密码学架构和支持。该库提供了许多加密算法和协议的实现,包括AES,RSA,DSA,ECDSA,Salsa20,Zlib,OpenPGP等等。 Bouncy Castle还提供了关于密码学相关话题的教育资源,例如密码学入门和最新的密码学新闻。如果您对密码学和安全性有兴趣,则Bouncy Castle官网是值得一看的资源。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值