Browse Source

本地注释-developer

FANGLH 9 years ago
parent
commit
f7aba18ea8

+ 1 - 1
WeiChat/build.gradle

@@ -125,6 +125,6 @@ dependencies {
     releaseCompile 'com.squareup.leakcanary:leakcanary-android-no-op:1.5'
     debugCompile 'com.squareup.leakcanary:leakcanary-android:1.5'
     androidTestCompile 'com.squareup.leakcanary:leakcanary-android-no-op:1.5'
-    compile files('libs/pushservice-4.5.5.77.jar')
+//    compile files('libs/pushservice-4.5.5.77.jar')
     compile files('libs/pushservice-5.2.0.12.jar')
 }

+ 17 - 0
WeiChat/proguard-rules.pro

@@ -0,0 +1,17 @@
+# Add project specific ProGuard rules here.
+# By default, the flags in this file are appended to flags specified
+# in C:\Android\sdk/tools/proguard/proguard-android.txt
+# You can edit the include path and order by changing the proguardFiles
+# directive in build.gradle.
+#
+# For more details, see
+#   http://developer.android.com/guide/developing/tools/proguard.html
+
+# Add any project specific keep options here:
+
+# If your project uses WebView with JS, uncomment the following
+# and specify the fully qualified class name to the JavaScript interface
+# class:
+#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
+#   public *;
+#}

+ 82 - 0
WeiChat/src/main/AndroidManifest.xml

@@ -132,6 +132,88 @@
                 <action android:name="cat.ereza.customactivityoncrash.RESTART" />
             </intent-filter>
         </activity>
+
+        <!-- push富媒体,使用富媒体推送必须声明 -->
+        <activity
+            android:name="com.baidu.android.pushservice.richmedia.MediaViewActivity"
+            android:configChanges="orientation|keyboardHidden"
+            android:label="MediaViewActivity" >
+        </activity>
+        <activity
+            android:name="com.baidu.android.pushservice.richmedia.MediaListActivity"
+            android:configChanges="orientation|keyboardHidden"
+            android:label="MediaListActivity"
+            android:launchMode="singleTask" >
+        </activity>
+        <!-- push富媒体结束 -->
+
+        <!-- push应用定义消息receiver声明 -->
+        <receiver android:name="com.xzjmyk.pm.receiver.MyPushMessageReceiver" >
+            <intent-filter>
+
+                <!-- 接收push消息 -->
+                <action android:name="com.baidu.android.pushservice.action.MESSAGE" />
+                <!-- 接收bind,unbind,fetch,delete等反馈消息 -->
+                <action android:name="com.baidu.android.pushservice.action.RECEIVE" />
+                <action android:name="com.baidu.android.pushservice.action.notification.CLICK" />
+            </intent-filter>
+        </receiver>
+
+        <!-- push必须的receviver和service声明 -->
+        <receiver
+            android:name="com.baidu.android.pushservice.PushServiceReceiver"
+            android:process=":bdservice_v1" >
+            <intent-filter>
+                <action android:name="android.intent.action.BOOT_COMPLETED" />
+                <action android:name="android.net.conn.CONNECTIVITY_CHANGE" />
+                <action android:name="com.baidu.android.pushservice.action.notification.SHOW" />
+                <action android:name="com.baidu.android.pushservice.action.media.CLICK" />
+                <!-- 以下四项为可选的action声明,可大大提高service存活率和消息到达速度 -->
+                <action android:name="android.intent.action.MEDIA_MOUNTED" />
+                <action android:name="android.intent.action.USER_PRESENT" />
+                <action android:name="android.intent.action.ACTION_POWER_CONNECTED" />
+                <action android:name="android.intent.action.ACTION_POWER_DISCONNECTED" />
+            </intent-filter>
+        </receiver>
+        <receiver
+            android:name="com.baidu.android.pushservice.RegistrationReceiver"
+            android:process=":bdservice_v1" >
+            <intent-filter>
+                <action android:name="com.baidu.android.pushservice.action.METHOD" />
+                <action android:name="com.baidu.android.pushservice.action.BIND_SYNC" />
+            </intent-filter>
+            <intent-filter>
+                <action android:name="android.intent.action.PACKAGE_REMOVED" />
+
+                <data android:scheme="package" />
+            </intent-filter>
+        </receiver>
+
+
+        <service
+            android:name="com.baidu.android.pushservice.PushService"
+            android:exported="true"
+            android:process=":bdservice_v1" >
+            <intent-filter>
+                <action android:name="com.baidu.android.pushservice.action.PUSH_SERVICE" />
+            </intent-filter>
+        </service>
+        <service
+            android:name="com.baidu.android.pushservice.CommandService"
+            android:exported="true" />
+
+        <!-- 适配Android N系统必需的ContentProvider声明,写权限包含应用包名-->
+        <provider
+            android:name="com.baidu.android.pushservice.PushInfoProvider"
+            android:authorities="com.baidu.push.example.bdpush"
+            android:writePermission="baidu.push.permission.WRITE_PUSHINFOPROVIDER.com.baidu.push.example"
+            android:protectionLevel = "signature"
+            android:exported="true" />
+
+        <!-- 在百度开发者中心查询应用的API Key -->
+        <meta-data
+            android:name="api_key"
+            android:value="1hcdebxXvNTZPvnMnQ3z7mmB" />
         <!--异常跳转页面-->
         <activity
             android:name=".CustomCrashActivity"

+ 4 - 0
WeiChat/src/main/java/com/xzjmyk/pm/activity/ui/MainActivity.java

@@ -60,6 +60,7 @@ import com.xzjmyk.pm.activity.volley.StringJsonArrayRequest;
 import com.xzjmyk.pm.activity.xmpp.CoreService;
 import com.xzjmyk.pm.activity.xmpp.ListenerManager;
 import com.xzjmyk.pm.activity.xmpp.listener.AuthStateListener;
+import com.xzjmyk.pm.receiver.Utils;
 
 import java.util.HashMap;
 import java.util.List;
@@ -390,9 +391,12 @@ public class MainActivity extends BaseActivity implements NetWorkObservable.NetW
     @Override
     protected void onCreate(Bundle savedInstanceState) {
         super.onCreate(savedInstanceState);
+        //注释
         getSupportActionBar().setDisplayShowHomeEnabled(false);
         getSupportActionBar().setDisplayHomeAsUpEnabled(false);
         setContentView(R.layout.activity_main);
+        PushManager.startWork(getApplicationContext(), PushConstants.LOGIN_TYPE_API_KEY,
+                Utils.getMetaValue(this, "api_key"));
         SIP_USERNAME = MyApplication.getInstance().mLoginUser.getUserId();
         String host = mConfig.MeetingHost;
         SIP_DOMAIN = host == null ? "120.24.211.24" : host;

+ 313 - 0
WeiChat/src/main/java/com/xzjmyk/pm/receiver/MyPushMessageReceiver.java

@@ -0,0 +1,313 @@
+package com.xzjmyk.pm.receiver;
+
+import android.content.Context;
+import android.text.TextUtils;
+import android.util.Log;
+
+import com.baidu.android.pushservice.PushMessageReceiver;
+
+import org.json.JSONException;
+import org.json.JSONObject;
+
+import java.text.SimpleDateFormat;
+import java.util.Date;
+import java.util.List;
+
+/*
+ * Push消息处理receiver。请编写您需要的回调函数, 一般来说: onBind是必须的,用来处理startWork返回值;
+ *onMessage用来接收透传消息; onSetTags、onDelTags、onListTags是tag相关操作的回调;
+ *onNotificationClicked在通知被点击时回调; onUnbind是stopWork接口的返回值回调
+ * 返回值中的errorCode,解释如下:
+ *0 - Success
+ *10001 - Network Problem
+ *10101  Integrate Check Error
+ *30600 - Internal Server Error
+ *30601 - Method Not Allowed
+ *30602 - Request Params Not Valid
+ *30603 - Authentication Failed
+ *30604 - Quota Use Up Payment Required
+ *30605 -Data Required Not Found
+ *30606 - Request Time Expires Timeout
+ *30607 - Channel Token Timeout
+ *30608 - Bind Relation Not Found
+ *30609 - Bind Number Too Many
+ * 当您遇到以上返回错误时,如果解释不了您的问题,请用同一请求的返回值requestId和errorCode联系我们追查问题。
+ *
+ */
+
+public class MyPushMessageReceiver extends PushMessageReceiver {
+    /** TAG to Log */
+    public static final String TAG = MyPushMessageReceiver.class
+            .getSimpleName();
+
+    /**
+     * 调用PushManager.startWork后,sdk将对push
+     * server发起绑定请求,这个过程是异步的。绑定请求的结果通过onBind返回。 如果您需要用单播推送,需要把这里获取的channel
+     * id和user id上传到应用server中,再调用server接口用channel id和user id给单个手机或者用户推送。
+     *
+     * @param context
+     *            BroadcastReceiver的执行Context
+     * @param errorCode
+     *            绑定接口返回值,0 - 成功
+     * @param appid
+     *            应用id。errorCode非0时为null
+     * @param userId
+     *            应用user id。errorCode非0时为null
+     * @param channelId
+     *            应用channel id。errorCode非0时为null
+     * @param requestId
+     *            向服务端发起的请求id。在追查问题时有用;
+     * @return none
+     */
+
+    @Override
+    public void onBind(Context context, int errorCode, String appid,
+            String userId, String channelId, String requestId) {
+        String responseString = "onBind errorCode=" + errorCode + " appid="
+                + appid + " userId=" + userId + " channelId=" + channelId
+                + " requestId=" + requestId;
+        Log.d(TAG, responseString);
+
+        if (errorCode == 0) {
+            // 绑定成功
+            Log.d(TAG, "绑定成功");
+        }
+        // Demo更新界面展示代码,应用请在这里加入自己的处理逻辑
+        updateContent(context, responseString);
+    }
+
+    /**
+     * 接收透传消息的函数。
+     *
+     * @param context
+     *            上下文
+     * @param message
+     *            推送的消息
+     * @param customContentString
+     *            自定义内容,为空或者json字符串
+     */
+    @Override
+    public void onMessage(Context context, String message,
+            String customContentString) {
+        String messageString = "透传消息 onMessage=\"" + message
+                + "\" customContentString=" + customContentString;
+        Log.d(TAG, messageString);
+
+        // 自定义内容获取方式,mykey和myvalue对应透传消息推送时自定义内容中设置的键和值
+        if (!TextUtils.isEmpty(customContentString)) {
+            JSONObject customJson = null;
+            try {
+                customJson = new JSONObject(customContentString);
+                String myvalue = null;
+                if (!customJson.isNull("mykey")) {
+                    myvalue = customJson.getString("mykey");
+                }
+            } catch (JSONException e) {
+                // TODO Auto-generated catch block
+                e.printStackTrace();
+            }
+        }
+
+        // Demo更新界面展示代码,应用请在这里加入自己的处理逻辑
+        updateContent(context, messageString);
+    }
+
+    /**
+     * 接收通知到达的函数。
+     *
+     * @param context
+     *            上下文
+     * @param title
+     *            推送的通知的标题
+     * @param description
+     *            推送的通知的描述
+     * @param customContentString
+     *            自定义内容,为空或者json字符串
+     */
+
+    @Override
+    public void onNotificationArrived(Context context, String title,
+            String description, String customContentString) {
+
+        String notifyString = "通知到达 onNotificationArrived  title=\"" + title
+                + "\" description=\"" + description + "\" customContent="
+                + customContentString;
+        Log.d(TAG, notifyString);
+
+        // 自定义内容获取方式,mykey和myvalue对应通知推送时自定义内容中设置的键和值
+        if (!TextUtils.isEmpty(customContentString)) {
+            JSONObject customJson = null;
+            try {
+                customJson = new JSONObject(customContentString);
+                String myvalue = null;
+                if (!customJson.isNull("mykey")) {
+                    myvalue = customJson.getString("mykey");
+                }
+            } catch (JSONException e) {
+                // TODO Auto-generated catch block
+                e.printStackTrace();
+            }
+        }
+        // Demo更新界面展示代码,应用请在这里加入自己的处理逻辑
+        // 你可以參考 onNotificationClicked中的提示从自定义内容获取具体值
+        updateContent(context, notifyString);
+    }
+
+    /**
+     * 接收通知点击的函数。
+     *
+     * @param context
+     *            上下文
+     * @param title
+     *            推送的通知的标题
+     * @param description
+     *            推送的通知的描述
+     * @param customContentString
+     *            自定义内容,为空或者json字符串
+     */
+    @Override
+    public void onNotificationClicked(Context context, String title,
+            String description, String customContentString) {
+        String notifyString = "通知点击 onNotificationClicked title=\"" + title + "\" description=\""
+                + description + "\" customContent=" + customContentString;
+        Log.d(TAG, notifyString);
+
+        // 自定义内容获取方式,mykey和myvalue对应通知推送时自定义内容中设置的键和值
+        if (!TextUtils.isEmpty(customContentString)) {
+            JSONObject customJson = null;
+            try {
+                customJson = new JSONObject(customContentString);
+                String myvalue = null;
+                if (!customJson.isNull("mykey")) {
+                    myvalue = customJson.getString("mykey");
+                }
+            } catch (JSONException e) {
+                // TODO Auto-generated catch block
+                e.printStackTrace();
+            }
+        }
+
+        // Demo更新界面展示代码,应用请在这里加入自己的处理逻辑
+        updateContent(context, notifyString);
+    }    
+    
+    /**
+     * setTags() 的回调函数。
+     *
+     * @param context
+     *            上下文
+     * @param errorCode
+     *            错误码。0表示某些tag已经设置成功;非0表示所有tag的设置均失败。
+     * @param successTags
+     *            设置成功的tag
+     * @param failTags
+     *            设置失败的tag
+     * @param requestId
+     *            分配给对云推送的请求的id
+     */
+    @Override
+    public void onSetTags(Context context, int errorCode,
+            List<String> sucessTags, List<String> failTags, String requestId) {
+        String responseString = "onSetTags errorCode=" + errorCode
+                + " sucessTags=" + sucessTags + " failTags=" + failTags
+                + " requestId=" + requestId;
+        Log.d(TAG, responseString);
+
+        // Demo更新界面展示代码,应用请在这里加入自己的处理逻辑
+        updateContent(context, responseString);
+    }
+
+    /**
+     * delTags() 的回调函数。
+     *
+     * @param context
+     *            上下文
+     * @param errorCode
+     *            错误码。0表示某些tag已经删除成功;非0表示所有tag均删除失败。
+     * @param successTags
+     *            成功删除的tag
+     * @param failTags
+     *            删除失败的tag
+     * @param requestId
+     *            分配给对云推送的请求的id
+     */
+    @Override
+    public void onDelTags(Context context, int errorCode,
+            List<String> sucessTags, List<String> failTags, String requestId) {
+        String responseString = "onDelTags errorCode=" + errorCode
+                + " sucessTags=" + sucessTags + " failTags=" + failTags
+                + " requestId=" + requestId;
+        Log.d(TAG, responseString);
+
+        // Demo更新界面展示代码,应用请在这里加入自己的处理逻辑
+        updateContent(context, responseString);
+    }
+
+    /**
+     * listTags() 的回调函数。
+     *
+     * @param context
+     *            上下文
+     * @param errorCode
+     *            错误码。0表示列举tag成功;非0表示失败。
+     * @param tags
+     *            当前应用设置的所有tag。
+     * @param requestId
+     *            分配给对云推送的请求的id
+     */
+    @Override
+    public void onListTags(Context context, int errorCode, List<String> tags,
+            String requestId) {
+        String responseString = "onListTags errorCode=" + errorCode + " tags="
+                + tags;
+        Log.d(TAG, responseString);
+
+        // Demo更新界面展示代码,应用请在这里加入自己的处理逻辑
+        updateContent(context, responseString);
+    }
+
+    /**
+     * PushManager.stopWork() 的回调函数。
+     *
+     * @param context
+     *            上下文
+     * @param errorCode
+     *            错误码。0表示从云推送解绑定成功;非0表示失败。
+     * @param requestId
+     *            分配给对云推送的请求的id
+     */
+    @Override
+    public void onUnbind(Context context, int errorCode, String requestId) {
+        String responseString = "onUnbind errorCode=" + errorCode
+                + " requestId = " + requestId;
+        Log.d(TAG, responseString);
+
+        if (errorCode == 0) {
+            // 解绑定成功
+            Log.d(TAG, "解绑成功");
+        }
+        // Demo更新界面展示代码,应用请在这里加入自己的处理逻辑
+        updateContent(context, responseString);
+    }
+
+    private void updateContent(Context context, String content) {
+        Log.d(TAG, "updateContent");
+        String logText = "" + Utils.logStringCache;
+
+        if (!logText.equals("")) {
+            logText += "\n";
+        }
+
+        SimpleDateFormat sDateFormat = new SimpleDateFormat("HH-mm-ss");
+        logText += sDateFormat.format(new Date()) + ": ";
+        logText += content;
+
+        Utils.logStringCache = logText;
+
+//        Intent intent = new Intent();
+//        intent.setClass(context.getApplicationContext(), PushDemoActivity.class);
+//        intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
+//        context.getApplicationContext().startActivity(intent);
+    }
+
+}

+ 86 - 0
WeiChat/src/main/java/com/xzjmyk/pm/receiver/Utils.java

@@ -0,0 +1,86 @@
+package com.xzjmyk.pm.receiver;
+
+import android.content.Context;
+import android.content.SharedPreferences;
+import android.content.SharedPreferences.Editor;
+import android.content.pm.ApplicationInfo;
+import android.content.pm.PackageManager;
+import android.content.pm.PackageManager.NameNotFoundException;
+import android.os.Bundle;
+import android.preference.PreferenceManager;
+import android.util.Log;
+
+import java.util.ArrayList;
+import java.util.List;
+
+public class Utils {
+    public static final String TAG = "PushDemoActivity";
+    public static final String RESPONSE_METHOD = "method";
+    public static final String RESPONSE_CONTENT = "content";
+    public static final String RESPONSE_ERRCODE = "errcode";
+    protected static final String ACTION_LOGIN = "com.baidu.pushdemo.action.LOGIN";
+    public static final String ACTION_MESSAGE = "com.baiud.pushdemo.action.MESSAGE";
+    public static final String ACTION_RESPONSE = "bccsclient.action.RESPONSE";
+    public static final String ACTION_SHOW_MESSAGE = "bccsclient.action.SHOW_MESSAGE";
+    protected static final String EXTRA_ACCESS_TOKEN = "access_token";
+    public static final String EXTRA_MESSAGE = "message";
+
+    public static String logStringCache = "";
+
+    // 获取ApiKey
+    public static String getMetaValue(Context context, String metaKey) {
+        Bundle metaData = null;
+        String apiKey = null;
+        if (context == null || metaKey == null) {
+            return null;
+        }
+        try {
+            ApplicationInfo ai = context.getPackageManager()
+                    .getApplicationInfo(context.getPackageName(),
+                            PackageManager.GET_META_DATA);
+            if (null != ai) {
+                metaData = ai.metaData;
+            }
+            if (null != metaData) {
+                apiKey = metaData.getString(metaKey);
+            }
+        } catch (NameNotFoundException e) {
+            Log.e(TAG, "error " + e.getMessage());
+        }
+        return apiKey;
+    }
+
+    public static List<String> getTagsList(String originalText) {
+        if (originalText == null || originalText.equals("")) {
+            return null;
+        }
+        List<String> tags = new ArrayList<String>();
+        int indexOfComma = originalText.indexOf(',');
+        String tag;
+        while (indexOfComma != -1) {
+            tag = originalText.substring(0, indexOfComma);
+            tags.add(tag);
+
+            originalText = originalText.substring(indexOfComma + 1);
+            indexOfComma = originalText.indexOf(',');
+        }
+
+        tags.add(originalText);
+        return tags;
+    }
+
+    public static String getLogText(Context context) {
+        SharedPreferences sp = PreferenceManager
+                .getDefaultSharedPreferences(context);
+        return sp.getString("log_text", "");
+    }
+
+    public static void setLogText(Context context, String text) {
+        SharedPreferences sp = PreferenceManager
+                .getDefaultSharedPreferences(context);
+        Editor editor = sp.edit();
+        editor.putString("log_text", text);
+        editor.commit();
+    }
+
+}