Commit 83a1b997 by 徐健

Merge branch 'feature/im_update' of…

Merge branch 'feature/im_update' of ssh://gitlab.yidianling.com:2224/app_android_lib/YDL-Component into feature/im_update
parents e8af2e71 5e72522b
......@@ -121,7 +121,9 @@ public class DemoAppLifecycles implements IAppLifecycles {
PlatformConfig.setQQZone("1107931541", "8dCvxUpi525uPGTJ");
}
MobclickAgent.setScenarioType(application, MobclickAgent.EScenarioType.E_DUM_NORMAL);
// MobclickAgent.setScenarioType(application, MobclickAgent.EScenarioType.E_DUM_NORMAL);
// 选用AUTO页面采集模式
MobclickAgent.setPageCollectionMode(MobclickAgent.PageMode.AUTO);
MobclickAgent.setCatchUncaughtExceptions(!BuildConfig.DEBUG);
//开启友盟集成测试
......
......@@ -33,7 +33,8 @@ buildscript {
password "fjoi#1+#@"
}
}
//Umeng sdk maven 地址
maven { url 'https://dl.bintray.com/umsdk/release' }
maven{ url 'http://maven.aliyun.com/nexus/content/groups/public/'}
maven {
......@@ -80,6 +81,8 @@ allprojects {
password "fjoi#1+#@"
}
}
//Umeng sdk maven 地址
maven { url 'https://dl.bintray.com/umsdk/release' }
maven{ url 'http://maven.aliyun.com/nexus/content/groups/public/'}
// maven { url'http://developer.huawei.com/repo/' }
maven { url "https://jitpack.io" }
......
......@@ -232,13 +232,17 @@ ext {
"BaseRecyclerViewAdapterHelper": "com.github.CymChad:BaseRecyclerViewAdapterHelper:2.9.34",
"flowlayout" : "cn.lankton:flowlayout:3.1.0",
"androidanimations" : "com.daimajia.androidanimations:library:2.3@aar",
"umeng-common" : "com.umeng.sdk:common:1.5.1",
"umeng-analytics" : "com.umeng.sdk:analytics:7.5.1",
"umeng-share-core" : "com.umeng.sdk:share-core:6.9.1",
"umeng-share-qq" : "com.umeng.sdk:share-qq:6.9.1.1",
"umeng-share-wechat" : "com.umeng.sdk:share-wechat:6.9.1",
"umeng-shareboard" : "com.umeng.sdk:shareboard-widget:6.9.1",
"umeng-debug" : "com.umeng.sdk:debug:1.0.0",
//友盟统计
"umeng-common" : "com.umeng.umsdk:common:2.1.0",
"umeng-analytics" : "com.umeng.umsdk:analytics:8.1.4",
//友盟社会化分享
"umeng-share-core" : "com.umeng.umsdk:share-core:6.9.6",
"umeng-share-qq" : "com.umeng.umsdk:share-qq:6.9.6",
"umeng-share-wechat" : "com.umeng.umsdk:share-wx:6.9.6",
//分享面板
"umeng-shareboard" : "com.umeng.umsdk:share-board:6.9.6",
//删除集成调试库,其功能合并到umeng基础组件库。
//"umeng-debug" : "com.umeng.sdk:debug:1.0.0",
"tablayout" : "com.flyco.tablayout:FlycoTabLayout_Lib:2.1.2@aar",
"stetho" : "com.facebook.stetho:stetho:1.5.0",
"stetho-okhttp3" : "com.facebook.stetho:stetho-okhttp3:1.4.1",
......
......@@ -122,7 +122,7 @@ public class TrendsListInteractor {
// LogUtil.i("get Response: " + trendsListBean.toString());
if (callBack != null) {
//更新缓存
updateCache(tab,trendsListBean);
// updateCache(tab,trendsListBean);
callBack.onTrendsListFetched(trendsListBean);
}
}, throwable -> {
......
......@@ -10,7 +10,7 @@ import android.support.v4.app.FragmentPagerAdapter;
public class TrendsHomeVpAdapter extends FragmentPagerAdapter {
public final static int dataSize=3;
public final static int dataSize = 3;
private Fragment[] mFragments;
private String[] titles = new String[]{
"推荐", "最新", "关注", "待回答", "我回答的"
......@@ -25,8 +25,8 @@ public class TrendsHomeVpAdapter extends FragmentPagerAdapter {
mFragments = fragments;
}
public void setDatas(Fragment[] fragments){
mFragments=fragments;
public void setDatas(Fragment[] fragments) {
mFragments = fragments;
}
@Override
......@@ -39,12 +39,12 @@ public class TrendsHomeVpAdapter extends FragmentPagerAdapter {
@Override
public int getCount() {
return mFragments!=null&&mFragments.length > 0 ? mFragments.length : 0;
return mFragments != null && mFragments.length > 0 ? mFragments.length : 0;
}
@Override
public CharSequence getPageTitle(int position) {
if (mFragments.length>0){
if (mFragments.length > 0) {
return titles[position];
}
return super.getPageTitle(position);
......
......@@ -23,7 +23,6 @@ import com.ydl.ydlcommon.base.BaseFragment;
import com.ydl.ydlcommon.utils.BuryPointUtils;
import com.ydl.ydlcommon.utils.SharedPreferencesEditor;
import com.ydl.ydlcommon.view.WrapContentLinearLayoutManager;
import com.ydl.ydlcommon.view.listener.EndlessRecyclerViewScrollListener;
import com.yidianling.common.tools.LogUtil;
import com.yidianling.common.tools.ToastUtil;
import com.yidianling.dynamic.R;
......@@ -45,6 +44,7 @@ import io.reactivex.android.schedulers.AndroidSchedulers;
import io.reactivex.schedulers.Schedulers;
;
/**
* @author Jim
* @描述:
......@@ -78,6 +78,7 @@ public class TrendsContentListFragment extends BaseFragment implements ITrendsLi
private TrendsCotentListAdapter mRcvAdapter;
private List<TrendsListBean.Trend> trendsDatas;
private RecyclerView.OnScrollListener mScrollListener;
private int lastVisibleItem = 0;
public static TrendsContentListFragment newInstance(int tabType, int topicId, String trendType, String trendUserid) {
TrendsContentListFragment fragment = new TrendsContentListFragment();
......@@ -179,36 +180,70 @@ public class TrendsContentListFragment extends BaseFragment implements ITrendsLi
trendsRcv.setAdapter(mRcvAdapter);
trendsRcv.setLayoutManager(layoutManager);
trendsRcv.getItemAnimator().setChangeDuration(0); //解决局部刷新闪屏
mScrollListener = new EndlessRecyclerViewScrollListener(layoutManager) {
@Override
public void onLoadMore(int page, int totalItemsCount, @org.jetbrains.annotations.Nullable RecyclerView view) {
if (!isRefresh) {
resetState();
last_id = getLastId();
LogUtil.i("loadMore last id: " + last_id + " page: " + page);
TrendsContentListFragment.this.page++;
switchDataToFetch();
}
}
mRcvAdapter.addFooterView(getFooterView());
// mScrollListener = new DynamicRecyclerViewScrollListener(layoutManager) {
// @Override
// public void onLoadMore(int page, int totalItemsCount, @org.jetbrains.annotations.Nullable RecyclerView view) {
// LogUtil.e("tab=" + tab + ",onLoadMore");
// LogUtil.e("tab=" + tab + ",==数据长度:" + mRcvAdapter.getDatas().size());
// if (!isRefresh) {
// resetState();
// last_id = getLastId();
// LogUtil.i("loadMore last id: " + last_id + " page: " + page);
// TrendsContentListFragment.this.page++;
// switchDataToFetch();
// }
// }
//
// @Override
// protected void onScrollDown() {
// LogUtil.e("tab=" + tab + ",onScrollDown");
//// ((TrendsHomeFragment) getParentFragment()).onScrollDown();
// }
//
// @Override
// protected void onScrollUp() {
// LogUtil.e("tab=" + tab + ",onScrollUp");
//// ((TrendsHomeFragment) getParentFragment()).onScrollUp();
// }
//
// @Override
// public void onScrollTop() {
// LogUtil.e("tab=" + tab + ",onScrollTop");
//// ((TrendsHomeFragment) getParentFragment()).onScrollTop();
// }
// };
mScrollListener = new RecyclerView.OnScrollListener() {
@Override
protected void onScrollDown() {
// ((TrendsHomeFragment) getParentFragment()).onScrollDown();
}
public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
if (newState == RecyclerView.SCROLL_STATE_IDLE) {
LogUtil.e("tab===停止滑动" + System.currentTimeMillis());
}
@Override
protected void onScrollUp() {
// ((TrendsHomeFragment) getParentFragment()).onScrollUp();
if (newState == RecyclerView.SCROLL_STATE_IDLE //停止滚动
&& lastVisibleItem >= (mRcvAdapter.getItemCount() - mRcvAdapter.getFootersCount())//最后一个显示的item序号大于适配器item数量,即显示了footer
&& mRcvAdapter.getFooterState() == TrendsCotentListAdapter.FOOTRE_STATE_LOAD_MORE
) {
LogUtil.e("tab=" + tab + ",onLoadMore");
LogUtil.e("tab=" + tab + ",==数据长度:" + mRcvAdapter.getDatas().size());
if (!isRefresh) {
LogUtil.e("tab===加载数据" + System.currentTimeMillis());
last_id = getLastId();
LogUtil.i("loadMore last id: " + last_id + " page: " + page);
TrendsContentListFragment.this.page++;
switchDataToFetch();
}
}
}
@Override
public void onScrollTop() {
// ((TrendsHomeFragment) getParentFragment()).onScrollTop();
public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
lastVisibleItem = layoutManager.findLastVisibleItemPosition();
}
};
trendsRcv.addOnScrollListener(mScrollListener);
mRcvAdapter.addFooterView(getFooterView());
}
private void doLikeAction(View view, int position, List<TrendsListBean.Trend> mDatas) {
......@@ -222,7 +257,7 @@ public class TrendsContentListFragment extends BaseFragment implements ITrendsLi
}
}
private void localData(){
private void localData() {
if (mPresenter != null) {
mPresenter.localData(tab);
}
......@@ -297,7 +332,7 @@ public class TrendsContentListFragment extends BaseFragment implements ITrendsLi
}
SharedPreferencesEditor.putString("trend_state", "");
LogUtil.d("trendType " + trendType);
localData();
// localData();
fetchTrendsList();
}
......@@ -391,8 +426,8 @@ public class TrendsContentListFragment extends BaseFragment implements ITrendsLi
@Override
public void showBanner(List<TrendsListBean.Banner> banner) {
//更新banner数据
if (getParentFragment() instanceof TrendsHomeFragment){
((TrendsHomeFragment)getParentFragment()).setBannerData(banner);
if (getParentFragment() instanceof TrendsHomeFragment) {
((TrendsHomeFragment) getParentFragment()).setBannerData(banner);
}
}
......@@ -400,16 +435,16 @@ public class TrendsContentListFragment extends BaseFragment implements ITrendsLi
public void showTrendsListView(List<TrendsListBean.Trend> data) {
isTrendsListLoading = false;
showLoadSuccessView();
if (page == 1){
if (null == trendsDatas){
if (page == 1) {
if (null == trendsDatas) {
trendsDatas = new ArrayList();
}else {
} else {
trendsDatas.clear();
}
if (null != data){
if (null != data) {
trendsDatas.addAll(data);
}
mRcvAdapter.setDatas(trendsDatas, mRcvAdapter.FOOTRE_STATE_INIT);
mRcvAdapter.setDatas(trendsDatas, mRcvAdapter.FOOTRE_STATE_LOAD_MORE);
mRcvAdapter.notifyDataSetChanged();
return;
}
......
......@@ -77,7 +77,7 @@ public class TrendsCotentListAdapter extends RecyclerView.Adapter<BaseViewHolder
public TrendsCotentListAdapter(Context context, List<TrendsListBean.Trend> datas) {
mContext = context;
mDatas = datas;
footerState = FOOTRE_STATE_INIT;
footerState = FOOTRE_STATE_LOAD_MORE;
}
public void setDatas(List<TrendsListBean.Trend> datas) {
......@@ -89,6 +89,10 @@ public class TrendsCotentListAdapter extends RecyclerView.Adapter<BaseViewHolder
this.footerState = footerState;
}
public int getFooterState() {
return footerState;
}
public void addDatas(List<TrendsListBean.Trend> datas, int footerState) {
this.footerState = footerState;
if (mDatas == null) {
......
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/dynamic_white">
<android.support.v7.widget.RecyclerView
android:id="@+id/recommend_dynamic_rcv"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:overScrollMode="never"
android:visibility="visible"/>
<android.support.v4.widget.NestedScrollView
android:id="@+id/trend_no_data_rel"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:visibility="gone">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:orientation="vertical">
<ImageView
android:id="@+id/trend_no_data_iv"
android:layout_width="100dp"
android:layout_height="100dp"
android:layout_marginTop="30dp"
android:layout_centerHorizontal="true"
android:src="@drawable/dynamic_blank"/>
<TextView
android:id="@+id/trend_no_data_tv"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="15dp"
android:text="暂无数据"
android:textColor="@color/dynamic_text_gray"
android:textSize="16sp"/>
</LinearLayout>
</android.support.v4.widget.NestedScrollView>
</FrameLayout>
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:descendantFocusability="blocksDescendants"
android:background="@color/dynamic_white">
<android.support.v7.widget.RecyclerView
android:id="@+id/recommend_dynamic_rcv"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:overScrollMode="never"
android:visibility="visible"/>
<android.support.v4.widget.NestedScrollView
android:id="@+id/trend_no_data_rel"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:visibility="gone">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:orientation="vertical">
<ImageView
android:id="@+id/trend_no_data_iv"
android:layout_width="100dp"
android:layout_height="100dp"
android:layout_marginTop="30dp"
android:layout_centerHorizontal="true"
android:src="@drawable/dynamic_blank"/>
<TextView
android:id="@+id/trend_no_data_tv"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="15dp"
android:text="暂无数据"
android:textColor="@color/dynamic_text_gray"
android:textSize="16sp"/>
</LinearLayout>
</android.support.v4.widget.NestedScrollView>
</RelativeLayout>
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#F4F4F5">
<TextView
android:id="@+id/loop_content_before"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginLeft="15dp"
android:layout_marginTop="5dp"
android:layout_marginBottom="5dp"
android:layout_marginRight="15dp"
android:textColor="#999999"
android:paddingBottom="5dp"
android:paddingLeft="15dp"
android:paddingTop="5dp"
android:paddingRight="5dp"
android:background="@drawable/dynamic_bg_radius_white_20"
tools:text="置顶 xxxxxx"/>
</LinearLayout>
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#F4F4F5">
<TextView
android:id="@+id/loop_content_before"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginLeft="15dp"
android:layout_marginTop="5dp"
android:layout_marginRight="15dp"
android:layout_marginBottom="5dp"
android:background="@drawable/dynamic_bg_radius_white_20"
android:ellipsize="end"
android:maxLines="1"
android:paddingLeft="15dp"
android:paddingTop="5dp"
android:paddingRight="5dp"
android:paddingBottom="5dp"
android:textColor="#999999"
tools:text="置顶 xxxxxx" />
</LinearLayout>
......@@ -150,7 +150,6 @@ dependencies {
api rootProject.ext.dependencies["umeng-share-qq"]
api rootProject.ext.dependencies["umeng-share-wechat"]
api rootProject.ext.dependencies["umeng-shareboard"]
api rootProject.ext.dependencies["umeng-debug"]
api rootProject.ext.dependencies["stetho"]
api rootProject.ext.dependencies["stetho-okhttp3"]
api rootProject.ext.dependencies["bugly-crashreport"]
......
......@@ -72,6 +72,7 @@ internal class BaiduActionDataBean private constructor(builder: Builder) {
internal var androidId: String? = ""
internal var convertParam: String? = ""
internal var uid : String? = ""
internal var mac : String? = ""
internal var channel : String? = ""
fun pkname(pkname: String = ""): Builder {
......@@ -143,6 +144,10 @@ internal class BaiduActionDataBean private constructor(builder: Builder) {
this.uid = uid
return this
}
fun mac(mac : String? = "") : Builder {
this.mac = mac
return this
}
fun channel(channel : String? = "") : Builder {
this.channel = channel
......
......@@ -6,19 +6,33 @@ import android.app.Activity;
import android.content.ComponentName;
import android.content.Context;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.content.res.Resources;
import android.net.ConnectivityManager;
import android.net.NetworkInfo;
import android.net.Uri;
import android.net.wifi.WifiInfo;
import android.net.wifi.WifiManager;
import android.os.Build;
import android.provider.Settings;
import android.telephony.TelephonyManager;
import android.text.TextUtils;
import android.util.Log;
import com.tbruyelle.rxpermissions2.RxPermissions;
import com.yidianling.common.tools.RxTool;
import com.ydl.ydlcommon.BuildConfig;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.InputStreamReader;
import java.io.LineNumberReader;
import java.io.Reader;
import java.net.InetAddress;
import java.net.NetworkInterface;
import java.net.SocketException;
import java.util.Enumeration;
import static com.umeng.socialize.utils.ContextUtil.getPackageName;
public class DeviceTool {
......@@ -223,4 +237,298 @@ public class DeviceTool {
return NETWORN_NONE;
}
public static String getMac(Context context) {
String strMac = null;
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M) {
strMac = getLocalMacAddressFromWifiInfo(context);
return strMac;
} else if (Build.VERSION.SDK_INT < Build.VERSION_CODES.N
&& Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
strMac = getMacAddress(context);
return strMac;
} else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
if (!TextUtils.isEmpty(getMacAddress())) {
strMac = getMacAddress();
return strMac;
} else if (!TextUtils.isEmpty(getMachineHardwareAddress())) {
strMac = getMachineHardwareAddress();
return strMac;
} else {
strMac = getLocalMacAddressFromBusybox();
return strMac;
}
}
return "02:00:00:00:00:00";
}
public static String getLocalMacAddressFromWifiInfo(Context context) {
WifiManager wifi = (WifiManager) context.getSystemService(Context.WIFI_SERVICE);
WifiInfo winfo = wifi.getConnectionInfo();
String mac = winfo.getMacAddress();
return mac;
}
public static String getMacAddress(Context context) {
// 如果是6.0以下,直接通过wifimanager获取
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M) {
String macAddress0 = getMacAddress0(context);
if (!TextUtils.isEmpty(macAddress0)) {
return macAddress0;
}
}
String str = "";
String macSerial = "";
try {
Process pp = Runtime.getRuntime().exec(
"cat /sys/class/net/wlan0/address");
InputStreamReader ir = new InputStreamReader(pp.getInputStream());
LineNumberReader input = new LineNumberReader(ir);
for (; null != str; ) {
str = input.readLine();
if (str != null) {
macSerial = str.trim();// 去空格
break;
}
}
} catch (Exception ex) {
Log.e("----->" + "NetInfoManager", "getMacAddress:" + ex.toString());
}
if (macSerial == null || "".equals(macSerial)) {
try {
return loadFileAsString("/sys/class/net/eth0/address")
.toUpperCase().substring(0, 17);
} catch (Exception e) {
e.printStackTrace();
Log.e("----->" + "NetInfoManager",
"getMacAddress:" + e.toString());
}
}
return macSerial;
}
private static String getMacAddress0(Context context) {
if (isAccessWifiStateAuthorized(context)) {
WifiManager wifiMgr = (WifiManager) context
.getSystemService(Context.WIFI_SERVICE);
WifiInfo wifiInfo = null;
try {
wifiInfo = wifiMgr.getConnectionInfo();
return wifiInfo.getMacAddress();
} catch (Exception e) {
Log.e("----->" + "NetInfoManager",
"getMacAddress0:" + e.toString());
}
}
return "";
}
/**
* Check whether accessing wifi state is permitted
*
* @param context
* @return
*/
private static boolean isAccessWifiStateAuthorized(Context context) {
if (PackageManager.PERMISSION_GRANTED == context
.checkCallingOrSelfPermission("android.permission.ACCESS_WIFI_STATE")) {
Log.e("----->" + "NetInfoManager", "isAccessWifiStateAuthorized:"
+ "access wifi state is enabled");
return true;
} else
return false;
}
private static String loadFileAsString(String fileName) throws Exception {
FileReader reader = new FileReader(fileName);
String text = loadReaderAsString(reader);
reader.close();
return text;
}
private static String loadReaderAsString(Reader reader) throws Exception {
StringBuilder builder = new StringBuilder();
char[] buffer = new char[4096];
int readLength = reader.read(buffer);
while (readLength >= 0) {
builder.append(buffer, 0, readLength);
readLength = reader.read(buffer);
}
return builder.toString();
}
/**
* 根据IP地址获取MAC地址
*
* @return
*/
public static String getMacAddress() {
String strMacAddr = null;
try {
// 获得IpD地址
InetAddress ip = getLocalInetAddress();
byte[] b = NetworkInterface.getByInetAddress(ip)
.getHardwareAddress();
StringBuffer buffer = new StringBuffer();
for (int i = 0; i < b.length; i++) {
if (i != 0) {
buffer.append(':');
}
String str = Integer.toHexString(b[i] & 0xFF);
buffer.append(str.length() == 1 ? 0 + str : str);
}
strMacAddr = buffer.toString().toUpperCase();
} catch (Exception e) {
}
return strMacAddr;
}
/**
* 获取移动设备本地IP
*
* @return
*/
private static InetAddress getLocalInetAddress() {
InetAddress ip = null;
try {
// 列举
Enumeration<NetworkInterface> en_netInterface = NetworkInterface
.getNetworkInterfaces();
while (en_netInterface.hasMoreElements()) {// 是否还有元素
NetworkInterface ni = (NetworkInterface) en_netInterface
.nextElement();// 得到下一个元素
Enumeration<InetAddress> en_ip = ni.getInetAddresses();// 得到一个ip地址的列举
while (en_ip.hasMoreElements()) {
ip = en_ip.nextElement();
if (!ip.isLoopbackAddress()
&& ip.getHostAddress().indexOf(":") == -1)
break;
else
ip = null;
}
if (ip != null) {
break;
}
}
} catch (SocketException e) {
e.printStackTrace();
}
return ip;
}
/**
* 获取本地IP
*
* @return
*/
private static String getLocalIpAddress() {
try {
for (Enumeration<NetworkInterface> en = NetworkInterface
.getNetworkInterfaces(); en.hasMoreElements(); ) {
NetworkInterface intf = en.nextElement();
for (Enumeration<InetAddress> enumIpAddr = intf
.getInetAddresses(); enumIpAddr.hasMoreElements(); ) {
InetAddress inetAddress = enumIpAddr.nextElement();
if (!inetAddress.isLoopbackAddress()) {
return inetAddress.getHostAddress().toString();
}
}
}
} catch (SocketException ex) {
ex.printStackTrace();
}
return null;
}
public static String getMachineHardwareAddress() {
Enumeration<NetworkInterface> interfaces = null;
try {
interfaces = NetworkInterface.getNetworkInterfaces();
} catch (SocketException e) {
e.printStackTrace();
}
String hardWareAddress = null;
NetworkInterface iF = null;
if (interfaces == null) {
return null;
}
while (interfaces.hasMoreElements()) {
iF = interfaces.nextElement();
try {
hardWareAddress = bytesToString(iF.getHardwareAddress());
if (hardWareAddress != null)
break;
} catch (SocketException e) {
e.printStackTrace();
}
}
return hardWareAddress;
}
/***
* byte转为String
*
* @param bytes
* @return
*/
private static String bytesToString(byte[] bytes) {
if (bytes == null || bytes.length == 0) {
return null;
}
StringBuilder buf = new StringBuilder();
for (byte b : bytes) {
buf.append(String.format("%02X:", b));
}
if (buf.length() > 0) {
buf.deleteCharAt(buf.length() - 1);
}
return buf.toString();
}
public static String getLocalMacAddressFromBusybox() {
String result = "";
String Mac = "";
result = callCmd("busybox ifconfig", "HWaddr");
// 如果返回的result == null,则说明网络不可取
if (result == null) {
return "网络异常";
}
// 对该行数据进行解析
// 例如:eth0 Link encap:Ethernet HWaddr 00:16:E8:3E:DF:67
if (result.length() > 0 && result.contains("HWaddr") == true) {
Mac = result.substring(result.indexOf("HWaddr") + 6,
result.length() - 1);
result = Mac;
}
return result;
}
private static String callCmd(String cmd, String filter) {
String result = "";
String line = "";
try {
Process proc = Runtime.getRuntime().exec(cmd);
InputStreamReader is = new InputStreamReader(proc.getInputStream());
BufferedReader br = new BufferedReader(is);
while ((line = br.readLine()) != null
&& line.contains(filter) == false) {
result += line;
}
result = line;
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
}
......@@ -48,16 +48,22 @@ class ActionCountUtils {
count(eventName, *sign1, urlStr = "", apiStr = "")
}
fun countUid(eventName: String,uid: String, vararg sign1: String) {
count(eventName, *sign1, urlStr = "", apiStr = "",uid = uid)
fun countUid(eventName: String, uid: String, vararg sign1: String) {
count(eventName, *sign1, urlStr = "", apiStr = "", uid = uid)
}
fun count(eventName: String, vararg sign1: String, urlStr: String = "", apiStr: String = "",uid: String = "") {
fun count(
eventName: String,
vararg sign1: String,
urlStr: String = "",
apiStr: String = "",
uid: String = ""
) {
var partId = ""
var position = ""
var userId = uid
if (TextUtils.isEmpty(uid)){
userId = ModularServiceManager.getPlatformUserService()?.getUser()?.userId?: ""
if (TextUtils.isEmpty(uid)) {
userId = ModularServiceManager.getPlatformUserService()?.getUser()?.userId ?: ""
}
if (eventName.contains("|")) {
val splitList = eventName.split("|")
......@@ -73,11 +79,25 @@ class ActionCountUtils {
/**
* 行为数据埋点调用的方法
*/
fun count(uid: String?, partId: String, position: String, url: String, api: String, sign1: String) {
fun count(
uid: String?,
partId: String,
position: String,
url: String,
api: String,
sign1: String
) {
count(uid, partId, position, url, api, signs = *arrayOf(sign1))
}
fun count(uid: String?, partId: String, position: String, url: String, api: String, vararg signs: String) {
fun count(
uid: String?,
partId: String,
position: String,
url: String,
api: String,
vararg signs: String
) {
try {
......@@ -140,17 +160,25 @@ class ActionCountUtils {
/**
* 百度检测数据埋点调用的方法
*/
fun baiduCount( partId: String, position: String, convertType: Int) {
fun baiduCount(partId: String, position: String, convertType: Int) {
val appFrom = BaseApp.instance.getGlobalConfig().appFrom
if (YDLConstants.FROM_YDL != appFrom){
if (YDLConstants.FROM_YDL != appFrom) {
return
}
val userId= ModularServiceManager.getPlatformUserService()?.getUser()?.userId?: ""
baiduCount(userId,partId,position,"","",convertType)
val userId = ModularServiceManager.getPlatformUserService()?.getUser()?.userId ?: ""
baiduCount(userId, partId, position, "", "", convertType)
}
fun baiduCount(uid: String?, partId: String, position: String, url: String, api: String, convertType: Int) {
var appId = "ydl-app-android-"+ (if (BaseApp.instance.getGlobalConfig().appFrom== YDLConstants.FROM_XLZX)"xlzx" else "user")
fun baiduCount(
uid: String?,
partId: String,
position: String,
url: String,
api: String,
convertType: Int
) {
var appId =
"ydl-app-android-" + (if (BaseApp.instance.getGlobalConfig().appFrom == YDLConstants.FROM_XLZX) "xlzx" else "user")
try {
val actionDataParams = ActionDataBean.Builder()
......@@ -185,6 +213,16 @@ class ActionCountUtils {
baiduActionDataParams.network(DeviceTool.getNetworkState(RxTool.getContext()))
baiduActionDataParams.convertParam("")
baiduActionDataParams.uid(uid)
try {
var mac = DeviceTool.getMac(BaseApp.getApp())
if (!TextUtils.isEmpty(mac)) {
mac = mac.replace(":", "")
}
com.ydl.ydlcommon.utils.LogUtil.d("MAC=${mac}")
baiduActionDataParams.mac(mac)
} catch (e: Exception) {
}
baiduActionDataParams.channel(YdlCommonOut.getChannelName())
val gson = Gson().toJson(baiduActionDataParams)
Log.e("Action", "---------$gson")
......@@ -206,13 +244,13 @@ class ActionCountUtils {
fun request(actionDataBean: ActionDataBean) {
try {
ApiRequestUtil.actionDataCount(actionDataBean)
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe({
LogUtil.i(TAG, it.data)
}) {
LogUtil.i(TAG, it.toString())
}
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe({
LogUtil.i(TAG, it.data)
}) {
LogUtil.i(TAG, it.toString())
}
} catch (e: Exception) {
e.printStackTrace()
}
......@@ -289,7 +327,8 @@ class ActionCountUtils {
*/
private fun isWifi(): Boolean {
try {
var connectivityManager: ConnectivityManager = RxTool.getContext().getSystemService(Context.CONNECTIVITY_SERVICE) as ConnectivityManager
var connectivityManager: ConnectivityManager =
RxTool.getContext().getSystemService(Context.CONNECTIVITY_SERVICE) as ConnectivityManager
var info: NetworkInfo = connectivityManager.activeNetworkInfo
if (info != null && info.type == ConnectivityManager.TYPE_WIFI) {
return true
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment