网友通过本文主要向大家介绍了q币充值平台,游戏充值平台代理,ios充值平台,骏网一卡通充值平台,充值平台等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
充值,充值平台
public class ChongZhiActivity extends BaseActivity { //支付的信息 private static final String PARTNER = PayKeys.DEFAULT_PARTNER; private static final String SELLER = PayKeys.DEFAULT_SELLER; private static final String RSA_PRIVATE = PayKeys.PRIVATE; private static final int SDK_PAY_FLAG = 1; @Bind(R.id.iv_title_back) ImageView ivTitleBack; @Bind(R.id.tv_title) TextView tvTitle; @Bind(R.id.iv_title_setting) ImageView ivTitleSetting; @Bind(R.id.chongzhi_text) TextView chongzhiText; @Bind(R.id.view) View view; @Bind(R.id.et_chongzhi) EditText etChongzhi; @Bind(R.id.chongzhi_text2) TextView chongzhiText2; @Bind(R.id.yue_tv) TextView yueTv; @Bind(R.id.btn_chongzhi) Button btnChongzhi; private Handler mHandler = new Handler() { public void handleMessage(Message msg) { switch (msg.what) { case SDK_PAY_FLAG: { PayResult payResult = new PayResult((String) msg.obj); // 支付宝返回此次支付结果及加签,建议对支付宝签名信息拿签约时支付宝提供的公钥做验签 String resultInfo = payResult.getResult(); String resultStatus = payResult.getResultStatus(); // 判断resultStatus 为“9000”则代表支付成功,具体状态码代表含义可参考接口文档 if (TextUtils.equals(resultStatus, "9000")) { Toast.makeText(ChongZhiActivity.this, "支付成功", Toast.LENGTH_SHORT).show(); } else { // 判断resultStatus 为非“9000”则代表可能支付失败 // “8000”代表支付结果因为支付渠道原因或者系统原因还在等待支付结果确认,最终交易是否成功以服务端异步通知为准(小概率状态) if (TextUtils.equals(resultStatus, "8000")) { Toast.makeText(ChongZhiActivity.this, "支付结果确认中", Toast.LENGTH_SHORT).show(); } else { // 其他值就可以判断为支付失败,包括用户主动取消支付,或者系统返回的错误 Toast.makeText(ChongZhiActivity.this, "支付失败", Toast.LENGTH_SHORT).show(); } } break; } default: break; } }; }; @Override protected void initData() { //默认情况下,button是不可操作的 btnChongzhi.setClickable(false); etChongzhi.addTextChangedListener(new TextWatcher() { @Override public void beforeTextChanged(CharSequence s, int start, int count, int after) { Log.e("TAG", "ChongZhiActivity beforeTextChanged()"); } @Override public void onTextChanged(CharSequence s, int start, int before, int count) { Log.e("TAG", "ChongZhiActivity onTextChanged()"); } @Override public void afterTextChanged(Editable s) { Log.e("TAG", "ChongZhiActivity afterTextChanged()"); String money = etChongzhi.getText().toString().trim(); if(TextUtils.isEmpty(money)){ //设置button为不可操作的 btnChongzhi.setClickable(false); //设置背景颜色 btnChongzhi.setBackgroundResource(R.drawable.btn_02); }else{ //设置button为可操作的 btnChongzhi.setClickable(true); //设置背景颜色 btnChongzhi.setBackgroundResource(R.drawable.btn_01); } } }); } @Override protected void initTitle() { ivTitleBack.setVisibility(View.VISIBLE); tvTitle.setText("充值"); ivTitleSetting.setVisibility(View.INVISIBLE); } @OnClick(R.id.iv_title_back) public void back(View view){ this.removeCurrentActivity(); } @Override protected int getLayoutId() { return R.layout.activity_chong_zhi; } @OnClick(R.id.btn_chongzhi) public void chongZhi(View view){ // UIUtils.toast("充值",false); // 订单 String orderInfo = getOrderInfo("iphone 7 plus 256G", "史上配置最高的iphone手机", "0.01"); // 对订单做RSA 签名 String sign = sign(orderInfo); try { // 仅需对sign 做URL编码 sign = URLEncoder.encode(sign, "UTF-8"); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } // 完整的符合支付宝参数规范的订单信息 final String payInfo = orderInfo + "&sign=\"" + sign + "\"&" + getSignType(); Runnable payRunnable = new Runnable() { @Override public void run() { // 构造PayTask 对象 PayTask alipay = new PayTask(ChongZhiActivity.this); // 调用支付接口,获取支付结果 String result = alipay.pay(payInfo); Message msg = new Message(); msg.what = SDK_PAY_FLAG; msg.obj = result; mHandler.sendMessage(msg); } }; // 必须异步调用 Thread payThread = new Thread(payRunnable); payThread.start(); } /** * get the sign type we use. 获取签名方式 * */ public String getSignType() { return "sign_type=\"RSA\""; } /** * sign the order info. 对订单信息进行签名 * * @param content * 待签名订单信息 */ public String sign(String content) { return SignUtils.sign(content, RSA_PRIVATE); } /** * create the order info. 创建订单信息 * */ public String getOrderInfo(String subject, String body, String price) { // 签约合作者身份ID String orderInfo = "partner=" + "\"" + PARTNER + "\""; // 签约卖家支付宝账号 orderInfo += "&seller_id=" + "\"" + SELLER + "\""; // 商户网站唯一订单号 orderInfo += "&out_trade_no=" + "\"" + getOutTradeNo() + "\""; // 商品名称 orderInfo += "&subject=" + "\"" + subject + "\""; // 商品详情 orderInfo += "&body=" + "\"" + body + "\""; // 商品金额 orderInfo += "&total_fee=" + "\"" + price + "\""; // 服务器异步通知页面路径 orderInfo += "¬ify_url=" + "\"" + "http://notify.msp.hk/notify.htm" + "\""; // 服务接口名称, 固定值 orderInfo += "&service=\"mobile.securitypay.pay\""; // 支付类型, 固定值 orderInfo += "&payment_type=\"1\""; // 参数编码, 固定值 orderInfo += "&_input_charset=\"utf-8\""; // 设置未付款交易的超时时间 // 默认30分钟,一旦超时,该笔交易就会自动被关闭。 // 取值范围:1m~15d。 // m-分钟,h-小时,d-天,1c-当天(无论交易何时创建,都在0点关闭)。 // 该参数数值不接受小数点,如1.5h,可转换为90m。 orderInfo += "&it_b_pay=\"30m\""; // extern_token为经过快登授权获取到的alipay_open_id,带上此参数用户将使用授权的账户进行支付 // orderInfo += "&extern_token=" + "\"" + extern_token + "\""; // 支付宝处理完请求后,当前页面跳转到商户指定页面的路径,可空 orderInfo += "&return_url=\"m.alipay.com\""; // 调用银行卡支付,需配置此参数,参与签名, 固定值 (需要签约《无线银行卡快捷支付》才能使用) // orderInfo += "&paymethod=\"expressGateway\""; return orderInfo; } /** * get the out_trade_no for an order. 生成商户订单号,该值在商户端应保持唯一(可自定义格式规范) * */ public