【第22期】观点:IT 行业加班,到底有没有价值?

当服务端为PHP时Android端的RSA加密

原创 2016年08月30日 16:41:17

这是实际项目里封装的一个工具类,代码如下微笑:

import android.util.Base64;

import java.security.KeyFactory;
import java.security.PublicKey;
import java.security.spec.X509EncodedKeySpec;

import javax.crypto.Cipher;

public class RsaUtil {
    private static final String ALGORITHM = "RSA";
    private static final String PUBLIC_KEY =//表示形式为 可以有换行 无空格无--begin--       "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCzlJ2qW0IqiB5F13Awr2vlMjP6" + "\r\n" +
            "ueXOmCG4+EGJx66dzRm35l+8JyCE+j1JUVB9DnsP9raznNvrfmLP83qgpim2chHt" + "\r\n" +
            "JINS2+CtzXVWwPaZtFzHgUE4X2PjSLRxH5CNOB8bb7KITmL2cerXdhHrO4q+Ldcq" + "\r\n" +
            "uu2LKUsDL3HS5YiIkwIDAQAB";

    /**
     * 获得公钥
     *
     * @param algorithm 算法
     * @param key       公钥文本
     */
    private static PublicKey getPublicKeyFromX509(String algorithm, String key) throws Exception {
        byte[] decodedKey = Base64.decode(key, Base64.DEFAULT);
        X509EncodedKeySpec x509 = new X509EncodedKeySpec(decodedKey);
        KeyFactory keyFactory = KeyFactory.getInstance(algorithm);
        return keyFactory.generatePublic(x509);
    }

    /**
     * 使用公钥加密
     *
     * @param content 需要加密的明文 如"123456"
     * @return 加密后的密文,相同明文的所生成的密文是动态变化的,即是不同的,格式如:
     * BXYIdUWYHZjxRM1Pkm8OxVL1ID5mm7HInvNMjwWsRLx9rymm2XadhnxBDDYYnN+i//3wuDQdx/vK
     * BUXygXwIOJwCckme4qpRFW5ANZrESyxRyTCL2JBcgzEVSc0bugXOsvpqbXQGvSY1d8PRSaSpoP19
     * AX3+U5oAh4AWWZZIojg=
     */
    public static String encryptByPublic(String content) {
        try {
            PublicKey publicKey = getPublicKeyFromX509(ALGORITHM, PUBLIC_KEY);
            Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");//此处有黄色警告可以不用管他
       cipher.init(Cipher.ENCRYPT_MODE, publicKey);
            byte plaintext[] = content.getBytes("UTF-8");
            byte[] output = cipher.doFinal(plaintext);
            return new String(Base64.encode(output, Base64.DEFAULT));
        } catch (Exception e) {
            return null;
        }
    }
}

版权声明:本文为博主原创文章,未经博主允许不得转载。 举报

相关文章推荐

Android客户端与PHP服务端RES公钥私钥互加解密

本来并非全部原创,可以归纳为d

OpenVPN 安装、配置客户端和服务端,以及OpenVPN的使用 (Windows 平台)

OpenVPN 开源,好用,而且免费,感谢 OpenVPN 团队开发此产品。   简介 OpenVPN允许参与创建VPN的单点使用公开密钥、电子证书、或者用户名/密码来进行身份验证。它大量使用了Ope...
  • joyous
  • joyous
  • 2012-09-30 15:37
  • 210926

程序员升职加薪指南!还缺一个“证”!

CSDN出品,立即查看!

Android get+post传值获取php服务端的json数据

private void GetResult(String channel_key, String session, String device_id, String api_version, String app_version, String timestamp, String ...

Android客户端与PHP服务端RES公钥私钥互加解密

本来并非全部原创,可以归纳为d

JAVA上百实例源码以及开源项目

简介 笔者当初为了学习JAVA,收集了很多经典源码,源码难易程度分为初级、中级、高级等,详情看源码列表,需要的可以直接下载! 这些源码反映了那时那景笔者对未来的盲目,对代码的热情、执着,对IT的憧憬、向往!此时此景,笔者只专注

OpenVPN 安装、配置客户端和服务端,以及OpenVPN的使用 (Windows 平台)

OpenVPN 开源,好用,而且免费,感谢 OpenVPN 团队开发此产品。   简介 OpenVPN允许参与创建VPN的单点使用公开密钥、电子证书、或者用户名/密码来进行身份验证。...
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)