Android微信SDK API 调用教程

最近一直在调用微信的API,却发现一直调用不成功,纠结了好久,各方面找教程,找官方,官方里的文档也只是写得很模糊,说是按三步走。

1、申请App_ID

2、填写包名3、

获取程序签名的md5值,

这三步只要你走对了就能调通,可是大家都不知道有时候我们Eclipse调用的keystore和我们打包的keystore获取到的程序签名的md5是不一样的。而且是每一个keystore对应生成的apk的值都会不一样。我们在申请的时候填的程序签名值是正式打包的,但我们在eclipse部署上去的却是用的我们默认的debug.keystore.而这样导致的后果就是程序签名不一样,会一直调不通。甚至我们都不知道我们错在哪。

先说一下怎么部署微信官网下的demo吧:【下面引用的内容为微信官网】

微信对Android  API调用是需要严格 的三个验证,只有app_id包名和程序签名完全对了的情况下才可以调得通。

如何运行sdkdemo工程

1、解压sdk demo工程压缩包,并导入到workspace,如下图:

2、选择Eclipse顶部菜单Window->Preferences,在弹出的对话框中,选择Android目录下的Build,如下图:

指定Custom debugkeystore选项的路径为sdk demo工程目录中的debug.keystore文件,如下图:

并应用该配置。

3、运行该sdk_sample工程。

好了,按以上三步走,你就能走通微信的DEMO,现在再来看我们自己的DEMO

1、custom Debugkeystore:换成我们自己的keystore

为方便你可以直接复制上面的default Debug keystore,然后接着走第二步

2、装上我们的应用到手机端,再去微信官网下载一个获取程序签名md5值的apk输入包名:

3、去微信后台申请我们调试的应用:

接着再写上示例代码中的代码:

[java] view plaincopyprint?

  1. private Button btn_share;
  2. public static final String WX_APP_ID = "wxc85b9dbef61b3fe4";
  3. private IWXAPI api;
  4. private String text="testssss";
  5. @Override
  6. public void onCreate(BundlesavedInstanceState) {
  7. super.onCreate(savedInstanceState);
  8. setContentView(R.layout.main);
  9. btn_share = (Button)findViewById(R.id.btn_share);
  10. api = WXAPIFactory.createWXAPI(this, WX_APP_ID,false);
  11. btn_share.setOnClickListener(new OnClickListener() {
  12. @Override
  13. public void onClick(View v) {
  14. api.registerApp(WX_APP_ID);
  15. // 初始化一个WXTextObject对象
  16. WXTextObjecttextObj = newWXTextObject();
  17. textObj.text = text;
  18. // 用WXTextObject对象初始化一个WXMediaMessage对象
  19. WXMediaMessagemsg = newWXMediaMessage();
  20. msg.mediaObject = textObj;
  21. // 发送文本类型的消息时,title字段不起作用
  22. msg.title = "Will be ignored";
  23. msg.description = "sdddd";
  24. // 构造一个Req
  25. SendMessageToWX.Reqreq = newSendMessageToWX.Req();
  26. req.transaction = buildTransaction("text"); // transaction字段用于唯一标识一个请求
  27. req.message = msg;
  28. //req.scene = SendMessageToWX.Req.WXSceneTimeline ;
  29. // 调用api接口发送数据到微信
  30. api.sendReq(req);
  31. finish();
  32. }
  33. });
  34. }
  35. private StringbuildTransaction(finalString type) {
  36. return (type == null) ? String.valueOf(System.currentTimeMillis())
  37. :type + System.currentTimeMillis();
  38. }

至此,大功告成。千万别忘记你程序打包用的keysotre再用那个微信提供的程序打包获取到签名和你在eclpise程序部署获取到的签名是不一样的。我们可以再申请一个正式的应用,填写信息可以完全一样,但是只要改掉

和你的app_id

微信获取程序签名工具下载地址:http://open.weixin.qq.com/download/sdk/gen_signature.apk

不知道大家是否有看通。如果再有疑问的话可以加我。希望此文章能帮助到正在用微信API的Android码农们。

如需转载引用请注明出处:http://blog.csdn.net/jiahui524

时间: 2024-08-03 22:19:37

Android微信SDK API 调用教程的相关文章

Android - 微信SDK的Demo调试

微信SDK的Demo调试 本文地址: http://blog.csdn.net/caroline_wendy 微信的SDK在使用时,会有一些问题,需要进行调试. 1. png图片错误:png图片错误,在网络上重新转换为png格式即可. 2. 获取token错误:修改scope和state,即可. // get token findViewById(R.id.get_token).setOnClickListener(new View.OnClickListener() { @Override p

微信企业号api调用频率

主动调用的频率限制 当你获取到AccessToken时,你的应用就可以成功调用企业号后台所提供的各种接口以管理或访问企业号后台的资源或给企业号成员发消息. 为了防止企业应用的程序错误而引发企业号服务器负载异常,默认情况下,每个企业号调用接口都有一定的频率限制,当超过此限制时,调用对应接口会收到相应错误码. 以下是当前默认的频率限制,企业号后台可能会根据运营情况调整此阈值: 基础频率 每企业调用单个cgi/api不可超过1000次/分,30000次/小时 每ip调用单个cgi/api不可超过200

android 百度地图API使用教程说明

导入库文件 在下载页面下载最新的库文件.将liblocSDK2.4.so文件拷贝到libs/armeabi目录下.将locSDK2.4.jar文件拷贝到工程根目录下,并在工程属性->Java Build Path->Libraries中选择"Add JARs",选定locSDK2.4.jar,确定后返回.这样您就可以在程序中使用百度定位API了. 设置AndroidManifest.xml 为区分2.3版本service,需要将manifest file中的 intent

android 使用NDK api调用AssetManager

{ 工具类代码 public native static  String getAssetStringUseJNI(Context context,String path); 1 NDK代码 #include <jni.h>#include <assert.h>#include <string.h>#include <malloc.h>#include <android/asset_manager.h>#include <android/a

Android利用微信SDK分享到微信教程,回调分享结果错误解决和注意点

在正式开始之前这里要着啰嗦一下,进来的同学一定要看,在申请应用的时候要填一个签名,这个签名是由应用的签名文件keystore决定的,那么你在填这个签名的时候,一定要把你的应用用正式的keyStore生成apk,安装到手机,然后用微信提供的获取应用签名的apk工具获取你应用的签名,然后这会生成的这个签名才是正确的,千万记得,不要使用dubug的ketStore测试,不然后面虽然可以修改,修改了后要审核,但是审核也是需要时间的,会很麻烦. 还有一点,你在测试微信分享的时候可能会直接在Eclipse好

Senparc.Weixin.MP SDK 微信公众平台开发教程(十六):AccessToken自动管理机制

Senparc.Weixin.MP SDK 微信公众平台开发教程(十六):AccessToken自动管理机制 在<Senparc.Weixin.MP SDK 微信公众平台开发教程(八):通用接口说明>中,我介绍了获取AccessToken(通用接口)的方法. 在实际的开发过程中,所有的高级接口都需要提供AccessToken,因此我们每次在调用高级接口之前,都需要执行一次获取AccessToken的方法,例如: 1 var accessToken = AccessTokenContainer.

Senparc.Weixin.MP SDK 微信公众平台开发教程(十一):高级接口说明

这里所说的高级接口是指面向通过认证的服务号开通的高级功能. 高级功能大致可以分类为: 用户接口 分组接口 客服接口(有别于之前介绍的多客服) 群发接口 多媒体接口 二维码接口 模板消息接口(不是所有账号都可开通) OAuth2.0(相对比较复杂,后面会有专门介绍) 以上所有的接口都包含在Senparc.Weixin.MP.AdvancedAPIs命名空间下. 一些共同的操作 几乎所有的高级接口都需要用到AccessToken来通讯(注意,下面如果没有特殊说明的接口都需要这个AccessToken

Senparc.Weixin.MP SDK 微信公众平台开发教程(二):成为开发者

Senparc.Weixin.MP SDK 微信公众平台开发教程(二):成为开发者 这一篇主要讲作为一名使用公众平台接口的开发者,你需要知道的一些东西.其中也涉及到一些微信官方的规定或比较掩蔽的注意点.欢迎补充! 我觉得做好成为开发者的准备比稀里糊涂开通微信后台的"高级"功能更重要,所以这一节先放在前面说. 一.公众平台的通讯过程 作为开发者,我们需要面对的主要有两个对象:微信服务器和应用程序(网站)服务器. 当微信用户向你的公众平台发送一条消息,实际上这条消息首先发送到微信服务器,由

Senparc.Weixin.MP SDK 微信公众平台开发教程(十二):OAuth2.0说明

紧接上一篇<Senparc.Weixin.MP SDK 微信公众平台开发教程(十一):高级接口说明>,这里专讲OAuth2.0. 理解OAuth2.0 首先我们通过一张图片来了解一下OAuth2.0的运作模式: 从上图我们可以看到,整个过程进行了2次"握手",最终利用授权的AccessToken进行一系列的请求,相关的过程说明如下: A:由客户端向服务器发出验证请求,请求中一般会携带这些参数 ID标识,例如appId 验证后跳转到的URL(redirectUrl) 状态参数