Heim >WeChat-Applet >WeChat-Entwicklung >Detaillierte Grafik- und Texterklärung zur Android-Entwicklung, WeChat-autorisierte Anmeldung und WeChat-Sharing-Analyse

Detaillierte Grafik- und Texterklärung zur Android-Entwicklung, WeChat-autorisierte Anmeldung und WeChat-Sharing-Analyse

高洛峰
高洛峰Original
2017-03-15 17:19:122412Durchsuche

Dieser Artikel enthält hauptsächlich detaillierte grafische und textliche Erläuterungen zur Android-Entwicklung der autorisierten WeChat-Anmeldung und der WeChat-Sharing-Analyse. Bei Bedarf können Sie mehr darüber erfahren.

Vorwort

In der Welle des mobilen Internets haben mit dem Internet verbundene APPs Einzelmaschinengeräte am Strand zerstört. Viele Unternehmen hoffen, dass ihre Anwendungen über ein Kontosystem verfügen können, aber viele Benutzer tun dies nicht unbedingt kaufen: Warum sollte ich ein Konto für Ihre Bewerbung registrieren? Weibo, WeChat und QQ sind fast zu Anwendungen geworden, die auf jedem Mobiltelefon installiert werden müssen. Deshalb sagten WeChat, Weibo und QQ: Komm schon, komm schon, ihr könnt alle mein Konto verwenden, um euch bei euren Heimanwendungen anzumelden, solange Sie folgen OAuth2.0. Nur dem Protokollstandard. Daher ist die Anmeldung bei sozialen Konten von Drittanbietern zur Wahl vieler neuer Anwendungen geworden. Da sich die Online-Dokumente der offiziellen offenen WeChat-Plattform von Tencent etwas vom neuesten SDK unterscheiden und die strukturelle Reihenfolge der Anmeldedokumente etwas ungeordnet ist, werde ich dies tun Zeichnen Sie heute hier einige meiner Erfahrungen auf, um die offiziellen Online-Dokumente der offenen WeChat-Plattform zu organisieren. Gleichzeitig kann die WeChat-Freigabe den Einfluss Ihrer eigenen APP erweitern, sodass die WeChat-Freigabefunktion auch eine Funktion ist, die viele Entwickler benötigen. Ich habe sie hier zusammengestellt, in der Hoffnung, für zukünftige Freunde auf demselben Gebiet hilfreich zu sein.

WeChat-Anmeldung

Der folgende Inhalt ist ein Auszug aus der Tencent Open Platform: https://open.weixin.qq.com /cgi -bin/showdocument?action=dir_list&t=resource/res_list&verif y=1&id=open1419317851&token=6bfe3acd2969037c7217667f24f8eeaf714e5113&lang=zh_CN

Autorisierungsprozess. Beschreibung

Wir Chat OAuth2.0 autorisierte Anmeldung für WeChat Die WeChat-Identität des Benutzers ist sicher , um sich bei Anwendungen oder Websites von Drittanbietern anzumelden. Nachdem der WeChat-Benutzer die Anmeldung bei der mit WeChat OAuth2.0 verbundenen Drittanbieteranwendung autorisiert hat, kann der Drittanbieter dies tun Erhalten Sie die Anmeldeinformationen der Schnittstelle des Benutzers (access_token). Über access_token kann die Autorisierungsbeziehungsschnittstelle der offenen WeChat-Plattform aufgerufen werden, um die grundlegenden Öffnungsinformationen von WeChat-Benutzern zu erhalten und Benutzern bei der Realisierung grundlegender Öffnungen zu helfen Funktionen.

Die autorisierte WeChat OAuth2.0-Anmeldung unterstützt derzeit den Authorization_Code-Modus, der für die serverseitige Anwendungsautorisierung geeignet ist. Der Gesamtprozess dieses Modells ist:

1. Ein Dritter initiiert eine autorisierte WeChat-Anmeldeanfrage. Nachdem der WeChat-Benutzer die Autorisierung der Drittanbieteranwendung zulässt, startet WeChat die Anwendung oder leitet sie weiter die Website eines Drittanbieters und bringen Sie den temporären Ticketcode-Parameter

2 mit. Fügen Sie AppID und AppSecret über den Code-Parameter hinzu und tauschen Sie access_token über API aus 🎜>3. Pass access_token führt einen Schnittstellenaufruf durch, um die grundlegenden Datenressourcen des Benutzers abzurufen oder dem Benutzer bei der Implementierung grundlegender Vorgänge zu helfen.

Access_token-Sequenzdiagramm abrufen:

Hinweis: Wenn der Entwickler die Anmeldeschnittstelle

aufrufen muss, ist eine Entwicklerauthentifizierung erforderlich und wird übermittelt

300Dayang, das offizielle Online-Dokument besagt, dass keine Zahlung erforderlich ist. Tatsächlich gehört das der Vergangenheit an, aber das Online-Dokument wurde nicht aktualisiert. Im Folgenden wird der autorisierte WeChat-Anmeldevorgang der Reihe nach erläutert. Alle Netzwerkanfragen sind GET-Anfragen.

1. Temporären Ticketcode abrufen

2. Access_token & openid abrufen

3. Überprüfen Sie, ob access_token gültig ist

4. Zugriffstoken aktualisieren oder erneuern

5. WeChat-Benutzerdaten abrufen


Vorläufigen Ticketcode abrufen

Die ersten drei nach rechts zeigenden Pfeile



Der Vorgang der beiden nach links zeigenden Pfeile spiegelt sich im Code wider:

{ 
  // 发出授权申请
  Final SendAuth.Req req = new SendAuth.Req();
  req.scope = "snsapi_userinfo";
  req.state = "wechat_sdk_微信登录,分享demo_test";
  api.sendReq(req);
}



Die zurückgegebenen Daten sind resp. Wenn sie zur Anforderung der Anmeldeautorisierung verwendet werden, handelt es sich um eine Instanz von SendAuth.Resp. Die übertragenen Daten sind:

public void onResp(BaseResp resp) ;// 这个回调接口位于IWXAPIEventHandler中


Fehlercode: ERR_OK = 0 (Benutzer stimmt zu); ERR_AUTH_DENIED = -4 (Benutzer verweigert die Autorisierung); ERR_USER_CANCEL = -2 (Benutzer bricht ab)
  1. Code : Benutzeraustausch Der Code von access_token ist nur gültig, wenn ErrCode 0 ist
  2. Status: ein Flag, das von einem Drittanbieterprogramm verwendet wird, um die Einzigartigkeit seiner Anfrage beim Senden zu identifizieren, übergeben Wenn das Drittanbieterprogramm sendReq aufruft, das vom WeChat-Terminal zurückgegeben wird, darf die Länge des Status
  3. string
  4. 1K

    nicht überschreiten

  5. lang:微信客户端当前语言

  6. country:微信客户端当前国家

以上数据均以static String形式存在SendAuth.Resp的resp对象中。

注意:当使用微信提供最新的SDK/library时,上面有些数据是不存在,微信开放平台的文档和API及SDK没有同步更新。读者可使用最下方微信登录,分享demo中的笔者使用的jar包构建工程。

获取access_token & openid

最后一条向右的箭头表示:使用得到的code,获取access_token,openid,接口为:
https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code

注意:微信的接口链接是使用SSL的安全链接,普通的HttpClient访问会导致应用崩溃或报错,详细方法请下载最下方的微信登录,分享demo代码

参数说明

  • appid:  应用唯一标识,在微信开放平台提交应用审核通过后获得

  • secret:应用密钥AppSecret,在微信开放平台提交应用审核通过后获得

  • code    :填写第一步获取的code参数

  • grant_type:固定值,填authorization_code

最下方向左的箭头表示使用code访问完链接返回的数据,json携带的数据有:

  • access_token:接口调用凭证

  • expires_in:access_token的有效期,一般为7200(秒),也即是两小时

  • refresh_token:用户刷新access_token

  • openid:授权用户唯一标识

  • scope:用户授权的作用域,使用逗号(,)分隔

检查access_token是否有效

由于access_token有效期为两小时,所以进行下一步操作前最好进行一次检查,接口为:
https://api.weixin.qq.com/sns/auth?access_token=ACCESS_TOKEN&openid=OPENID 

传入的参数为accesss_token和openid。

access_token有效时返回的json是:


{ 
"errcode":0,"errmsg":"ok"
}

失效时的返回数据为:


{ 
"errcode":40003,"errmsg":"invalid openid"
}

如果access_token有效,则跳过下一步,失效时需要刷新或续期access_token。

刷新或续期access_token

接口说明

access_token是调用授权关系接口的调用凭证,由于access_token有效期(目前为2个小时)较短,当access_token超时后,可以使用refresh_token进行刷新,access_token刷新结果有两种:

1.若access_token已超时,那么进行refresh_token会获取一个新的access_token,新的超时时间;

2.若access_token未超时,那么进行refresh_token不会改变access_token,但超时时间会刷新,相当于续期access_token。

refresh_token拥有较长的有效期(30天),当refresh_token失效的后,需要用户重新授权。

刷新accessToken接口为:
https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=APPID&grant_type=refresh_token&refresh_token=REFRESH_TOKEN 

参数说明:

  • appid:应用唯一标识

  • grant_type:固定值,填refresh_token

  • refresh_token:填写前面获取到的refresh_token的值

返回的json数据有:

  • access_token:接口调用凭证

  • expires_in:access_token接口调用凭证超时时间,单位(秒)

  • refresh_token:用户刷新access_token

  • openid:授权用户唯一标识

  • scope:用户授权的作用域,使用逗号(,)分隔

获取微信用户详细信息

获取access_token,openid后,就可以用来获取更多用户信息,比如微信昵称,头像,性别等。接口为:
https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID 

可获取的json携带的数据有:

  • openid:普通用户的标识,对当前开发者帐号唯一

  • nickname:普通用户昵称

  • sex:普通用户性别,1为男性,2为女性

  • province:普通用户个人资料填写的省份

  • city:普通用户个人资料填写的城市

  • country:国家,如中国为CN

  • headimgurl:用户头像,最后一个数值代表正方形头像大小(有0、46、64、96、132数值可选,0代表640*640正方形头像),用户没有头像时该项为空

  • privilege:用户特权信息,json数组,如微信沃卡用户为(chinaunicom)

  • unionid:用户统一标识。针对一个微信开放平台帐号下的应用,同一用户的unionid是唯一的。

微信官方建议: 

 开发者最好保存unionID信息,以便以后在不同应用之间进行用户信息互通。

微信登录的流程结束了, 至于开发者需要将那些用户信息上传到自家的app服务器就取决于开发者了。

微信分享

1、微信分享分为微信好友分享,朋友圈分享,当然,还有收藏也是共用分享的接口,无需授权登录即可调用分享接口。

2、由于好友分享,朋友圈分享和收藏只是一个参数的区别,所以下面只讲好友分享,具体的可以下载最下方的微信登录,分享demo源码进行查看。

3、微信可以分享的内容包括,纯文字,图片,链接,音乐,视频,app,emoji表情等。

微信分享流程

1、在你的工程里面新建一个wxapi包,并且新建一个WXEntryActivity,继承Activity,或其他Activity(这两步是必须的,微信开发文档中有提到),详见:
https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=1417751808&token=&lang=zh_CN 

 2、并在manifest文件里面加上exported属性,设置为true。

3、实现一个IWXAPIEventHandler接口。 

 微信发送的请求将回调到onReq方法,发送到微信请求的响应结果将回调到onResp方法 

在WXEntryActivity中将接收到的intent及实现了IWXAPIEventHandler接口的对象传递给IWXAPI接口的handleIntent方法,示例如下: 


api.handleIntent(getInent(),this);

当微信发送请求到你的应用,将通过IWXAPIEventHandler接口的onReq方法进行回调,类似的,应用请求微信的响应结果将通过onResp回调。

注意 

如果需要混淆代码,为了保证sdk的正常使用,需要在proguard.cfg加上下面两行配置:


-keep class com.tencent.mm.sdk.** { 
 *; 
 }

微信分享详细代码流程是:


IWXAPI api = WXAPIFactory.createWXAPI(this, APP_ID, false);// 传入申请到的appid,得到一个IWXAPI的实例
api.registerApp(APP_ID);// 将app注册到微信列表,我不知道这是什么意思,有知道的请告诉我,谢谢!

// 开始分享纯文本到给好友
WXTextObject textObj = new WXTextObject();
textObj.text = text;

// 用WXTextObject对象初始化一个WXMediaMessage对象
WXMediaMessage msg = new WXMediaMessage();
msg.mediaObject = textObj;

// 发送文本类型的消息时,title字段不起作用
// msg.title = "Will be ignored";
msg.title = "分享文字标题";
msg.description = text;

// 构造一个Req
SendMessageToWX.Req req = new SendMessageToWX.Req();
req.transaction = buildTransaction("text"); // transaction字段用于唯一标识一个请求
req.message = msg;

req.scene = SendMessageToWX.Req.WXSceneTimeline;// 表示发送场景为朋友圈,这个代表分享到朋友圈
// req.scene = SendMessageToWX.Req.WXSceneSession;//表示发送场景为好友对话,这个代表分享给好友
// req.scene = SendMessageToWX.Req.WXSceneFavorite;// 表示发送场景为收藏,这个代表添加到微信收藏
// 调用api接口发送数据到微信 
api.sendReq(req);

上面大致的表现了一个分享纯文本给好友的场景,如果需要分享到朋友圈,只需要更改req.scene字段值。

1、其中IWXAPI.registerAPP(APP_ID)是官方demo中的一行代码,表示的是将app注册到微信列表,我并不知道有什么用,所谓的微信列表出现在哪儿?该行代码删除后,仍然可以获取登录授权,实现分享等功能。有知道的请告诉我,谢谢!

2、目前笔者遇到无法分享在线图片WXImageObject的问题,分享在线图片时出现分享界面右上角“发送”按钮灰色,无法点击的情况,希望分享成功的朋友告诉我,谢谢!问题如下图

要分享链接,图片,音乐,视频等需要将WXTextObject 对象改成对应的obj对象。详细请下载文章下方的微信登录,分享demo。

后记

由于微信官方demo中并未提供微信登录的代码示例,分享的代码很齐全,可是分享在线图片的代码在我这里却又问题,所以笔者将自己的一些经验和遇到的坑总结在这里,包括了微信第三方登录,微信分享的内容,希望对大家有所帮助。也希望笔者在文中提到的问题有热心人能够解答


//1、 注册到微信列表有什么用,微信列表在哪儿可以看到
IWXAPI.registerApp(APP_ID);
//2、 我为什么无法使用以下代码分享在线图片
WXImageObject imgObj = new WXImageObject();
imgObj.imageUrl = imgUrl;// 在线图片链接

WXMediaMessage msg = new WXMediaMessage();
msg.mediaObject = imgObj;

Bitmap bmp = BitmapFactory.decodeStream(new URL(url).openStream());
Bitmap thumbBmp = Bitmap.createScaledBitmap(bmp, THUMB_SIZE, THUMB_SIZE, true);
bmp.recycle();
msg.thumbData = Util.bmpToByteArray(thumbBmp, true);

SendMessageToWX.Req req = new SendMessageToWX.Req();
req.transaction = buildTransaction("img");
req.message = msg;
req.scene = isTimelineCb.isChecked() ? SendMessageToWX.Req.WXSceneTimeline : SendMessageToWX.Req.WXSceneSession;
api.sendReq(req);

最近有人向我反映生成的apk无法正常运行。在此进行解释:

Der Grund, warum die durch den Demo-Quellcode generierte APK nicht normal ausgeführt werden kann, ist: Beim Hinzufügen einer Anwendung zur offenen WeChat-Plattform sind der Paketname, die Anwendungssignatur und die App_ID gebunden. Die von Ihnen signierte APK funktioniert nicht und der Democode dient nur als Referenz und Kommunikation.

Das obige ist der detaillierte Inhalt vonDetaillierte Grafik- und Texterklärung zur Android-Entwicklung, WeChat-autorisierte Anmeldung und WeChat-Sharing-Analyse. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn