ホームページ >WeChat アプレット >WeChatの開発 >Android開発の詳細なグラフィックとテキストの説明 WeChat認証ログインとWeChat共有分析
この記事では主に写真とテキストで詳細な説明を紹介しますAndroidWeChat認証ログインとWeChat共有分析の開発 必要に応じて、詳細を学ぶことができます。
はじめに
モバイル インターネットの波の中で、インターネットに接続された APP は、自社のアプリケーションにアカウント システムが搭載されることを望んでいますが、多くのユーザーは必ずしもそれを購入する必要はありません。アプリケーションのアカウントに登録しますか? Weibo、Weibo、および QQ は、ほぼすべての人の携帯電話にインストールする必要のあるアプリケーションになりました。そのため、WeChat、Weibo、および QQ は次のように言いました。「さあ、さあ、皆さんは私のアカウントを使用してホーム アプリケーションにログインできます。あなたは OAuth2.0 に従っています。まさにプロトコル標準です。したがって、サードパーティのソーシャル アカウント ログインは、テンセントの公式 WeChat オープン プラットフォームのオンライン ドキュメントが最新の SDK とは多少異なり、ログイン関連ドキュメントの構造順序が多少乱れているため、多くの新興アプリケーションで選択されるようになりました。 WeChat オープン プラットフォームの公式オンライン ドキュメントを整理するために、今日ここで私の経験の一部を記録します。同時に、WeChat 共有は自分の APP の影響力を拡大することができるため、WeChat 共有機能は多くの開発者にとって必要な機能でもあり、同じ分野の将来の友人に役立つことを願ってここにまとめました。
WeChat ログイン
以下の内容は Tencent Open Platform からの抜粋です: https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_ リスト&t=リソース/res_list&verify=1&id=open1419317851&token=6bfe3acd2969037c7217667f24f8eeaf714e5113&lang=zh_CN
認証プロセスの説明
WeChat OAuth2.0 認証ログインにより、WeChat ユーザーは WeChat ID を使用できるようになります 安全性サードパーティへのログイン アプリケーションまたは Web サイトの場合、WeChat ユーザーが WeChat OAuth2.0 に接続されているサードパーティ アプリケーションへのログインを承認した後、サードパーティはユーザーのインターフェース呼び出し資格情報 (access_token) を取得できます。 access_token を使用して WeChat オープン プラットフォーム認証関係インターフェイス呼び出しを行うと、WeChat ユーザーの基本的なオープン情報を取得し、ユーザーが基本的なオープン機能を実現できるようになります。
WeChat OAuth2.0 認証ログインは現在、サーバー側でのアプリケーション認証に適した authorization_code モードをサポートしています。このモデルの全体的なプロセスは次のとおりです:
1. WeChat ユーザーがサードパーティ アプリケーションの承認を許可した後、サードパーティが WeChat 認証ログイン リクエストを開始し、WeChat がアプリケーションを起動するか、サードパーティ Web サイトにリダイレクトします。
2. code パラメータを介して AppID と AppSecret を追加し、
を介してインターフェース呼び出しを行い、ユーザーの基本データ リソースを取得します。ユーザーが基本的な操作を実装できるように支援します。
access_token シーケンス図を取得します:
注: 開発者が
ログイン インターフェースを呼び出す必要がある場合、開発者認証を通過し、300Dayang を支払う必要があると公式オンライン ドキュメントに記載されています。実際、それは過去のことであり、オンラインドキュメントが更新されていないだけです。 以下、WeChatの認証ログイン手順を順に説明していきます。すべてのネットワーク リクエストは GET リクエストです。
1. 一時的なチケットコードを取得します
2. access_token と openid を取得します
4. access_token を更新または更新します
{
// 发出授权申请
Final SendAuth.Req req = new SendAuth.Req();
req.scope = "snsapi_userinfo";
req.state = "wechat_sdk_微信登录,分享demo_test";
api.sendReq(req);
}
左の2つの矢印のプロセスはコードに反映されています:
public void onResp(BaseResp resp) ;// 这个回调接口位于IWXAPIEventHandler中
ErrorCode: ERR_OK = 0 (ユーザーが同意) ERR_AUTH_DENIED = -4 (ユーザーが認証を拒否); 2 (ユーザーキャンセル)
code: ユーザーが access_token と交換するコード。ErrCode が 0 の場合にのみ有効
state: サードパーティプログラムによって送信されたリクエストの一意性を識別するために使用されるフラグ。 sendReq がサードパーティ プログラムによって呼び出された場合、WeChat 端末によって返される受信、状態
文字列lang:微信客户端当前语言
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无法正常运行。在此进行解释:
デモ ソース コードによって生成された APK が正常に実行できない理由は、WeChat オープン プラットフォームにアプリケーションを追加するときに、パッケージ名、アプリケーション署名、および app_id がバインドされるためです。署名した APK は機能しません。デモ コードは参照と連絡のみを目的としています。
以上がAndroid開発の詳細なグラフィックとテキストの説明 WeChat認証ログインとWeChat共有分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。