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

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

安卓java代码接入如下:

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
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
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);
     }
 
}

  

 

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
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
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" );
     }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Android应用接入PayPal订阅功能,可以按照以下步骤进行: 1. 集成PayPal SDK:首先,你需要在你的Android应用中集成PayPal SDK。你可以从PayPal开发者网站获取最新的SDK,并按照文档进行集成。 2. 创建PayPal订阅计划:在PayPal开发者控制台上创建一个订阅计划。你需要提供相关的订阅信息,如价格、订阅周期、订阅名称等。 3. 获取客户端ID:在PayPal开发者控制台上创建一个应用,然后获取一个客户端ID。这个客户端ID将用于在Android应用中进行身份验证和支付操作。 4. 在Android应用中配置支付信息:在你的Android应用中配置PayPal支付信息,包括客户端ID和其他相关设置。这将确保你的应用能够与PayPal进行通信。 5. 调起PayPal支付界面:当用户选择订阅或购买某项服务时,你可以通过调用PayPal SDK提供的接口,传递订阅信息,调起PayPal支付界面供用户进行支付操作。用户可以使用PayPal账号或信用卡完成支付过程。 6. 处理支付结果回调:用户完成支付后,PayPal会将支付结果返回给你的Android应用。你需要在应用中接收到回调通知后,验证支付结果的真实性,并更新用户的订阅状态或购买状态。 7. 自动续订处理:PayPal会自动处理订阅的续订操作,你无需手动处理。当订阅周期即将结束时,PayPal会自动向用户收取续订费用,并发送回调通知给你的应用。 需要注意的是,接入PayPal订阅功能需要你在服务器端进行管理和处理,通过与PayPal的接口交互实现相关功能。同时,你需要遵守PayPal的相关规定和合规要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值