支付宝支付传送门:https://www.cnblogs.com/dingxiansen/p/9208949.html

二、微信支付

1. 微信支付流程图


相比较而言,微信支付是要比支付宝麻烦一些,并且微信的开发文档个人也感觉写的比较乱,初次接触会有些懵。

2. 集成前准备

  1. 注册、登录微信开发者平台
  2. 注册应用,得到APPID申请开通微信支付,填写申请资料
  3. 找到 开发者文档 下载SDK

3.开始集成

  微信支付可以直接在app build.gradle中设置

/*微信支付集成*/
compile 'com.tencent.mm.opensdk:wechat-sdk-android-with-mta:+'

  然后在你的包下,这里要注意以下放在指定包下边

  

 AndroidManifest.xml配置

 <!--微信支付,回掉-->
<activity
android:name=".wxapi.WXPayEntryActivity"
android:exported="true"
android:launchMode="singleTop" />

微信的后台参数返回,相对于支付宝的返回信息,微信返回信息更加清晰一下,不过没啥用,一会加密完都一个样子

格式化后:

{
"msg":"success",
"code":200,
"data":{
"appid":"自己申请的appId",
"noncestr":"jqEmamoTbMoi0hRP",
"package":"Sign=WXPay",
"partnerid":"150****351",
"prepayid":"wx21144021******fd37e2948041031",
"sign":"50E345DCF6900A*****10126E7424",
"timestamp":"1529563221"
},
"status":"0"
}

拿到返回参数,微信支付方法

 /*微信支付测试OK*/
private void testWxPay(final String key, final String value) {
StringRequest stringRequest = new StringRequest(Request.Method.POST, NetWorkUrl.WXPAY, new Response.Listener<String>() {
@RequiresApi(api = Build.VERSION_CODES.M)
@Override
public void onResponse(String s) {
Log.e("GoPayOrderActivity", "-------getJson2-------" + s.toString()); /*判断code*/
String code = (JSONObject.parseObject(s.toString()).getString("code"));
if (code.equals("200")) {
String jsonObject = JSONObject.parseObject(s.toString()).getString("data");
String appId = JSONObject.parseObject(jsonObject).getString("appid");
String sign = JSONObject.parseObject(jsonObject).getString("sign");
String packageWx = JSONObject.parseObject(jsonObject).getString("package");
String partnerid = JSONObject.parseObject(jsonObject).getString("partnerid");
String prepayid = JSONObject.parseObject(jsonObject).getString("prepayid");
String noncestr = JSONObject.parseObject(jsonObject).getString("noncestr");
String timestamp = JSONObject.parseObject(jsonObject).getString("timestamp");
Log.e("GoPayOrderActivity", "onResponse: appId" + appId);
Log.e("GoPayOrderActivity", "onResponse: sign" + sign);
Log.e("GoPayOrderActivity", "onResponse: package" + packageWx);
Log.e("GoPayOrderActivity", "onResponse: partnerid" + partnerid);
Log.e("GoPayOrderActivity", "onResponse: prepayid" + prepayid);
Log.e("GoPayOrderActivity", "onResponse: noncestr" + noncestr);
Log.e("GoPayOrderActivity", "onResponse: timestamp" + timestamp);
api = WXAPIFactory.createWXAPI(GoPayOrderActivity.this, appId); PayReq req = new PayReq();
//req.appId = "wxf8b4f85f3a794e77"; // 测试用appId
//req的参数接受可以拿取order对象的数据
req.appId = appId;
req.partnerId = partnerid;
req.prepayId = prepayid;
req.nonceStr = noncestr;
req.timeStamp = timestamp;
req.packageValue = packageWx;
req.sign = sign;
req.extData = "app data"; // optional
// 在支付之前,如果应用没有注册到微信,应该先调用IWXMsg.registerApp将应用注册到微信
api.sendReq(req);
}
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError volleyError) { }
}) {
@Override
public Map<String, String> getParams() throws AuthFailureError {
Log.e("GoPayOrderActivity", "getParams:-----------------> " + userEntity.getPhone()); Map<String, String> map = new HashMap<String, String>();
map.put("account", userEntity.getPhone());
map.put(key, value);
// map.put("productId", "1");
// map.put("productId", "1");
map.put("token", userEntity.getToken());
return map;
} @Override
public Map<String, String> getHeaders() throws AuthFailureError {
HashMap<String, String> headers = new HashMap<String, String>();
if (userEntity.getToken().equals("") && userEntity != null) {
headers.put("Authorization", userEntity.getToken());
}
return headers;
} };
/*设置请求一次*/
stringRequest.setRetryPolicy(
new DefaultRetryPolicy(
5000,//默认超时时间,应设置一个稍微大点儿的,例如本处的500000
DefaultRetryPolicy.DEFAULT_MAX_RETRIES,//默认最大尝试次数
DefaultRetryPolicy.DEFAULT_BACKOFF_MULT
)
);
AppApplication.getHttpQueues().add(stringRequest);/*请求数据*/
}

微信支付回调

WXPayEntryActivity.java

public class WXPayEntryActivity extends Activity implements IWXAPIEventHandler {

    private static final String TAG = "WXPayEntryActivity";

    private IWXAPI api;

    @Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.pay_result); api = WXAPIFactory.createWXAPI(this, Constants.APP_ID);
api.handleIntent(getIntent(), this);
} @Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
setIntent(intent);
api.handleIntent(intent, this);
} @Override
public void onReq(BaseReq req) {
} @Override
public void onResp(BaseResp resp) {
Log.d(TAG, "onPayFinish, errCode = " + resp.errCode);
if (resp.getType() == ConstantsAPI.COMMAND_PAY_BY_WX) {
AlertDialog.Builder builder = new AlertDialog.Builder(WXPayEntryActivity.this);
/*注释掉的可以成功*/
builder.setTitle(R.string.app_tip);
builder.setMessage(getString(R.string.pay_result_callback_msg, String.valueOf(resp.errCode)));
builder.show();
int code = resp.errCode;
switch (code) {
case 0:
MobclickAgent.onEvent(WXPayEntryActivity.this, "payment_success", "付款成功");
// finish();
// Toast.makeText(this, "支付成功", Toast.LENGTH_SHORT).show();
/*跳转我的会员页面*/
AppApplication.addActivity(WXPayEntryActivity.this);
Intent intent = new Intent(this, MyVipActivity.class);
startActivity(intent);
break;
case -1:
MobclickAgent.onEvent(WXPayEntryActivity.this, "payment_fali", "付款失败");
// 失败原因 可能的原因:签名错误、未注册APPID、项目设置APPID不正确、注册的APPID与设置的不匹配,其他异常等
Toast.makeText(this, "支付失败", Toast.LENGTH_SHORT).show();
finish();
break;
case -2:
Toast.makeText(this, "支付取消", Toast.LENGTH_SHORT).show();
finish();
break;
default:
Toast.makeText(this, "支付取消", Toast.LENGTH_SHORT).show();
finish();
break;
} } }
}

完成上述,微信支付也是可以完成的了,注意测试的时候要用Release包,测试包是调用不起来微信的

如果问题或建议请发送到我的邮箱:dingchao7323@qq.com

Android开发支付集成——微信集成的更多相关文章

  1. Android开发支付集成——支付宝集成

    微信支付传送门:https://www.cnblogs.com/dingxiansen/p/9209159.html 一.支付宝支付 1. 支付宝支付流程图 2. 集成前准备 去蚂蚁金服注册应用获取a ...

  2. Android开发——支付宝和微信支付快速接入流程

    一.Android快速实现支付宝支付 1.首先,我们需要前往支付宝开放平台,申请我们的支付功能:https://open.alipay.com/platform/home.htm 支付宝首页 这里 有 ...

  3. Salesforce 开发 | Salesforce与微信集成实操指南

    配置前须知 Salesforce通过试点对特定客户提供Lightning WeChat Messaging,该试点需要同意特定的条款.除非Salesforce宣布WeChat Messaging全面可 ...

  4. odoo开发笔记--与微信集成

    odoo 与微信 https://github.com/JoneXiong/oejia_wx

  5. Android开发之仿微信显示更多文字的View

    最近开发需求中要模仿微信朋友圈文章的展开收起功能,网上找了找,发现都有问题,于是乎自己在前辈的基础上进行了一定量的修改,下边将源码贴出来供大家参考:1.主Activity布局文件就不粘贴了,很简单,就 ...

  6. android开发--布局三(微信布局)

    微信主界面 我们布局应该从局来看,如上图,我们可以分为三个大的LinearLayout,再从LinearLayout嵌套其它布局,从而做出界面 文件 主界面代码: <LinearLayout x ...

  7. Android开发 sharesdk分享微信/朋友圈的时候只显示文字,不显示链接

    问题:分享的时候只将分享的content分享出去了,连标题及链接都没有分享出去. 原因:没有配置image导致. 解决办法: 在  showShare 方法里面添加配置: if(ImageUrlOrP ...

  8. 五步搞定Android开发环境部署

    引言   在windows安装Android的开发环境不简单也说不上算复杂,本文写给第一次想在自己Windows上建立Android开发环境投入 Android浪潮的朋友们,为了确保大家能顺利完成开发 ...

  9. Android开发学习——搭建开发环境

    在学校开课学习了android的一些简单的UI组件,布局,四大组件学习了2个,数据存储及网络通信,都是一些简单的概念,入门而已.许多东西需要自己去学习. 学习一下 Android开发环境的搭建,两种方 ...

随机推荐

  1. 解决vs2019中暂时无法为.net core WinForms使用 Designer 的临时方法

    目录 解决vs2019中暂时无法为.net core WinForms使用 Designer 的临时方法 安装 vs 2019 professional/enterprise版本 在vs的设置里,勾选 ...

  2. asp.net core系列 28 EF模型配置(字段,构造函数,拥有实体类型)

    一. 支持字段 EF允许读取或写入字段而不是一个属性.在使用实体类时,用面向对象的封装来限制或增强应用程序代码对数据访问的语义时,这可能很有用.无法使用数据注释配置.除了约定,还可以使用Fluent ...

  3. Eclipse4JavaEE安装SpringBoot

    第一步:下载SpringBoot SpringBoot官网下载链接 第二步:在Eclipse里进行安装 打开Eclipse,菜单栏Help ->Install New Software,进入下图 ...

  4. Android Service与Activity的交互

    Android中有时候需要在Service中改变Activity的UI,或者在Activity中修改Service中的数值.首先必须使用与Activity绑定的Service,有三种方式可以实现.第一 ...

  5. lombok的安装

    Lombok简介 Lombok是一个可以通过简单的注解形式来帮助我们简化消除一些必须有但显得很臃肿的Java代码的工具,通过使用对应的注解,可以在编译源码的时候生成对应的方法.官方地址:https:/ ...

  6. V8引擎的垃圾回收策略

    V8 的垃圾回收策略主要基于分代式垃圾回收机制.所谓分代式,就是将内存空间分为新生代和老生代两种,然后采用不同的回收算法进行回收. 新生代空间 新生代空间中的对象为存活时间较短的对象,大多数的对象被分 ...

  7. 将HTML字符转换为DOM节点并动态添加到文档中

    将HTML字符转换为DOM节点并动态添加到文档中 将字符串动态转换为DOM节点,在开发中经常遇到,尤其在模板引擎中更是不可或缺的技术. 字符串转换为DOM节点本身并不难,本篇文章主要涉及两个主题: 1 ...

  8. 微信小程序小结02-- 完整的demo

    小程序确实方便,在移动端方便小个体宣传,不需要服务器和域名,还有客服功能.按朋友的意思,做了一次调整,分成了首页.预约和我的三个页面. 下面说下遇到的几个问题. 01.客服功能 不得不说这个一条龙服务 ...

  9. EF实体实现链接字符串加密

    1.加密解密方法 using System;using System.Security.Cryptography; using System.Text;namespace DBUtility{ /// ...

  10. .NET Core微服务之基于Consul实现服务治理(续)

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 上一篇发布之后,很多人点赞和评论,不胜惶恐,这一篇把上一篇没有弄到的东西补一下,也算是给各位前来询问的朋友的一些回复吧. 一.Consul ...