A. 安卓手机怎么开启微信支付
1、在微信中或许您找不到微信支付的通道,没有任何可绑定银行卡的入口。其实,当您第一次进行支付时会提供给您绑定银行卡的入口,绑定后,就可以在其他公众帐号中完成微信支付。
2、现在我们来完成首次支付操作以绑定银行卡。在微信主界面切换到“我”界面,然后点击列表项中的“表情商店”选项,如图所示。
3、在新界面中选择一套表情进行购买操作,如“饭团和他的朋友们”,点击右边的价格按钮购买此套表情(不是真的购买,只是为了演示给大家如何绑定银行卡)。
4、点击“付款”按钮开始使用微信支付,支付时需要绑定银行卡。请输入持卡人银行卡号码,然后点击“下一步”按钮。
5、输入银行卡类型、银行预留持卡人姓名、身份证、手机号等个人信息。稍后会收到短信验证码,微信会自动获取短信验证码,点击“下一步”按钮即可。
6、下面的操作需要设置微信安全支付6位数字密码,需要用户自行执行,就不累述了,相信您已经知道如何绑定银行卡了!记得不要执行到最后,不然真的购买6元表情了。
7、绑定银行卡快捷支付后,下次在公众帐号、扫二维码、App中进行微信支付时就不需要再次绑定,只需输入支付密码即可完成支付。您可以在“我 -> 个人头像 -> 个人信息 -> 我的银行卡”下管理已绑定的银行卡或添加新的银行卡。
B. 微信支付不成功,闪一下窗口就提示交易取消了返回到首页
一、文件损坏造成微信闪退遇到这个问题反复重新安装微信是解决不了问题,需要先清空微信数据然后重新安装才可以。按菜单键,找到系统设置->应用程序(部分手机名称不一样),在列表中找到微信图标,点击弹出程序信息界面,点击清空数据即可。
二、SD卡空间不足造成闪退很多游戏或软件在SD卡空间不足的情况下会出现闪退。按菜单键,找到系统设置->存储(部分手机名称不一样),如果可用空间小于1M时,就应该删除或清理一些应用。
C. android微信支付demo怎么开通零钱支付
准备:
1,导入微信的libs包libammsdk.jar;
2,测试时使用weixinDemo中的debug_keystore;
3,需要注意应用要通过审核,并且几个Key值正确,一下为微信支付Demo中的值:
?
1
2
3
4
5
6
7
8
9
10
//微信公众平台id;
private
String app_wx_appid=WxConstants.app_wx_appid;
//微信开放平台和商户约定的密钥
private
String app_wx_secret_key="";
//微信公众平台商户模块和商户约定的密钥
private
String app_wx_parent_key="";
//微信公众平台商户模块和商户约定的支付密钥
private
String app_wx_pay_key="";
//
商家向财付通申请的商家id */
private
String app_tx_parent_key = "1900000109";
==========================================
根据微信支付Demo,微信支付分为三步:
第一步,获取accessToken,accessToken值第二步要用;
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private
class
GetAccessTokenTask extends
AsyncTask<void,
void,=""
wxgetaccesstokenresult="">
{
@Override
protected
WxGetAccessTokenResult doInBackground(Void... params) {
WxGetAccessTokenResult
result = getAccessToken();
return
result;
}
@Override
protected
void
onPostExecute(WxGetAccessTokenResult result) {
if
(result.localRetCode == WxLocalRetCode.ERR_OK) {
GetPrepayIdTask
getPrepayId = new
GetPrepayIdTask();
getPrepayId.execute(result);
}
}}</void,>
解析服务器响应
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private
WxGetAccessTokenResult getAccessToken() {
WxGetAccessTokenResult
result = new
WxGetAccessTokenResult();
String
url = String.format(api_get_access_token,
"client_credential",
app_wx_appid,
app_wx_secret_key);
byte[]
buf = WeixinUtil.httpGet(url);
if
(buf == null
|| buf.length == 0)
{
result.localRetCode
= WxLocalRetCode.ERR_HTTP;
return
result;
}
String
content = new
String(buf);
result.parseFrom(content);
return
result;
}
第二步,根据第一步的accesstoken值,将 组装的商品参数Post给微信服务器
?
1
2
3
4
5
6
7
8
9
10
11
12
13
private
class
GetPrepayIdTask extends
AsyncTask<wxgetaccesstokenresult, void,=""
wxgetprepayidresult="">
{
@Override
protected
WxGetPrepayIdResult doInBackground(WxGetAccessTokenResult... params) {
WxGetPrepayIdResult
result = getPrepayId(params[0]);
return
result;
}
@Override
protected
void
onPostExecute(WxGetPrepayIdResult result) {
if
(result.localRetCode == WxLocalRetCode.ERR_OK) {
sendPayReq(result);
}
}
}</wxgetaccesstokenresult,>
组装参数
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
private
WxGetPrepayIdResult getPrepayId(WxGetAccessTokenResult accessTokenResult) {
String
url = String.format(api_get_preorder_id,accessTokenResult.accessToken);
String
entity = appSign.getWxPrepayAppSign();WxGetPrepayIdResult
result = new
WxGetPrepayIdResult();byte[]
buf = WeixinUtil.httpPost(url, entity);
if
(buf == null
|| buf.length == 0)
{
result.localRetCode
= WxLocalRetCode.ERR_HTTP;
return
result;
}String
content = new
String(buf);
result.parseFrom(content);
return
result;
}
Post给服务器
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<span
style="white-space:pre">
</span>private
void
sendPayReq(WxGetPrepayIdResult result) {PayReq
req = new
PayReq();
req.appId
= app_wx_appid;
req.partnerId
= app_tx_parent_key;
req.prepayId
= result.prepayId;
req.nonceStr
= appSign.getNoncestr();
req.timeStamp
= appSign.getTimestamp();
req.packageValue
= "Sign="
+ appSign.getPackageSign();List<namevaluepair>
signParams = new
LinkedList<namevaluepair>();
signParams.add(new
BasicNameValuePair("appid",
req.appId));
signParams.add(new
BasicNameValuePair("appkey",
app_wx_pay_key));
signParams.add(new
BasicNameValuePair("noncestr",
req.nonceStr));
signParams.add(new
BasicNameValuePair("package",
req.packageValue));
signParams.add(new
BasicNameValuePair("partnerid",
req.partnerId));
signParams.add(new
BasicNameValuePair("prepayid",
req.prepayId));
signParams.add(new
BasicNameValuePair("timestamp",
req.timeStamp));
req.sign
= WeixinUtil.genSign(signParams);wxRequest.sendReq(req);
}</namevaluepair></namevaluepair>
?
1
?
1
第三步:在项目下新建一个包wxapi,建立一个类名为WXPayEntryActivity作为接受微信的支付结果,不过最终结果以服务器的返回为准notify_url:
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
package
net.sourceforge.simcpux.wxapi;
public
class
WXPayEntryActivity extends
Activity implements
IWXAPIEventHandler{<pre name="code"
class="java"><span
style="white-space:pre">
</span>@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(this);
builder.setTitle("支付结果");
builder.setMessage("支付结果"+String.valueOf(resp.errCode));
builder.show();
}
}</pre>}
<p></p>
<pre
class="brush:java;"></pre>
==========================================
<p></p>
<p>暂时没想到其他想说的,先看个效果</p>
<p>1,包结构,需要注意的就是接收微信返回结果的那个类名;</p>
<p><img
src="http://www.2cto.com/uploadfile/Collfiles/20140901/201409010901522.png"
alt="\"
style="display:
inline; width: 239px; height: 238px;"></p>
<p>2,组装数据,规则在文档中有说明<㖞�"http://www.2cto.com/kf/ware/vc/"
target="_blank"
class="keylink">vcD4KPHByZSBjbGFzcz0="brush:java;">//package_
字段生成方法
//package生成方法:
//A)对所有传入参数按照字段名的ASCII
码从小到大排序(字典序)后,使用URL 键值对的格式(即key1=value1&key2=value2…)拼接成字符串string1;
//B)
在string1 最后拼接上key=partnerKey 得到stringSignTemp 字符串, 并对 stringSignTemp进行md5 运算,再将得到的字符串所有字符转换为大写,得到sign值signValue。
//C)对string1
中的所有键值对中的value 进行urlencode 转码,按照a 步骤重新拼接成字符串,得到string2。对于js 前端程序,一定要使用函数encodeURIComponent 进行urlencode编码(注意!进行urlencode时要将空格转化为%20而不是+)。
//D)将sign=signValue
拼接到string1 后面得到最终的package 字符串。//app_signature生成方法:
//A)参与签名的字段包括:appid、appkey、noncestr、package、timestamp以及
traceid
//B)对所有待签名参数按照字段名的ASCII
码从小到大排序(字典序)后,使用URL 键值对的格式(即key1=value1&key2=value2…)拼接成字符串string1。 注意:所有参数名均为小写字符
//C)对string1
作签名算法,字段名和字段值都采用原始值,不进行URL 转义。具体签名算法为SHA1</p>
\
D. Android接入微信支付之-1错误码踩坑之旅
微信支付文档写的真的棒啊!少林功夫真的好啊!
永远猜不到-1错误码是啥问题。
顺便介绍下签名文件:
debug.keystore:
在Android Stio中系统默认内置了一个签名文件debug.keystore,用于我们在debug下的默认App签名。
release.keystore:
由用户自己生成
获取签名信息:
打开电脑终端,输入以下命令:
可以看到签名信息的MD5、sha1、sha256值。微信支付需要的就是MD5的去冒号小写版。例如本机:。
也可以在Android Studio底部tools window中的terminal中敲命令
清单文件AndroidManifest.xml中WXPayEntryActivity的声明配置:
errCode -1:签名错误,所说的签名就是第三个sign。当然还有APPID未通过,和APPID注册的和返回的不一样,这个是“微信开放平台”里的东西。
E. 微信支付开发 返回-1
如果是APP使用正常中,突然返回-1,可能是被微信风控了,这个很难申诉,而且这个找客服是查不到的。微信没有具体返回码的错误都是返回-1。
F. android怎么实现微信支付
APP想要接入微信支付,请先获取开发平台帐号,并且获取开发者资质认证。这资质认证可在开发平台申请,并提交相关资料。认证通过后,提交APP以获取AppID才能继续申请。
随后登录开放平台,在管理中心中选择所需的APP,点击右侧的申请开通,提交所需材料。审核通过后,可通过发送到开户邮箱中的商户账号和密码登录商户平台进行验证,最后在线签署协议,并根据附件中的开发文档启动设计和开发。
G. Unity-Android集成微信支付出现返回-1问题
前段时间出去玩了一段时间,回公司得知一个惊天消息——微信支付出问题了!!!这个问题比较奇怪,说是部分机型可以支付成功,部分机型如小米、三星无法调起支付,返回-1。
众所周知返回-1的话代表了各种各样的错误(坑),所以只好从头开始排查,首先排查 WXPayEntryActivity.java 这个文件是否放在了 .wxapi包 下,及 manifest里的注册是否为.wxapi.WXPayEntryActivity ,确定无误后检查后台返回的参数是否有误
至此如果都正确,可以开始着手检查在后台里的参数设置是否正确
这里需要注意的是应用签名和应用包名,因为出问题的包不是由我打包的,我怀疑问题在于应用签名对不上,最后发现果然如此。打包的同事使用了另一个keystore文件进行打包,导致应用签名与后台填写的不一致,于是重新生成了签名更新后台设置,问题解决。
至于为什么部分机型可以正常支付,而部分机型无法调起,我参照有些coder遇到的问题“微信支付只能成功调起一次”
因为成功支付的机型为公司测试机,而不成功的机型是用户机,猜测因为公司测试机里曾经调试过微信支付,有正确的包名和签名的缓存,微信在调起时直接读取缓存值,验证正确后直接调起,而当缓存值出错时微信才会再次去读取新的包名和签名重新验证,因此出现了部分机型可支付的问题。也因为这个原因, 修改完签名后再次调试,第一次返回的还是-1,但再次点击就可以成功调起,此后也没有再返回-1。 个人猜测,如有错误欢迎指出讨论。
微信支付的坑实在是太多了,还有OC编写的iOS的IAP也有很多藏起来的坑,一直想把Unity内调用Java集成的微信、支付宝支付,使用OC集成的iOS内购详细过程写上来,但是一直犯懒。。这段时间一定要写好,给自己做个记录,也给大家作为一个参考。
H. android 微信支付问题,老是返回-1
你好,这个需要对接的,首先需要开通微信支付功能,然后对接到微信支付平台就可以了。 亲,我的回答你满意吗?满意的话给个采纳吧!或者你可以选择继续向我追问哦。
I. android开发微信支付集成客户端二次签名怎么做
1.客户端代码得到用户购买的商品信息,将之传给自己公司app服务器,参数包含但不限于以下:
params.put("appid", appID);// 微信appid,选择性上传,服务器写死亦可
params.put("money", money);// 支付金额,单位:分
params.put("name", goodsName);// 商品名称
params.put("currencytype", "CNY");// 支付币种,只能填CNY,代表人民币12341234
备注:以上是参数字段是我们公司服务器定义,给服务器用以获取预支付订单号prePayId用。
备注2:详细字段请参考:https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=9_1
2.app服务器调用微信“统一下单”接口,得到prePayId订单号并返回prePayId给手机客户端;
3.手机客户端使用prePayId及商品信息调起微信客户端进行支付;
3.1用户操作:输入密码进行支付;返回键取消支付;网络无连接支付失败等;
4.微信客户端回调支付结果给咱们的APP客户端;
5.微信服务器异步通知咱们公司app服务器支付结果(服务器的工作,与客户端无关)
这个其实很简单的,demo文档写得很详细,直接上代码吧:
/**
* 获取sign签名
*
* @return
*/
private String genPayReq() {
// 获取参数的值
PayReq request = new PayReq();
request.appId = ConstantsMember.APP_ID;
request.partnerId = ConstantsMember.MCHID;
request.prepayId = mPrepayId;
request.packageValue = "Sign=WXPay";
request.nonceStr = DataUtil.getGuid();
request.timeStamp = DataUtil.getTimeStamp();
// 把参数的值传进去SortedMap集合里面
SortedMap<Object, Object> parameters = new TreeMap<Object, Object>();
// {appid=wx34df375d7dae8c90, noncestr=,
// package=Sign=WXPay, partnerid=1349967601,
// prepayid=, timestamp=1468031760}
parameters.put("appid", request.appId);
parameters.put("noncestr", request.nonceStr);
parameters.put("package", request.packageValue);
parameters.put("partnerid", request.partnerId);
parameters.put("prepayid", request.prepayId);
parameters.put("timestamp", request.timeStamp);
String characterEncoding = "UTF-8";
String mySign = createSign(characterEncoding, parameters);
System.out.println("我的签名是:" + mySign);
return mySign;
}
/**
* 微信支付签名算法sign
*
* @param characterEncoding
* @param parameters
* @return
*/
public static String createSign(String characterEncoding,
SortedMap<Object, Object> parameters) {
StringBuffer sb = new StringBuffer();
Set es = parameters.entrySet();// 所有参与传参的参数按照accsii排序(升序)
Iterator it = es.iterator();
while (it.hasNext()) {
@SuppressWarnings("rawtypes")
Map.Entry entry = (Map.Entry) it.next();
String k = (String) entry.getKey();
Object v = entry.getValue();
if (null != v && !"".equals(v) && !"sign".equals(k)
&& !"key".equals(k)) {
sb.append(k + "=" + v + "&");
}
}
sb.append("key=" + ConstantsMember.KEY); //KEY是商户秘钥
String sign = MD5Util.MD5Encode(sb.toString(), characterEncoding)
.toUpperCase();
return sign; //
//
}