android客户端手机号码解密方法

来源:未知 责任编辑:责任编辑 发表时间:2014-05-26 10:58 点击:

由于58同城在页面上抓取二手房信息的时候,用户的联系电话是图片的,本人水平关系无法进行很好的识别,所以转为抓取其android客户端比较容易,之前都是好好的,最近发现其升级到1.3.0.0后手机号码进行了加密,所以直接反编译其android客户端,查到其用的是des加密,而且加密的key很容易就拿到,下面贴出解密方法。(des加解密比较简单下面贴出来)
 
Java代码 
import java.security.SecureRandom; 
import javax.crypto.Cipher; 
import javax.crypto.SecretKey; 
import javax.crypto.SecretKeyFactory; 
import javax.crypto.spec.DESKeySpec; 
 
public class Decode458 { 
    static byte[] key = null; //这个key如果有需要请反编译58客户端获取这里不便贴出 
     
    public static void main(String[] args) throws Exception { 
        System.out.println(new String(Decode458.decode(Decode458.convertHexString("002E674657AE8239982087DCB2E6A99B")))); 
        System.out.println(Decode458.toHexString(Decode458.encode("13219863008".getBytes()))); 
    } 
     
    public static byte[] decode(byte[] paramArrayOfByte) { 
        try { 
            SecureRandom localSecureRandom = new SecureRandom(); 
            DESKeySpec localDESKeySpec = new DESKeySpec(key); 
            SecretKey localSecretKey = SecretKeyFactory.getInstance("DES") 
                    .generateSecret(localDESKeySpec); 
            Cipher localCipher = Cipher.getInstance("DES"); 
            localCipher.init(2, localSecretKey, localSecureRandom); 
            return localCipher.doFinal(paramArrayOfByte); 
        } catch (Exception e) { 
            e.printStackTrace(); 
            return null; 
        } 
    } 
     
    public static byte[] encode(byte[] paramArrayOfByte) { 
        try { 
            SecureRandom localSecureRandom = new SecureRandom(); 

发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
用户名: 验证码:点击我更换图片
最新评论 更多>>

推荐热点

  • Android 完全退出程序
  • 原创:Android应用开发-Andorid歌词秀,含源码
  • android 屏幕保护
  • Android手机软件汉化教程---第四课 dex文件汉化
  • 众多Android 开源项目推荐,给力工作给力学习
  • Android Audio代码分析4
  • Android得到已安装的应用程序信息!
  • Android开发者指南(29) —— USB Host and Accessory
  • Android成长的幕后推手:工程师鲁宾
网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
Copyright © 2008-2015 计算机技术学习交流网. 版权所有

豫ICP备11007008号-1