由于工作需求破解了微信的数据库 并获取想要的信息上传服务器 都是内部手机 网上大神反编译了微信 发现微信的数据库是通过
手机的IMEI(唯一识别码) + UIN 大写的IMEI + UIN 进行MD5加密 取32位小写 的前7位就是破解数据库的密码
这是核心原理 根据这个 可以手动获取IMEI 加上UIN 通过 http://tool.chinaz.com/Tools/MD5.aspx线上加密
手动破解不用写代码这种
IMEI 应该不用我说 设置里自己去看 下载三方软件也可以看
至于 UIN 是在 data data com.tencent.mm shared_prefs 文件里的
aunt_info_key_prefs.xml 在这个文件里的 value 值就是了 我们要找到Uin
还有一个问题 网上提及的很少 微信的数据库加密是通过getDeviceID 这个函数会随机获取 IMEI 1 IMEI2 和MEID 进行加密 我已经确认了
肯定不会获取 IMEI2 只会通过默认卡1 IMEI1 和MEID进行 加密 如果破解失败可以用MEID 尝试进行破解 我在下面的连接数据库那做了这个机制
失败就走 MEID试一遍 MEID无法直接获取 我们都是手动获取的把MEID放在文件里 进行读取

接下来就是写代码了 微信数据库也是比较火 网上资料不少的 我也是参考了好多
[java] view plain copy
public static final String WX_ROOT_PATH = “/data/data/com.tencent.mm/”;

// U ID 文件路径
private static final String WX_SP_UIN_PATH = WX_ROOT_PATH + “shared_prefs/auth_info_key_prefs.xml”;

private String mDbPassword;

// 提交参数

private int count=0;

private String IMEI;

private String Uin;

private static final String WX_DB_DIR_PATH = WX_ROOT_PATH + “MicroMsg”;

private List mWxDbPathList = new ArrayList<>();

private static final String WX_DB_FILE_NAME = “EnMicroMsg.db”;

private String mCurrApkPath = “/data/data/” + MyApplication.getContextObject().getPackageName() + “/”;

private static final String COPY_WX_DATA_DB = “wx_data.db”;

// 我是放在了服务里 做了延迟每隔一个小时破解一次 可以去掉

d

public void onCreate() {
super.onCreate();
// 获取root权限
execRootCmd(“chmod -R 777 ” + WX_ROOT_PATH);
execRootCmd(“chmod 777 /data/data/com.tencent.mm/shared_prefs/auth_info_key_prefs.xml”);

Toast.makeText(this,”开启服务”,Toast.LENGTH_LONG).show();

Timer timer = new Timer();  timer.schedule(new TimerTask() {  @Override  public void run() {  // 获取微信的U id  initCurrWxUin();  //sqlt= (EditText) findViewById(sqlt);  // 获取 IMEI 唯一识别码  TelephonyManager phone = (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE);  IMEI = phone.getDeviceId();  System.out.println("IMEI"+IMEI);  // 根据imei和uin生成的md5码,获取数据库的密码(去前七位的小写字母)  initDbPassword(IMEI, Uin);  System.out.println(mDbPassword + "数据库的密码");  System.out.println("开始统计好友数量");  //  递归查询微信本地数据库文件  File wxDataDir = new File(WX_DB_DIR_PATH);  mWxDbPathList.clear();  searchFile(wxDataDir, WX_DB_FILE_NAME);  System.out.println("查询数据库文件");  System.out.println(mWxDbPathList+"读取到的数据库");  try {  在  //处理多账号登陆情况      // 这里要注意 微信登陆多个账号会产生 多个数据库文件   // 所有我们需要把每个数据库文件都尝试破解一下 总有一个密码正确连接成功  // 有需要可以把注释解开     //  现在的写法是取集合遍历出来的数据库最后一个 我发现遍历的函数很大几率从老文件开是遍历  // 最后遍历的db 数据库很可能是新的 也就是当前账号的 但并不稳定 因为这个函数并没有解释  //   是从老的开始遍历  两个数据库的情况下 最后一个数据库确实是新的  // for (int i = 0; i < mWxDbPathList.size(); i++) {  File file = mWxDbPathList.get(mWxDbPathList.size()-1);   File file = mWxDbPathList.get(i); // 正常写法  String copyFilePath = mCurrApkPath + COPY_WX_DATA_DB;                //将微信数据库拷贝出来,因为直接连接微信的db,会导致微信崩溃  当前数据库只能连接一个              copyFile(file.getAbsolutePath(), copyFilePath);                 File copyWxDataDb = new File(copyFilePath);                openWxDb(copyWxDataDb);

// }

  }catch (Exception e){  // Toast.makeText(getApplicationContext(),"解析失败",Toast.LENGTH_LONG).show();  }  // 上传统计数据  login();  }

}, 1000, 3600000);//0是延时;100是间隔

相关
相关工具类 直接复制就行 环境复制就


/**
* 执行linux指令
*
* @param paramString
*/
public void execRootCmd(String paramString) {
try {
Process localProcess = Runtime.getRuntime().exec(“su”);
Object localObject = localProcess.getOutputStream();
DataOutputStream localDataOutputStream = new DataOutputStream((OutputStream) localObject);
String str = String.valueOf(paramString);
localObject = str + “\n”;
localDataOutputStream.writeBytes((String) localObject);
localDataOutputStream.flush();
localDataOutputStream.writeBytes(“exit\n”);
localDataOutputStream.flush();
localProcess.waitFor();
localObject = localProcess.exitValue();
} catch (Exception localException) {
localException.printStackTrace();
}
}

/**
* 获取微信的uid
* 微信的uid存储在SharedPreferences里面
* 存储位置\data\data\com.tencent.mm\shared_prefs\auth_info_key_prefs.xml
*/
private void initCurrWxUin() {
Uin = null;
File file = new File(WX_SP_UIN_PATH);
try {
FileInputStream in = new FileInputStream(file);
SAXReader saxReader = new SAXReader();
Document document = saxReader.read(in);
Element root = document.getRootElement();
List elements = root.elements();
for (Element element : elements) {
if (“_auth_uin”.equals(element.attributeValue(“name”))) {
Uin = element.attributeValue(“value”);
}
}
} catch (Exception e) {
e.printStackTrace();
LogUtil.e(“获取微信uid失败,请检查auth_info_key_prefs文件权限”);
}
}
/**
* 根据imei和uin生成的md5码,获取数据库的密码(去前七位的小写字母)
*
* @param imei
* @param uin
* @return
*/
private void initDbPassword(String imei, String uin) {
if (TextUtils.isEmpty(imei) || TextUtils.isEmpty(uin)) {
LogUtil.e(“初始化数据库密码失败:imei或uid为空”);
return;
}
String md5 = getMD5(imei + uin);
System.out.println(imei+uin+”初始数值”);
System.out.println(md5+”MD5”);
String password = md5.substring(0, 7).toLowerCase();
System.out.println(“加密后”+password);
mDbPassword = password;
}

public String getMD5(String info)
{
try
{
MessageDigest md5 = MessageDigest.getInstance(“MD5”);
md5.update(info.getBytes(“UTF-8”));
byte[] encryption = md5.digest();

    StringBuffer strBuf = new StringBuffer();  for (int i = 0; i < encryption.length; i++)  {  if (Integer.toHexString(0xff & encryption[i]).length() == 1)  {  strBuf.append("0").append(Integer.toHexString(0xff & encryption[i]));  }  else  {  strBuf.append(Integer.toHexString(0xff & encryption[i]));  }  }  return strBuf.toString();
}
catch (NoSuchAlgorithmException e)
{  return "";
}
catch (UnsupportedEncodingException e)
{  return "";
}

}

/**
* md5加密
*
* @param content
* @return
*/
private String md5(String content) {
MessageDigest md5 = null;
try {
md5 = MessageDigest.getInstance(“MD5”);
md5.update(content.getBytes(“UTF-8”));
byte[] encryption = md5.digest();//加密
StringBuffer sb = new StringBuffer();
for (int i = 0; i < encryption.length; i++) {
if (Integer.toHexString(0xff & encryption[i]).length() == 1) {
sb.append(“0”).append(Integer.toHexString(0xff & encryption[i]));
} else {
sb.append(Integer.toHexString(0xff & encryption[i]));
}
}
return sb.toString();
} catch (Exception e) {
e.printStackTrace();
return null;
}
}

/**
* 递归查询微信本地数据库文件
*
* @param file 目录
* @param fileName 需要查找的文件名称
*/
private void searchFile(File file, String fileName) {
// 判断是否是文件夹
if (file.isDirectory()) {
// 遍历文件夹里所有数据
File[] files = file.listFiles();
if (files != null) {
for (File childFile : files) {
searchFile(childFile, fileName);
}
}
} else {
if (fileName.equals(file.getName())) {
mWxDbPathList.add(file);
}
}
}

/**
* 复制单个文件
*
* @param oldPath String 原文件路径 如:c:/fqf.txt
* @param newPath String 复制后路径 如:f:/fqf.txt
* @return boolean
*/
public void copyFile(String oldPath, String newPath) {
try {
int byteRead = 0;
File oldFile = new File(oldPath);
if (oldFile.exists()) { //文件存在时
InputStream inStream = new FileInputStream(oldPath); //读入原文件
FileOutputStream fs = new FileOutputStream(newPath);
byte[] buffer = new byte[1444];
while ((byteRead = inStream.read(buffer)) != -1) {
fs.write(buffer, 0, byteRead);
}
inStream.close();
}
} catch (Exception e) {
System.out.println(“复制单个文件操作出错”);
e.printStackTrace();

}

}


// 重点到了 我们之前的操作 遍历文件获取的db 数据库 以及密码 现在就可以用 数据库和密码进行连接
密码正确 成功进入数据库 获取表信息 我下面获取的是好友的总人数 误差在 + -2 直接大部分这个
这个需要自己观察表 进行查询

/**
* 连接数据库
*
* @param dbFile
*/
private void openWxDb(File dbFile) {
Context context = MyApplication.getContextObject();
SQLiteDatabase.loadLibs(context);
SQLiteDatabaseHook hook = new SQLiteDatabaseHook() {
public void preKey(SQLiteDatabase database) {
}

        public void postKey(SQLiteDatabase database) {  database.rawExecSQL("PRAGMA cipher_migrate;"); //兼容2.0的数据库  }  };  try {  //打开数据库连接  SQLiteDatabase db = SQLiteDatabase.openOrCreateDatabase(dbFile, mDbPassword, null, hook);  //查询所有好友总数(verifyFlag!=0:公众号等类型,群里面非好友的类型为4,未知类型2)  // Cursor c1 = db.rawQuery("select * from rcontact where verifyFlag = 0  and type != 4 and type != 2 and type !=33 limit 20, 9999", null);  Cursor c1 = db.rawQuery("select * from rcontact where username not like 'gh_%' and verifyFlag<>24 and verifyFlag<>29 and verifyFlag<>56 and type<>33 and type<>70 and verifyFlag=0 and type<>4 and type<>0 and showHead<>43 and type<>65536",null);  while (c1.moveToNext()) {  String type = c1.getString(c1.getColumnIndex("type"));  System.out.println(type+"参数");  count++;  }  // sqlt.setText("好友总数"+count);  System.out.println("总共参数"+count);  //  Toast.makeText(getApplicationContext(),"好友总数"+count,Toast.LENGTH_SHORT).show();  c1.close();  db.close();  } catch (Exception e) {  LogUtil.e("读取数据库信息失败");

// e.printStackTrace();
//打开数据库连接
// 根据imei和uin生成的md5码,获取数据库的密码(去前七位的小写字母)
/// initDbPassword(“A100004AF6C883”, Uin);
String MEID=readFileSdcard(“/mnt/sdcard/meid.txt”);
String dMEID=MEID.replace(“\r\n”,”“);
initDbPassword(dMEID.toUpperCase(),Uin);
System.out.println(mDbPassword+”MEID—密码”);
count=0;
SQLiteDatabase db = SQLiteDatabase.openOrCreateDatabase(dbFile, mDbPassword, null, hook);

        //查询所有联系人(verifyFlag!=0:公众号等类型,群里面非好友的类型为4,未知类型2)  // 获取好友总数  // Cursor c1 = db.rawQuery("select * from rcontact where verifyFlag = 0  and type != 4 and type != 2 and type !=33 limit 20, 9999", null);  Cursor c1 = db.rawQuery("select * from rcontact where username not like 'gh_%' and verifyFlag<>24 and verifyFlag<>29 and verifyFlag<>56 and type<>33 and type<>70 and verifyFlag=0 and type<>4 and type<>0 and showHead<>43 and type<>65536",null);  while (c1.moveToNext()) {  String type = c1.getString(c1.getColumnIndex("type"));  System.out.println(type+"参数");  count++;  //Toast.makeText(getApplicationContext(),type,Toast.LENGTH_SHORT).show();  }  // sqlt.setText("好友总数"+count);  // Toast.makeText(getApplicationContext(),"好友总数"+count,Toast.LENGTH_SHORT).show();  System.out.println("总共参数"+count);  c1.close();  db.close();  }
}  //*//*读在/mnt/sdcard/目录下面的文件
public String readFileSdcard(String fileName){  String res="";  try{  FileInputStream fin = new FileInputStream(fileName);  int length = fin.available();  byte [] buffer = new byte[length];  fin.read(buffer);  res = EncodingUtils.getString(buffer, "UTF-8");  fin.close();  }  catch(Exception e){  e.printStackTrace();  }  return res;  }

相关博客 我也是参考他完成的需求 http://m.blog.csdn.net/article/details?id=54024442 写的更详细

破解成功LOG 会打印相关 信息可以进行查询 也可以下载个 sqlcipher 数据库可视化工具 进行查看

破解微信数据库 并查询数据上传服务器相关推荐

  1. STM32--ESP8266物联网WIFI模块(贝壳物联)--温湿度数据上传服务器显示

    本文适用于STM32F103C8T6等MCU,其他MCU可以移植,完整资源见文末链接 一.简介 随着移动物联网的发展,各场景下对于物联控制.数据上传.远程控制的诉求也越来越多,基于此乐鑫科技推出了便宜 ...

  2. Arduino--ESP8266物联网WIFI模块(贝壳物联)--数据上传服务器(单数据接口)

    一.简介 随着移动物联网的发展,各场景下对于物联控制.数据上传.远程控制的诉求也越来越多,基于此乐鑫科技推出了便宜好用性价比极高的wifi物联模块--ESP8266,话不多少我们先来看看这个神奇的模块 ...

  3. 微信小程录制视频上传服务器,微信小程序-从相册获取图片,视频使用相机拍照,录像上传+服务器nodejs版接收-微信小程序视频上传功能-微信小程序视频上传...

    在本文微信小程序-从相册获取图片使用相机拍照本地图片上传之前需要看看微信小程序-获取用户session_key,openid,unionid-后端为nodejs代码封装是在上文添加的.本文知识点:1. ...

  4. Excel数据上传并且导入数据库

    Excel数据上传并导入数据库 Excel表中的数据示例样板 相关依赖(本博客编写环境springboot) <!--poi实现excel导入导出--><dependency> ...

  5. 小程序空显示undefined_微信小程序显示ESP8266上传的实时显示温湿度数据

    第一.原理讲解 原理简述:利用发布订阅模式.第一步,先读取DHT11温湿度数值,第二步,新建主题,然后esp8266往这个主题发送消息,第三步.小程序通过http API接口获取数据.小程序控制原理: ...

  6. STM32控制NB-IOT将数据上传至微信与网站显示

    利用nb-iot的Modbus协议将获取的数据发至服务器,通过微信与网站显示 前段时间给同学做了一个小项目.基于stm32103获取空气质量数据,温湿度等信息,然后利用nb-iot上传.之前一直听过这 ...

  7. 树莓派数据上传数据库_树莓派内部数据向domoticz的上传

    树莓派的数据上传->Domoticz 树莓派的温度检测到的数据可以通过API发送到domoticz 示例代码:#!/usr/bin/env python # -*- coding:utf-8 - ...

  8. android拦截请求数据库,拦截所有App的网络请求并将需要的数据上传到属于你自己的服务器...

    前提 : 有时会遇到这样的需求:将一些别人app上比较优质的内容,用到自己产品中.由于别人的app做了大量的参数加密, 我们获取不到加密规则,所以使用接口直接调用的方法就走不通. 本文就是要介绍使用逆 ...

  9. 微信朋友圈的图片上传,多图上传怎么去撸才合适?我们一起来实现吧!

    微信朋友圈的图片上传,多图上传怎么去撸才合适?我们一起来实现吧! 图片上传是非常常见的功能,而多图上传在大多数应用中也是非常常见的,比如微信的朋友圈,微博的动态,都是有九宫格图片的,那这里肯定涉及了多 ...

最新文章

  1. SpringMVC工作环境搭建 配置文件
  2. R 语言爬虫 之 cnblog博文爬取
  3. win7安装gtp磁盘_GPT转MBR分区格式安装win7/win10系统教程
  4. 几个常用的JS代码.
  5. 搬运 centos7.2 apache 绑定二级目录 访问依然是apache页面
  6. 一对一,一对多,多对多查询 (注解写法)
  7. edge 浏览器中数字显示为链接
  8. 通过了微软的SharePoint认证考试(70-542: Microsoft Office SharePoint Server 2007 - Application Development)...
  9. 十年站长人生路不言放弃 访资深个人站长游伟
  10. python从入门到放弃表情图-Python 从入门到放弃(一)
  11. pyqt5 实现右键自定义_Python界面(GUI)编程PyQt5事件和信号
  12. 第七章 数据库设计(联系毕业论文))
  13. 报错:UnicodeDecodeError: ‘gbk‘ codec can‘t decode byte 0x93 in position 1721: illegal multibyte sequen
  14. strtolower()和strtoupper()中文乱码问题
  15. 搭建企业私有Git服务
  16. 机器人相关专家研究机构
  17. android模拟器 百度云盘,MEmu逍遥安卓模拟器海外纯净版
  18. 什么是C语言的合法正确标识符?什么是C语言关键字?
  19. 程序员钱多多准备应聘拼多多
  20. docker对已经启动的容器添加目录映射(挂载目录)

热门文章

  1. bat脚本实现遍历文件夹下所有jar文件名
  2. 《java核心技术36讲》学习笔记-------杨晓峰(极客时间)
  3. 【算法竞赛从入门到精通】【基础算法】
  4. Android之手机振动和振铃
  5. JAVA常见类(十二)Calendar类
  6. HIT 大物实验 数据处理代码
  7. 云效安全那些事儿-Codeup代码智能安全检测服务
  8. python人机猜拳游戏代码_python 实现人和电脑猜拳的示例代码
  9. php药物,php药品进销存管理系统
  10. matlab系列之(一)——利用matlab实现任意两个多项式相加