基于Android与.net服务器RSA加密算法的数据加密
2016-07-29 18:08
344 查看
public class EncryptCode { private static File file; /** * 加密方法 * source: 源数据 */ public static String encrypt(String source) throws Exception { // 用证书的公钥加密 CertificateFactory cff = CertificateFactory.getInstance("X.509"); FileInputStream fis1 = new FileInputStream(file); // 证书文件 Certificate cf = cff.generateCertificate(fis1); PublicKey pk1 = cf.getPublicKey(); // 得到证书文件携带的公钥 BASE64Encoder bse = new BASE64Encoder(); Cipher c1 = Cipher.getInstance("RSA/ECB/PKCS1Padding"); // 定义算法:RSA c1.init(Cipher.ENCRYPT_MODE,pk1); byte[] msg1 = c1.doFinal(source.getBytes()); // 加密后的数据 String encode = bse.encode(msg1); //使用base64进行编码 return encode; //返回加密结果 } /** * 加密证书的拷贝 */ public static void copyDb(String certificate,Context ctx) { InputStream in = null; FileOutputStream out = null; try { //获取本地目录路径 File filesDir = ctx.getFilesDir(); file = new File(filesDir,certificate); if (file.exists()) { return; } AssetManager assets = ctx.getAssets();//资产管理器 in = assets.open(certificate); out = new FileOutputStream(file); int len; byte[] buffer = new byte[1024]; while ((len = in.read(buffer)) != -1) { out.write(buffer,0,len); } } catch (IOException e) { e.printStackTrace(); } finally { try { in.close(); out.close(); } catch (Exception e) { e.printStackTrace(); } } } }
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- Android IPC进程间通讯机制
- Android Manifest 用法
- [转载]Activity中ConfigChanges属性的用法
- Android之获取手机上的图片和视频缩略图thumbnails
- Android之使用Http协议实现文件上传功能
- Android学习笔记(二九):嵌入浏览器
- android string.xml文件中的整型和string型代替
- i-jetty环境搭配与编译
- android之定时器AlarmManager
- android wifi 无线调试
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- android 代码实现控件之间的间距
- android FragmentPagerAdapter的“标准”配置
- Android"解决"onTouch和onClick的冲突问题
- android:installLocation简析
- android searchView的关闭事件
- SourceProvider.getJniDirectories