Android 应用接入广点通统计API 方案

官方给你参考文档,很扯淡,是c++和python脚本:

安卓java代码接入如下:

package com.edaixi.util;

import java.io.UnsupportedEncodingException;
import java.net.SocketException;
import java.net.URLEncoder;
import java.security.MessageDigest;
import android.annotation.SuppressLint;
import android.content.Context;
import android.telephony.TelephonyManager;
import com.lidroid.xutils.HttpUtils;
import com.lidroid.xutils.exception.HttpException;
import com.lidroid.xutils.http.ResponseInfo;
import com.lidroid.xutils.http.callback.RequestCallBack;
import com.lidroid.xutils.http.client.HttpRequest.HttpMethod;

public class TecentAdsUtil {

	private static Context mContext;

	public TecentAdsUtil(Context mContext) {
		super();
		TecentAdsUtil.mContext = mContext;
	}

	@SuppressWarnings("deprecation")
	public void getToTencentAds() throws SocketException {
		String encrypt_key = "*************";
		String IMEIString = getDeviceIMEI();
		String TimeString = getSystemTime();
		String query_string;
		try {
			query_string = "muid=" + URLEncoder.encode(IMEIString, "UTF-8")
					+ "&conv_time=" + URLEncoder.encode(TimeString, "UTF-8");

			String page = "http://t.gdt.qq.com/conv/app/appid" + "/conv?"
					+ query_string;
			String encode_page = URLEncoder.encode(page, "UTF-8");
			String property = "encrypt_key&GET&" + encode_page;
			String signature = string2MD5(property);

			String base_data = query_string + "&sign="
					+ URLEncoder.encode(signature, "UTF-8");
			String base64 = ToBase64(base_data, encrypt_key);
			String data = new String(Base64Util.encode(base64.getBytes()));
			String attachment = "conv_type="
					+ URLEncoder.encode("MOBILEAPP_ACTIVITE", "UTF-8")
					+ "&app_type=" + URLEncoder.encode("ANDROID", "UTF-8")
					+ "&advertiser_id=" + URLEncoder.encode("673411", "UTF-8");
			final String finalUrl = "http://t.gdt.qq.com/conv/app/1104311868/conv?v="
					+ data + "&" + attachment;

			HttpUtils http = new HttpUtils();
			http.configTimeout(10 * 1000);
			http.send(HttpMethod.GET, finalUrl, new RequestCallBack<String>() {

				@Override
				public void onStart() {
				}

				@Override
				public void onFailure(HttpException arg0, String result) {
				}

				@Override
				public void onSuccess(ResponseInfo<String> result) {
					LogUtil.e("===广点通返回的结果==="+result.result);
				}
			});
		} catch (UnsupportedEncodingException e) {
			e.printStackTrace();
		}
	}

	@SuppressLint("DefaultLocale")
	public static String getDeviceIMEI() {
		String imei = ((TelephonyManager) mContext
				.getSystemService(Context.TELEPHONY_SERVICE)).getDeviceId();
		return string2MD5(imei.toLowerCase());
	}

	// 获取当前时间戳
	public static String getSystemTime() {
		long time = System.currentTimeMillis() / 1000;
		return time + "";
	}

	// MD5工具类
	public static String string2MD5(String inStr) {
		MessageDigest md5 = null;
		try {
			md5 = MessageDigest.getInstance("MD5");
		} catch (Exception e) {
			System.out.println(e.toString());
			e.printStackTrace();
			return "";
		}
		char[] charArray = inStr.toCharArray();
		byte[] byteArray = new byte[charArray.length];

		for (int i = 0; i < charArray.length; i++)
			byteArray[i] = (byte) charArray[i];
		byte[] md5Bytes = md5.digest(byteArray);
		StringBuffer hexValue = new StringBuffer();
		for (int i = 0; i < md5Bytes.length; i++) {
			int val = ((int) md5Bytes[i]) & 0xff;
			if (val < 16)
				hexValue.append("0");
			hexValue.append(Integer.toHexString(val));
		}
		return hexValue.toString();

	}

	// Base64工具类
	public static String ToBase64(String base_data, String encrypt_key) {
		char[] base_datachar = base_data.toCharArray();
		char[] base_datacharBak = new char[base_datachar.length];
		char[] encrypt_keychar = encrypt_key.toCharArray();
		int j = 0;
		for (int i = 0; i < base_datachar.length; i++) {
			base_datacharBak[i] = (char) (base_datachar[i] ^ encrypt_keychar[j]);
			j = (++j) % (encrypt_keychar.length);
		}
		return new String(base_datacharBak);
	}

}

  

package com.edaixi.util;

import java.io.UnsupportedEncodingException;

public class Base64Util {
	private static char[] base64EncodeChars = new char[] { ‘A‘, ‘B‘, ‘C‘, ‘D‘,
			‘E‘, ‘F‘, ‘G‘, ‘H‘, ‘I‘, ‘J‘, ‘K‘, ‘L‘, ‘M‘, ‘N‘, ‘O‘, ‘P‘, ‘Q‘,
			‘R‘, ‘S‘, ‘T‘, ‘U‘, ‘V‘, ‘W‘, ‘X‘, ‘Y‘, ‘Z‘, ‘a‘, ‘b‘, ‘c‘, ‘d‘,
			‘e‘, ‘f‘, ‘g‘, ‘h‘, ‘i‘, ‘j‘, ‘k‘, ‘l‘, ‘m‘, ‘n‘, ‘o‘, ‘p‘, ‘q‘,
			‘r‘, ‘s‘, ‘t‘, ‘u‘, ‘v‘, ‘w‘, ‘x‘, ‘y‘, ‘z‘, ‘0‘, ‘1‘, ‘2‘, ‘3‘,
			‘4‘, ‘5‘, ‘6‘, ‘7‘, ‘8‘, ‘9‘, ‘+‘, ‘/‘ };

	private static byte[] base64DecodeChars = new byte[] { -1, -1, -1, -1, -1,
			-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
			-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
			-1, -1, -1, -1, 62, -1, -1, -1, 63, 52, 53, 54, 55, 56, 57, 58, 59,
			60, 61, -1, -1, -1, -1, -1, -1, -1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
			10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1,
			-1, -1, -1, -1, -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37,
			38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1,
			-1, -1 };

	public static String encode(byte[] data) {
		StringBuffer sb = new StringBuffer();
		int len = data.length;
		int i = 0;
		int b1, b2, b3;
		while (i < len) {
			b1 = data[i++] & 0xff;
			if (i == len) {
				sb.append(base64EncodeChars[b1 >>> 2]);
				sb.append(base64EncodeChars[(b1 & 0x3) << 4]);
				sb.append("==");
				break;
			}
			b2 = data[i++] & 0xff;
			if (i == len) {
				sb.append(base64EncodeChars[b1 >>> 2]);
				sb.append(base64EncodeChars[((b1 & 0x03) << 4)
						| ((b2 & 0xf0) >>> 4)]);
				sb.append(base64EncodeChars[(b2 & 0x0f) << 2]);
				sb.append("=");
				break;
			}
			b3 = data[i++] & 0xff;
			sb.append(base64EncodeChars[b1 >>> 2]);
			sb.append(base64EncodeChars[((b1 & 0x03) << 4)
					| ((b2 & 0xf0) >>> 4)]);
			sb.append(base64EncodeChars[((b2 & 0x0f) << 2)
					| ((b3 & 0xc0) >>> 6)]);
			sb.append(base64EncodeChars[b3 & 0x3f]);
		}
		return sb.toString();
	}

	public static byte[] decode(String str) throws UnsupportedEncodingException {
		StringBuffer sb = new StringBuffer();
		byte[] data = str.getBytes("US-ASCII");
		int len = data.length;
		int i = 0;
		int b1, b2, b3, b4;
		while (i < len) {
			/* b1 */
			do {
				b1 = base64DecodeChars[data[i++]];
			} while (i < len && b1 == -1);
			if (b1 == -1)
				break;
			/* b2 */
			do {
				b2 = base64DecodeChars[data[i++]];
			} while (i < len && b2 == -1);
			if (b2 == -1)
				break;
			sb.append((char) ((b1 << 2) | ((b2 & 0x30) >>> 4)));
			/* b3 */
			do {
				b3 = data[i++];
				if (b3 == 61)
					return sb.toString().getBytes("ISO-8859-1");
				b3 = base64DecodeChars[b3];
			} while (i < len && b3 == -1);
			if (b3 == -1)
				break;
			sb.append((char) (((b2 & 0x0f) << 4) | ((b3 & 0x3c) >>> 2)));
			/* b4 */
			do {
				b4 = data[i++];
				if (b4 == 61)
					return sb.toString().getBytes("ISO-8859-1");
				b4 = base64DecodeChars[b4];
			} while (i < len && b4 == -1);
			if (b4 == -1)
				break;
			sb.append((char) (((b3 & 0x03) << 6) | b4));
		}
		return sb.toString().getBytes("ISO-8859-1");
	}
}

  

时间: 2024-10-29 09:06:22

Android 应用接入广点通统计API 方案的相关文章

GPRS联网模块:广和通FIBOCOM_G510 支持接入机智云

[GPRS模组]广和通FIBOCOM_G510 支持接入机智云,具体开发流程参考:http://docs.gizwits.com/zh-cn/deviceDev/debug/G510.html G510 GAgent固件:是运行在各种通讯模组上的一款应用程序(固件),可以提供上层应用(手机APP等控制端.云端)到产品设备的双向数据通讯,此外,还提供对设备的配置入网.发现绑定.程序升级等功能. 产品开发者使用G510 GAgent后,只需要关心产品的业务逻辑开发,不用关心数据的通讯功能开发, 该固

广和通G510模组接入方案

文档编辑 G510是广和通推出的一款基于GPRS的通讯模组,本篇通过讲述如何通过G510模组把MCU接入到机智云云端,并实现通讯的方案.全篇文章的内容包括G510模组的管脚介绍.SIM卡连接.供电要求.串口定义以及固件烧写方法等,合作厂商在进行设备接入时请参照以下资料进行,以免造成不可控的错误. 模组接入准备 G510模组管脚图 SIM卡连接方法 模块包含了一个 SIM 卡接口,这个接口符合 GSM 11.11 和 GSM 11.12 标准(基于 ISO/IEC 7816) . 这些标准定义了

Android平台接入Facebook登录

官方教程地址: https://developers.facebook.com/docs/android/getting-started 开发环境为Android Studio,官方要求SDK最低版本为“API 15: Android 4.0.3”. 一.创建应用 1.激活账号 按照要求创建APP,生成appId. 注意:在填写APP名称的时候,不能包含任何有关facebook的名字或简写,否则无法通过. 2.配置Gradle文件 配置app下的build.gradle文件. 如下: //添加到

cocos2d-js添加广点通插屏(通过jsb反射机制)

1.把广点通的jar包加入libs文件夹 2.修改AndroidManifest.xml文件 添加权限: <uses-permission android:name="android.permission.READ_PHONE_STATE"/> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/> <uses-permission andr

Unity3d Android SDK接入解析(四)通用的Android SDK接入中间件

一.前言 接入Android SDK正式告一段落,在这段时间里面,依次接入了华为.应用宝.小米.360等等大大小小十来个SDK,也算对Unity接入渠道SDK有了较为全面的理解,对各个渠道的坑也算深有体会....在接入过程中时间比较紧张,没办法抽空来进行总结深思.今天正好有空,便对之前的接入SDK的代码进行了一次重构,写了一个比较通用的Unity接入Android SDK的中间件,前人栽树,后人乘凉. 进入正题 如果有对一些只是有疑问的,可以看看我之前的三篇文章: 传送门: Unity3d An

Android支付接入(二):移动游戏基地

原地址:http://blog.csdn.net/simdanfeg/article/details/9011863 上篇博文跟大家一起走了一遍支付宝支付,今天我们来看看移动支付.众所周知目前付费通道的龙头老大还要当属三大运营商(移动.联通.电信).运营商接入代码相对简单,但琐碎的要求太多,涉及到启动界面.桌面图标.主界面.退出界面等.移动游戏基地后台地址:http://g.10086.cn/ 部分截图 注意事项: 1.移动游戏基地sdk为动态打包,即公司信息,计费点信息都是在申请计费点的时候提

广点通优化6大招

广点通的优势是大数据,广点通背面它的大途径,是8亿多的QQ活泼用户,6.26亿的QQ空间活泼用户, 这还包含K放途径,微信上几亿的用户,不光是用户多,用户的活泼度十分高,日上传照片3.6个亿,每天点赞来表达自己情感的超越3个亿.3月31日,腾讯广点通将携手多位协作伙伴在京正式发布DMP(Data Management Platform 数据办理途径),并举行协作伙伴签约典礼.协作伙伴来自电商.生活效劳.品牌等不同范畴.腾讯以K放心态与职业同享大数据才能,致力于成为各职业数据孤岛的"衔接点&quo

Unity在Android和iOS中如何调用Native API

本文主要是对unity中如何在Android和iOS中调用Native API进行介绍. 首先unity支持在C#中调用C++ dll,这样可以在Android和iOS中提供C++接口在unity中调用.利用这一特性,可以扩展unity的功能.例如集成和调用第三方库.同时为了满足对unity接口的一致性,可以考虑在android和iOS上提供相同的接口供C#调用. 这里列举以下两个例子. 1. 1. 以弹出一个覆盖部分屏幕的webview为例来说明如何从C#调用Native接口. 2. 2. 简

商务通代码API

<!DOCTYPE HTML> <html> <head> <meta http-equiv="content-type" content="text/html" /> <meta name="author" content="barney" /> <title> 无标题 2 </title> </head> <body>