這篇文章給大家介紹怎么在Android中實現(xiàn)第三方登錄與分享功能,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
10年積累的網(wǎng)站制作、成都做網(wǎng)站經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先網(wǎng)站設(shè)計后付款的網(wǎng)站建設(shè)流程,更有豐順免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
1.下載shareSDK分享的SDK
2.導(dǎo)入jar與res
打開開發(fā)文檔并下載對應(yīng)的SDK以及demo,下載SDK時要選擇你需要的功能
下載完的文件對應(yīng)的功能如下圖所示:
導(dǎo)入到Android studio中并添加依賴
3.配置Android Manifest XML
sdk中需要的Activity
新浪
<activity android:name="com.umeng.socialize.media.WBShareCallBackActivity" android:configChanges="keyboardHidden|orientation" android:theme="@android:style/Theme.Translucent.NoTitleBar" android:exported="false" > </activity> <activity android:name="com.sina.weibo.sdk.web.WeiboSdkWebActivity" android:configChanges="keyboardHidden|orientation" android:exported="false" android:windowSoftInputMode="adjustResize" > </activity> <activity android:theme="@android:style/Theme.Translucent.NoTitleBar.Fullscreen" android:launchMode="singleTask" android:name="com.sina.weibo.sdk.share.WbShareTransActivity"> <intent-filter> <action android:name="com.sina.weibo.sdk.action.ACTION_SDK_REQ_ACTIVITY" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity>
微信
<activity android:name=".wxapi.WXEntryActivity" android:configChanges="keyboardHidden|orientation|screenSize" android:exported="true" android:theme="@android:style/Theme.Translucent.NoTitleBar" />
<activity android:name="com.tencent.tauth.AuthActivity" android:launchMode="singleTask" android:noHistory="true" > <intent-filter> <action android:name="android.intent.action.VIEW" /> <category android:name="android.intent.category.DEFAULT" /> <category android:name="android.intent.category.BROWSABLE" /> <data android:scheme="tencent100424468" /> </intent-filter> </activity> <activity android:name="com.tencent.connect.common.AssistActivity" android:theme="@android:style/Theme.Translucent.NoTitleBar" android:configChanges="orientation|keyboardHidden|screenSize"/>
添加權(quán)限:
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <uses-permission android:name="android.permission.INTERNET" />
適配
Android6.0權(quán)限適配
if(Build.VERSION.SDK_INT>=23){ String[] mPermissionList = new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE,Manifest.permission.ACCESS_FINE_LOCATION,Manifest.permission.CALL_PHONE,Manifest.permission.READ_LOGS,Manifest.permission.READ_PHONE_STATE, Manifest.permission.READ_EXTERNAL_STORAGE,Manifest.permission.SET_DEBUG_APP,Manifest.permission.SYSTEM_ALERT_WINDOW,Manifest.permission.GET_ACCOUNTS,Manifest.permission.WRITE_APN_SETTINGS}; ActivityCompat.requestPermissions(this,mPermissionList,123); }
其中123是requestcode,可以根據(jù)這個code判斷,用戶是否同意了授權(quán)。如果沒有同意,可以根據(jù)回調(diào)進(jìn)行相應(yīng)處理:
@Override public void onRequestPermissionsResult(int requestCode, String permissions[], int[] grantResults) { }
初始化設(shè)置
@Override public void onCreate() { super.onCreate(); UMConfigure.init(this,"5a12384aa40fa3551f0001d1" ,"umeng",UMConfigure.DEVICE_TYPE_PHONE,"");//58edcfeb310c93091c000be2 5965ee00734be40b580001a0 }
接下來需要設(shè)置各個平臺的appkey:
PlatformConfig.setWeixin("wxdc1e388c3822c80b", "3baf1193c85774b3fd9d18447d76cab0"); //豆瓣RENREN平臺目前只能在服務(wù)器端配置 PlatformConfig.setSinaWeibo("3921700954", "04b48b094faeb16683c32669824ebdad","http://sns.whalecloud.com"); PlatformConfig.setYixin("yxc0614e80c9304c11b0391514d09f13bf"); PlatformConfig.setQQZone("100424468", "c7394704798a158208a74ab60104f0ba"); PlatformConfig.setTwitter("3aIN7fuF685MuZ7jtXkQxalyi", "MK6FEYG63eWcpDFgRYw4w9puJhzDl0tyuqWjZ3M7XJuuG7mMbO"); PlatformConfig.setAlipay("2015111700822536"); PlatformConfig.setLaiwang("laiwangd497e70d4", "d497e70d4c3e4efeab1381476bac4c5e"); PlatformConfig.setPinterest("1439206"); PlatformConfig.setKakao("e4f60e065048eb031e235c806b31c70f"); PlatformConfig.setDing("dingoalmlnohc0wggfedpk"); PlatformConfig.setVKontakte("5764965","5My6SNliAaLxEm3Lyd9J"); PlatformConfig.setDropbox("oz8v5apet3arcdy","h7p2pjbzkkxt02a"); PlatformConfig.setYnote("9c82bf470cba7bd2f1819b0ee26f86c6ce670e9b");
簽名
必須用keystore簽名后的apk來測試,簽名文件如果不加,部分平臺的授權(quán)會受到影響。
使用步驟
一.分享
友盟分享分為兩種形式:
使用分享面板的分享,用戶可以調(diào)用我們的打開分享面板的方法,點擊分享面板的對應(yīng)平臺進(jìn)行分享。
不使用分享面板的分享,用戶可以自己寫分享按鈕,或者觸發(fā)事件,然后調(diào)用我們的分享方法,進(jìn)行分享。簡而言之,直接分享就是在用戶自己的界面組件中插入分享行為,分享面板是打開我們寫好的一個界面組件,根據(jù)點擊事件進(jìn)行分享。
打開分享面板的代碼如下:
new ShareAction(MainActivity.this) .setPlatform(SHARE_MEDIA.QQ)//傳入平臺 .withText("hello")//分享內(nèi)容 .setCallback(umShareListener)//回調(diào)監(jiān)聽器 .share();
分享的類型有多種,具體可以看友盟開發(fā)者文檔,這里以連接為例:
分享鏈接可以使用UMWeb進(jìn)行分享:
UMWeb web = new UMWeb(Defaultcontent.url); web.setTitle("This is music title");//標(biāo)題 web.setThumb(thumb); //縮略圖 web.setDescription("my description");//描述
然后調(diào)用將這個參數(shù)設(shè)置到ShareAction中:
new ShareAction(ShareActivity.this) .withMedia(web) .share();
二.第三方登錄
第三方登錄包含兩種使用場景:
獲取用戶資料的授權(quán)接口,使用該接口可以獲取該三方平臺返回的所有資料(包括姓名,性別,頭像等)目前支持第三方登錄的平臺包括:
國內(nèi)平臺(微信、新浪微博、QQ、豆瓣、人人)
國外平臺(Facebook、Twitter、linkedIn、kakao、VKontakte、Dropbox)
這里推薦直接使用第一種方式實現(xiàn),因為本質(zhì)上三方登錄最終都需要拉取三方平臺的用戶資料,從這點來說,直接調(diào)用SDK和通過后臺服務(wù)器請求,安全性是一樣的
第三方登錄包含兩種使用場景:
獲取用戶資料的授權(quán)接口,使用該接口可以獲取該三方平臺返回的所有資料(包括姓名,性別,頭像等)目前支持第三方登錄的平臺包括:
國內(nèi)平臺(微信、新浪微博、QQ、豆瓣、人人)
國外平臺(Facebook、Twitter、linkedIn、kakao、VKontakte、Dropbox)
這里推薦直接使用第一種方式實現(xiàn),因為本質(zhì)上三方登錄最終都需要拉取三方平臺的用戶資料,從這點來說,直接調(diào)用SDK和通過后臺服務(wù)器請求,安全性是一樣的
獲取用戶資料
獲取用戶資料可以使用如下接口:
mShareAPI.getPlatformInfo(UserinfoActivity.this, SHARE_MEDIA.SINA, umAuthListener);
其中umAuthListener為授權(quán)回調(diào),構(gòu)建如下:
UMAuthListener authListener = new UMAuthListener() { /** * @desc 授權(quán)開始的回調(diào) * @param platform 平臺名稱 */ @Override public void onStart(SHARE_MEDIA platform) { } /** * @desc 授權(quán)成功的回調(diào) * @param platform 平臺名稱 * @param action 行為序號,開發(fā)者用不上 * @param data 用戶資料返回 */ @Override public void onComplete(SHARE_MEDIA platform, int action, Map<String, String> data) { Toast.makeText(mContext, "成功了", Toast.LENGTH_LONG).show(); } /** * @desc 授權(quán)失敗的回調(diào) * @param platform 平臺名稱 * @param action 行為序號,開發(fā)者用不上 * @param t 錯誤原因 */ @Override public void onError(SHARE_MEDIA platform, int action, Throwable t) { Toast.makeText(mContext, "失?。?quot; + t.getMessage(), Toast.LENGTH_LONG).show(); } /** * @desc 授權(quán)取消的回調(diào) * @param platform 平臺名稱 * @param action 行為序號,開發(fā)者用不上 */ @Override public void onCancel(SHARE_MEDIA platform, int action) { Toast.makeText(mContext, "取消了", Toast.LENGTH_LONG).show(); } };
關(guān)于怎么在Android中實現(xiàn)第三方登錄與分享功能就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
網(wǎng)頁名稱:怎么在Android中實現(xiàn)第三方登錄與分享功能
本文網(wǎng)址:http://aaarwkj.com/article34/ipddpe.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、ChatGPT、網(wǎng)站內(nèi)鏈、手機(jī)網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、定制網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)