这个修改微信支付密码码按照这改的,怎么还是不行?

微信支付密码忘了,原来绑定的银行卡已停用,怎样找回密码?
全部答案(共3个回答)
1刷机可能是个可行的方法 2 一下办法可以尝试 :这个方法比较简单按紧急电话键入####按下拨号键后迅速按下电话上方的锁键试试看 还有一个比较复杂的如果不行的话...
进去我的银行卡界面,右上角点开,有个支付密码,进去可以修改。
微信钱包支付密码,是指你绑定银行卡时设置的支付密码。设置一个安全额支付密码就可以了的
微信支付密码要你自己设置才有的 就在我-我的账户-银行卡里面 要想绑定银行卡的,并不是你银行卡的密码
在“我”的个人信息中打开“我的银行卡选择“支付密码
答: 手机上问答,老是震动很烦人,又不知道怎么调?怎么不要以取消震动呢。
答: 美国苹果公司的新款手机,全触屏的智能机,在中国卖的很贵。
答: 手机购买还是找正规卖家
天猫等网站
答: 可能被设置了禁言你IP接入吧
大家还关注
确定举报此问题
举报原因(必选):
广告或垃圾信息
激进时政或意识形态话题
不雅词句或人身攻击
侵犯他人隐私
其它违法和不良信息
报告,这不是个问题
报告原因(必选):
这不是个问题
这个问题分类似乎错了
这个不是我熟悉的地区
相关问答:123456789101112131415君,已阅读到文档的结尾了呢~~
以微信支付为例,探讨移动支付的风险管控,贸易业务风险管控探讨,风险管控,安全风险分级管控,风险分级管控实施指南,安全风险分级管控制度,安全风险管控实施方案,风险辨识分级管控台账,安全风险管控,风险管控和隐患排查
扫扫二维码,随身浏览文档
手机或平板扫扫即可继续访问
以微信支付为例,探讨移动支付的风险管控
举报该文档为侵权文档。
举报该文档含有违规或不良信息。
反馈该文档无法正常浏览。
举报该文档为重复文档。
推荐理由:
将文档分享至:
分享完整地址
文档地址:
粘贴到BBS或博客
flash地址:
支持嵌入FLASH地址的网站使用
html代码:
&embed src='/DocinViewer--144.swf' width='100%' height='600' type=application/x-shockwave-flash ALLOWFULLSCREEN='true' ALLOWSCRIPTACCESS='always'&&/embed&
450px*300px480px*400px650px*490px
支持嵌入HTML代码的网站使用
您的内容已经提交成功
您所提交的内容需要审核后才能发布,请您等待!
3秒自动关闭窗口62765人阅读
Android开发(1048)
首先我们先看一个android微信支付时遇到的一个错误提示:onPayFinish, errCode = -1&当你参数签名都没有问题的时候,出现这个提示,请按照如下操作:在你的项目测试android微信的组件(微信分享、微信支付等)的时候,一定要用你自己的keystore签名出来测试,如果用debug.keystore肯定是不成功的!1,在微信开放平台申请app_id,app_key我就不在这里叙述了,稍后我会把开发文档一并上传的,你也可以去微信开放平台自行查看(差不多一个周才会通过审核)&2,下面我就来说一说微信支付开发时需要注意的地方:2.1 首先来看一下,微信支付的架构和流程图&&&3.2 再来看一下成功调起微信支付的界面&&3下面开始讲解配置工程3.1 这里必须要有wxapi这个包名,同时必须有WXPayEntryActivity这个类名,否则无法调起微信支付,(开发文档没有标注,废了好大周章)&3.2 支付成功通知:在WXPayEntryActivity的OnResp中处理,不能以微信返回的通知界面为准(我遇到的情况,网络不稳定的时候,微信返回界面提示支付失败,但是收到微信通知其实已经支付成功了),必须要去自己的服务器查询支付状态,这里微信建议用轮循机制去查询(最好听微信劝,O(∩_∩)O哈哈~) @Override
public void onResp(BaseResp resp) {
Log.d(TAG, &onPayFinish, errCode = & + resp.errCode);
if (resp.getType() == MAND_PAY_BY_WX) {
AlertDialog.Builder builder = new AlertDialog.Builder(this);
builder.setTitle(R.string.app_tip);
builder.setMessage(getString(R.string.pay_result_callback_msg, resp.errStr +&;code=& + String.valueOf(resp.errCode)));
builder.show();
}3.3 生成prepay_id,在服务器完成,由服务器去跟微信服务器交互,客户端不需要参与 /**
* 获取预支付订单号:
* prepay_id(服务器完成)!!!
* 注意:如果服务端开发文档跟客户端demo里的参数不一样,以demo里的参数为准,
* 否则服务器传过来的参数无法调起微信支付!!!
private String genProductArgs() {
StringBuffer xml = new StringBuffer();
nonceStr = genNonceStr();
xml.append(&&/xml&&);
List&NameValuePair& packageParams = new LinkedList&NameValuePair&();
packageParams.add(new BasicNameValuePair(&appid&, Constants.APP_ID));
packageParams.add(new BasicNameValuePair(&body&, &APP pay test&));
/**这里用的是mach_id,跟sign签名时参数名不同,一定要注意*/
packageParams.add(new BasicNameValuePair(&mch_id&, Constants.MCH_ID));
packageParams.add(new BasicNameValuePair(&nonce_str&, nonceStr));
packageParams.add(new BasicNameValuePair(&notify_url&, &http://121.40.35.3/test&));
packageParams.add(new BasicNameValuePair(&out_trade_no&,genOutTradNo()));
packageParams.add(new BasicNameValuePair(&spbill_create_ip&,&127.0.0.1&));
packageParams.add(new BasicNameValuePair(&total_fee&, &1&));
packageParams.add(new BasicNameValuePair(&trade_type&, &APP&));
String sign = genPackageSign(packageParams);
packageParams.add(new BasicNameValuePair(&sign&, sign));
String xmlstring =toXml(packageParams);
} catch (Exception e) {
Log.e(TAG, &genProductArgs fail, ex = & + e.getMessage());
}3.4 获取二次签名signprivate void genPayReq() {
req.appId = Constants.APP_ID;
req.partnerId = Constants.MCH_ID;
req.prepayId = resultunifiedorder.get(&prepay_id&);
req.packageValue = &prepay_id=&+resultunifiedorder.get(&prepay_id&);
req.packageValue = &Sign=WXPay&;
req.nonceStr = genNonceStr();
req.timeStamp = String.valueOf(genTimeStamp());
List&NameValuePair& signParams = new LinkedList&NameValuePair&();
signParams.add(new BasicNameValuePair(&appid&, req.appId));
signParams.add(new BasicNameValuePair(&noncestr&, req.nonceStr));
* 这里的package参数值必须是Sign=WXPay,否则IOS端调不起微信支付,
* (参数值是&prepay_id=&+resultunifiedorder.get(&prepay_id&)的时候Android可以,IOS不可以)
signParams.add(new BasicNameValuePair(&package&, req.packageValue));
/**注意二次签名这里不再是mch_id,变成了*/
signParams.add(new BasicNameValuePair(&partnerid&, req.partnerId));
signParams.add(new BasicNameValuePair(&prepayid&, req.prepayId));
signParams.add(new BasicNameValuePair(&timestamp&, req.timeStamp));
req.sign = genAppSign(signParams);
sb.append(&sign\n&+req.sign+&\n\n&);
show.setText(sb.toString());
Log.e(&orion&, signParams.toString());
}3.5 起调微信支付private void sendPayReq() {
msgApi.registerApp(Constants.APP_ID);
msgApi.sendReq(req);
}3.6 配置Manifest.xml,权限什么的按照文档的配置就行了 &activity
android:name=&.PayActivity&
android:label=&@string/app_name&
android:exported=&true&
android:launchMode=&singleTop&&
&intent-filter&
&action android:name=&android.intent.action.MAIN& /&
&category android:name=&android.intent.category.LAUNCHER& /&
&/intent-filter&
&!--这个intent-filter不要忘了--&
&intent-filter&
&action android:name=&android.intent.action.VIEW&/&
&category android:name=&android.intent.category.DEFAULT&/&
&data android:scheme=&wxd930ea5d5a258f4f&/&
&/intent-filter&
&/activity&4,支付通知接口和退款接口按照开发文档即可,这里不再赘述5, 在你的项目测试微信支付的时候,一定要用你自己的keystore签名出来测试,如果用debug.keystore肯定是不成功的,切记,切记,不要闹乌龙!!!好了,就写这么多吧,以此文来祭奠我和同事被腾讯坑死的那几天,如果有不懂的童鞋可以给我留言,或者QQ:联系我,大家可以去这个地址下载微信支付v3.0版本的开发文档和demo,以及一个成功的微信支付demo app,轮询事件大家可以参考我的下一篇blog,从别人那里转来的,写的挺详细的&补充问题:微信支付v3 body中文无法支付问题String nonceStr = genNonceStr();xml.append(&&/xml&&);// Yuebai Steam Car Wash Service&List&NameValuePair& packageParams = new LinkedList&NameValuePair&();packageParams.add(new BasicNameValuePair(&appid&, Constants.APP_ID));packageParams.add(new BasicNameValuePair(&body&, &月白洗车&));// 这个一改就无法支付packageParams.add(new BasicNameValuePair(&mch_id&, Constants.MCH_ID));packageParams.add(new BasicNameValuePair(&nonce_str&, nonceStr));packageParams.add(new BasicNameValuePair(&notify_url&, HttpConstant.wxapi));packageParams.add(new BasicNameValuePair(&out_trade_no&, orderid));packageParams.add(new BasicNameValuePair(&spbill_create_ip&, &127.0.0.1&));int a = (int) (Integer.parseInt(m) * 100);packageParams.add(new BasicNameValuePair(&total_fee&, a + &&));packageParams.add(new BasicNameValuePair(&trade_type&, &APP&));String sign = genPackageSign(packageParams);packageParams.add(new BasicNameValuePair(&sign&, sign));String xmlstring = toXml(packageParams);&return&new String(xmlstring.toString().getBytes(), &ISO8859-1&);//这句加上就可以了吧xml转码下&另外说明的是,如果想增加参数,请先看看下面的内容。签名算法签名生成的通用步骤如下:第一步,设所有发送或者接收到的数据为集合M,将集合M内非空参数值的参数按照参数名ASCII码从小到大排序(字典序),使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串stringA。特别注意以下重要规则:◆ 参数名ASCII码从小到大排序(字典序);◆ 如果参数的值为空不参与签名;◆ 参数名区分大小写;◆ 验证调用返回或微信主动通知签名时,传送的sign参数不参与签名,将生成的签名与该sign值作校验。◆ 微信接口可能增加字段,验证签名时必须支持增加的扩展字段第二步,在stringA最后拼接上key得到stringSignTemp字符串,并对stringSignTemp进行MD5运算,再将得到的字符串所有字符转换为大写,得到sign值signValue。key设置路径:微信商户平台(pay.)--&账户设置--&API安全--&密钥设置举例:假设传送的参数如下:appid: wxd930ea5d5a258f4fmch_id: device_info: 1000body: testnonce_str: ibuaiVcKdpRxkhJA第一步:对参数按照key=value的格式,并按照参数名ASCII字典序排序如下:stringA=&appid=wxd930ea5d5a258f4f&body=test&device_info=1000&mch_id=&nonce_str=ibuaiVcKdpRxkhJA&;第二步:拼接API密钥:stringSignTemp=&stringA&key=c09247ec02edce69f6a2d&sign=MD5(stringSignTemp).toUpperCase()=&9A0AA9CF3B7&最终得到最终发送的数据:&xml&&appid&wxd930ea5d5a258f4f&/appid&&mch_id&&/mch_id&&device_info&1000&device_info&&body&test&/body&&nonce_str&ibuaiVcKdpRxkhJA&/nonce_str&&sign&9A0AA9CF3B7&/sign&&xml&微信提供相关接口在线签名验证工具:。&&所以,如果我们增加两个参数:attach、device_info就必须根据参数名ASCII字典序增加,如下图位置。如果将参数attach放在trade_type之后肯定就会报签名错误。List&NameValuePair& packageParams = new LinkedList&NameValuePair&();
packageParams.add(new BasicNameValuePair(&appid&, Constant.weixin_appID));
packageParams.add(new BasicNameValuePair(&attach&, mOrderNo));
packageParams.add(new BasicNameValuePair(&body&, &订单-& + mOrderNo)); //商品描述
packageParams.add(new BasicNameValuePair(&device_info&, &ANDROID&));
packageParams.add(new BasicNameValuePair(&mch_id&, Constant.MCH_ID));
packageParams.add(new BasicNameValuePair(&nonce_str&, nonceStr));
packageParams.add(new BasicNameValuePair(&notify_url&, &/wechat_notify.php&));
packageParams.add(new BasicNameValuePair(&out_trade_no&,genOutTradNo()));
packageParams.add(new BasicNameValuePair(&spbill_create_ip&, &127.0.0.1&));
packageParams.add(new BasicNameValuePair(&total_fee&, String.valueOf((int) (mMoney * 100))));//商品金额,以分为单位
packageParams.add(new BasicNameValuePair(&trade_type&, &APP&));&最后再为大家分享点干货。在计算订单总价的时候,有时会出现***.99998的现象,这个是浮点数计算出现的问题,得需要&BigDecimal解决高精度计算。下面是我的解决方法,大家有更好的可以分享下。/*
* 总订单的价格(不包含运费)
public double calculatingTotalPriceNoFreight() {
double total = 0.00;
for (ShopCartItem cartItem : getDataList()) {
double orderPrice = calculatingOrderPrice(cartItem);
total += orderP
//double值保留 2 位小数,使用银行家舍入法
return MathUtil.round(total, 2, BigDecimal.ROUND_HALF_EVEN) ;
}MathUtil.javapackage com.haier.cabinet.customer.
import java.math.BigD
public class MathUtil {
* 对double数据进行取精度.
* @param value
double数据.
* @param scale
精度位数(保留的小数位数).
* @param roundingMode
精度取值方式.
* @return 精度计算后的数据.
public static double round(double value, int scale,
int roundingMode) {
BigDecimal bd = new BigDecimal(value);
bd = bd.setScale(scale, roundingMode);
double d = bd.doubleValue();
* double 相加
* @param d1
* @param d2
public static double sum(double d1,double d2){
BigDecimal bd1 = new BigDecimal(Double.toString(d1));
BigDecimal bd2 = new BigDecimal(Double.toString(d2));
return bd1.add(bd2).doubleValue();
* double 相减
* @param d1
* @param d2
public static double sub(double d1,double d2){
BigDecimal bd1 = new BigDecimal(Double.toString(d1));
BigDecimal bd2 = new BigDecimal(Double.toString(d2));
return bd1.subtract(bd2).doubleValue();
* double 乘法
* @param d1
* @param d2
public static double mul(double d1,double d2){
BigDecimal bd1 = new BigDecimal(Double.toString(d1));
BigDecimal bd2 = new BigDecimal(Double.toString(d2));
return bd1.multiply(bd2).doubleValue();
* double 乘法
* @param n
* @param d2
public static double mul(int n,double d2){
BigDecimal bd1 = new BigDecimal(Integer.toString(n));
BigDecimal bd2 = new BigDecimal(Double.toString(d2));
return bd1.multiply(bd2).doubleValue();
* double 除法
* @param d1
* @param d2
* @param scale 四舍五入 小数点位数
public static double div(double d1,double d2,int scale){
当然在此之前,你要判断分母是否为0,
为0你可以根据实际需求做相应的处理
BigDecimal bd1 = new BigDecimal(Double.toString(d1));
BigDecimal bd2 = new BigDecimal(Double.toString(d2));
return bd1.divide
(bd2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
* 将double类型数据转为字符串
* @param d
public static String double2String(double d){
BigDecimal bg = new BigDecimal(d * 100);
double doubleValue = bg.setScale(2,BigDecimal.ROUND_HALF_UP).doubleValue();
String.valueOf((int)doubleValue);
补充:微信官网上对于支付返回-1是&&我犯的错和他描述的都不一样。1、新建一个微信支付demo的工程,将包名和签名上传给微信。并保证apk是通过keystore方式打了签名的,用官方的工具做签名。2、将官方的demo示例参考一下,权限部分:&!-- WeixinPay --&
&uses-permission android:name=&android.permission.INTERNET& /&
&uses-permission android:name=&android.permission.MODIFY_AUDIO_SETTINGS&/&
&uses-permission android:name=&android.permission.WRITE_EXTERNAL_STORAGE&
&activity android:name=&.MainActivity&
android:exported=&true&&
&intent-filter&
&action android:name=&android.intent.action.MAIN& /&
&category android:name=&android.intent.category.LAUNCHER& /&
&/intent-filter&
&intent-filter&
&action android:name=&android.intent.action.VIEW&/&
&category android:name=&android.intent.category.DEFAULT&/&
&data android:scheme=&wxd31ef1f4dd******&/&
&/intent-filter&
&/activity&
&activity android:name=&.AlipayH5Activity&&&/activity&
&activity android:name=&com.*******.paydemo.wxapi.WXPayEntryActivity&
android:exported=&true&
android:launchMode=&singleTop&&
&/activity&&/span&Activity部分的逻辑代码:IWXAPI api = WXAPIFactory.createWXAPI(MainActivity.this, null);//通过工厂创建对象
api.registerApp(ConstUtil.APP_ID);
PayReq request = new PayReq();
request.appId = ConstUtil.APP_ID;
request.partnerId = ConstUtil.PARTNER_ID;
request.prepayId = wxPrepayEntity.getPrepay_id();
request.nonceStr = wxPrepayEntity.getReq_noncestr();
request.timeStamp = wxPrepayEntity.getReq_timestamp();
request.packageValue = wxPrepayEntity.getReq_package();
request.sign = wxPrepayEntity.getReq_sign();
request.extData = &app data&; // optional
// 在支付之前,如果应用没有注册到微信,应该先调用IWXMsg.registerApp将应用注册到微信
api.sendReq(request);每一个参数都很关键的,如果签名和包名确定都没有问题,那么基本上是传递的参数有问题。最好跟做后台的同事一起看看就能解决问题。比如partnerId传错了就会出现签名错误,再比如timeStamp,你用了自定义的时间戳与服务器的不一致,也会出现错误。排查错误最好把sign这个字段的值打印出来,与服务器生成的信息做比较,参数值没有问题才会不出问题!1.第一种原因就是上边的这些参数有问题。一般都是秘钥有问题。需自己登陆商家版后台修改&&2.需要知道支付是需要打包才能运行。这也是蛋疼的一点,测试只能通过log和Toast来推断。掉不起来可以去微信开放平台看自己配置的参数是否正确。3.微信支付跟支付宝支付不一样。微信支付同一订单不会第二次跳到支付页面 提示支付失败,同一订单第二次支付的时候直接在请求遇支付订单的时候就会返回preayid为空。所以童鞋们应该在吊起支付这一步判断一下 ,比较服务器很容易出错导致订单状态没有改,让用户一直付款。4.无法接受回调结果是因为微信规定接受支付那个类的必须在manifest里配置的包名+.wxapi里& 所以这也是比较蛋疼的一点。5.微信支付支付过的订单再次获取prepare_id为null 无法掉起支付。6. 微信支付同一订单只能绑定一个价格 列如: &33订单最初的价格为1,这是获取prepareid可以获取到值,如果对33的价格进行修改,如果没有生成过预支付订单可以获取,如果已经生成过则获取到的prepareid为null &不可以调起支付Android快速实现微信支付如果你已经成功集成了微信登录和分享,那么此文将助你快速集成微信支付,此文基于微信支付SDK3.1.1,也就是目前为止最新的SDK资源下载不过我相信,即便你看了微信的官方文档,你依然不知道微信支付怎么集成,因为微信支付的官方文档简直太.....如果你已经准备好了资源包,接下来正式开始集成我们需要的资源其实有以下几样,在开始前,就这些转备好吧1)微信支付的APPID2)微信支付依赖包 &&& libammsdk.jar3)一个Activity类 &&& WXPayEntryActivity.java这里需要特别说明一下,这个Activity类,直接从上下载到的范例代码中copy到自己的工程中即可,这个页面是在你调起微信支付完成支付(或取消或失败)后,再回到你的App时会调用的一个页面。页面的布局可以是你自定义的布局,直接放图讲解:先说一下这个类的路径,网上也有一大堆介绍了,我直接放图,路径一定,而且必须是这样的:WXPayEntryActivity 的路径在这个类中需要注意的地方有两个:1、这个类中的布局是可以自定义的,如果你不需要展示什么布局,而是要跳转页面,把这段代码删除即可回调页面的布局2、回调结果的处理,下面是官方的处理方式,直接给了一个dialog,很多人会摸不着头脑,如果你不需要这个dialog,直接删除就好了,不需要把官方demo中的布局和资源都复制过来官方的处理方式下面是我自定义的处理方式,比较简单,就是土司显示了一下支付结果,如果你需要支付成功后跳转,那么直接在这里startActivity即可,别忘记最后要将这个页面finish()自定义的处理方式这个类中的其余的回调方法,我们都不需要去操作然后我们就可以开始支付了,支付很简单,真的很简单参数列表这是微信支付需要我们携带的参数,对于新人来说,可能比较困惑的是我怎么生成这些参数呢?其实这些参数都是服务器返回给我们的,APPID我们可以自己保存在本地一份,其余的都是服务器返回给我们的,大概介绍一下流程:发起支付的流程,提交订单的时候的参数根据项目需要配置最后,服务器返回给我们微信支付的参数后,我们就可以愉快的支付了,这里是关键一步,注意!!发起支付的关键步骤至此我们已经可以调起微信支付页面来支付了最后还有一个需要注意的是,很多人被这一步坑了,就是关于微信开放平台签名的问题。其实只要你手机上的程序的签名和你在微信平台登记的签名一致即可,无论是debug版本,还是release版本参考文章:/p/ce
&&相关文章推荐
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:9956054次
积分:72556
积分:72556
排名:第23名
原创:504篇
转载:916篇
评论:2722条
如果您认为本博客不错,读后觉得有收获,不妨打赏赞助我一下,让我有动力继续写出高质量的博客。
赠人玫瑰,手有余香。分享技术,传递快乐。
QQ交流群:
有心课堂会员,请加入VIP QQ交流群:
文章:28篇
阅读:103569
文章:69篇
阅读:504918

我要回帖

更多关于 修改微信支付密码 的文章

 

随机推荐