支付方式-微信支付


//1*******微信扫码支付申请
微信扫码支付是商户系统按微信支付协议生成支付二维码,用户再用微信“扫一扫”完成
支付的模式。该模式适用于 PC 网站支付、实体店单品或订单支付、媒体广告支付等场景。
申请步骤:(了解)
第一步:注册公众号(类型须为:服务号)
请根据营业执照类型选择以下主体注册:个体工商户| 企业/公司| 政府| 媒体| 其他类型。
第二步:认证公众号
公众号认证后才可申请微信支付,认证费:300 元/次。
第三步:提交资料申请微信支付
登录公众平台,点击左侧菜单【微信支付】,开始填写资料等待审核,审核时间为 1-5
个工作日内。
第四步:开户成功,登录商户平台进行验证
资料审核通过后,请登录联系人邮箱查收商户号和密码,并登录商户平台填写财付通备
付金打的小额资金数额,完成账户验证。
第五步:在线签署协议
本协议为线上电子协议,签署后方可进行交易及资金结算,签署完立即生效。


在线微信支付开发文档:
https://pay.weixin.qq.com/wiki/doc/api/index.html      自己看

如果你不能联网,请查阅讲义配套资源 (资源\配套软件\微信扫码支付\开发文档)
我们在本章课程中会用到”统一下单”和”查询订单”两组 API

模式一: 由微信运营 控制二维码 生成二维码供商家使用 。流程: 二维码已经用微信运营生成好。 用户 ——》扫描——微信运营后台——读取到url 检测是否存在商家
——》检测通过——》 用户授权 ——》 授权通过——》订单生成 ——》 循环检测订单状态 ——》返回商家状态
模式二: 由商家自己控制二维码  
        
        生成之前与微信运营后台交互 
        

****************这是采用的是模式二***********************

//1**在支付工程service 导入坐标


        <dependency>
        <groupId>com.github.wxpay</groupId>
        <artifactId>wxpay-sdk</artifactId>
        <version>0.0.3</version>
        </dependency>

        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpclient</artifactId>
        </dependency>
        
        
2**        
配置 :添加配置文件 weixinpay.properties

appid: 微信公众账号或开放平台 APP 的唯一标识
partner:财付通平台的商户账号
partnerkey:财付通平台的商户密钥
notifyurl: 回调地址

appid=wx8397f8696b538317
partner=1473426802
partnerkey=8A627A4578ACE384017C997F12D68B23
notifyurl=http://a31ef7db.ngrok.io/WeChatPay/WeChatPayNotify    

3**    
将二维码插件 QRious 拷贝到 pinyougou-cart-web 的 plugins 目录中


4 接口:  这里是生成二维码接口, out_trade_no 是商家订单号 ,total_fee是金额 用String方便传输  单位是分

    public Map createNative(String out_trade_no, String total_fee);


    
    @Service
    public class WeixinPayServiceimpl implements WeixinPayService {

    @Value("${appid}")
    private String appid;
    @Value("${partner}")
    private String partner;
    @Value("${partnerkey}")
    private String partnerkey;

    @Override
    public Map createNative(String out_trade_no, String total_fee) {
        Map param = new HashMap();
        param.put("appid", appid);//公众号
        param.put("mch_id", partner);//商户号
        param.put("nonce_str", WXPayUtil.generateNonceStr());//随机字符串
        param.put("body", "品优购");//商品描述
        param.put("out_trade_no", out_trade_no);//商户订单号
        param.put("total_fee",total_fee);//总金额(分)
        param.put("spbill_create_ip", "127.0.0.1");//IP
        param.put("notify_url", "http://test.itcast.cn");//回调地址(随便写)
        param.put("trade_type", "NATIVE");//交易类型

        try {
//2.生成要发送的 xml
            String xmlParam = WXPayUtil.generateSignedXml(param, partnerkey);
            System.out.println(xmlParam);
            HttpClient client=new HttpClient("https://api.mch.weixin.qq.com/pay/unifiedorder");
            client.setHttps(true);
            client.setXmlParam(xmlParam);
            client.post();
//3.获得结果
            String result = client.getContent();
            System.out.println(result);
            Map<String, String> resultMap = WXPayUtil.xmlToMap(result);
            Map<String, String> map=new HashMap<>();
            map.put("code_url", resultMap.get("code_url"));//支付地址
            map.put("total_fee", total_fee);//总金额
            map.put("out_trade_no",out_trade_no);//订单号
            return map;
        } catch (Exception e) {
            e.printStackTrace();
            return new HashMap<>();
        }
    }

//Controller层  这里是随机生成的代码  并且设置为1分  写死的 ,这个"1",要从前端传输过来
        @RestController
        @RequestMapping("/pay")
        public class PayController {
        @Reference
        private WeixinPayService weixinPayService;
        
        @RequestMapping("/createNative")
        public Map createNative(){
        IdWorker idworker=new IdWorker();
        return weixinPayService.createNative(idworker.nextId()+"","1");
            }
        }


//访问这个方法 就可以生成微信的给的 url  再用qrious生成二维码到页面

//这个时候已经生成的二维码,但是并不能判断用户是否已经支付
        查询交易状态

        (pay-service)
        
        @Override
        public Map queryPayStatus(String out_trade_no) {
        //1.封装参数
        Map param=new HashMap();
        param.put("appid", appid);
        param.put("mch_id", partner);
        param.put("out_trade_no", out_trade_no);
        param.put("nonce_str", WXPayUtil.generateNonceStr());
        try {
            String xmlParam = WXPayUtil.generateSignedXml(param, partnerkey);
            //2.发送请求
            HttpClient httpClient=new HttpClient("https://api.mch.weixin.qq.com/pay/orderquery");
            httpClient.setHttps(true);
            httpClient.setXmlParam(xmlParam);
            httpClient.post();
            
            //3.获取结果
            String xmlResult = httpClient.getContent();
            Map<String, String> map = WXPayUtil.xmlToMap(xmlResult);
            System.out.println("调动查询API返回结果:"+xmlResult);
            
            return map;
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            return null;
        }
        
    }


//这里就要在 cart-web的 PayController中设置循环查询状态,三秒一次 ,并且过了100秒会重新生成订单号二维码,如果返回"SUCCESS"则支付成功  
    
    @RequestMapping("/queryPayStatus")
    public Result queryPayStatus(String out_trade_no){
        Result result=null;
        int x=0;
        while(true){
            
            Map<String,String> map = weixinPayService.queryPayStatus(out_trade_no);//调用查询
            if(map==null){
                result=new Result(false, "支付发生错误");
                break;
            }
            if(map.get("trade_state").equals("SUCCESS")){//支付成功
                result=new Result(true, "支付成功");                
                orderService.updateOrderStatus(out_trade_no, map.get("transaction_id"));//修改订单状态
                break;
            }
            
            try {
                Thread.sleep(3000);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            
            x++;
            if(x>=100){                
                result=new Result(false, "二维码超时");
                break;                
            }
            
        }
        return result;
    }


//支付成功 页面显示订单号  和提示支付成功,并添加到数据库订单表中 并修改购物车中的商品状态为已购买
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值