代码风格 - 统一结果返回

好处:
后端统一返回格式,前端可以:
1.根据错误码做合适的展示,避免盲目等待、重复请求、无奈刷新。
2.根据页面当前的分页方式,对数据做相应处理。
后台:
后端主要使用类:R ResultCode:
首先是R,针对这个类我的考虑是其他类引用时会更加的方便,那么做泛型设计,静态的build都是个不错的选择。ResultCode 这个类的设计是将状态码和状态信息进行绑定,那么可以增加复用性。当需要新的message时,只要在ResultcodeEnum 新增一个枚举类型。看完这个类之后再下面讲讲枚举类的设计。

1.定义统一规范的枚举类:

package com.enation.app.javashop.core.video;


/**
 * @desc 请求状态枚举
 *       后续状态若太多,可以考虑使用继承等方式拓展。
 * @slice zhaozhe 2020-8-16 16:48:44
 */
public enum ResultCode {

    /**
     * 广义通用
     */
    SUCCESS(1, "成功"),
    ERROR(-1, "错误"),
    NOT_FOUND(-404, "没有找到资源"),
    NOT_EMPTY(-400, "字段不能为空"),
    DUPLICATE_EXCEPTION(-200, "重复异常"),

    /**
     * 规约:时间异常类 value定义区间为 -100 ~ -199
     */
    TIME_EMPTY(-100, "时间不能为空"),
    TIME_MORE_THAN_14_DAYS(-101, "时间跨度不能超过两个星期"),

    /**
     * 规约:字段为空 value区间 -200 ~ -299
     */
    OPENID_EMPTY(-201, "openid不能为空");
    private int value;

    private String msg;

    ResultCode(int value, String msg) {
        this.value = value;
        this.msg = msg;
    }

    public int getValue() {
        return value;
    }

    public String getMsg() {
        return msg;
    }
}

2.对Controller的结果输出 

package com.enation.app.javashop.core.video;

import com.fasterxml.jackson.annotation.JsonInclude;
import lombok.Data;

/**
 * @desc 后端返回统一的结果集,例如包括状态码等信息,可以让前端更好的进行页面的展示。
 *       封装这样一个结果集有通用且常用的几个属性:
 *          code: 状态码
 *          message:状态信息
 *          data:返回数据
 *       后端统一返回格式,前端可以:根据错误码做合适的展示,避免盲目等待、重复请求、无奈刷新。
 *                              根据页面当前的分页方式,对数据做相应处理。
 * @param <T>
 * @since zhaozhe 2020-8-16 16:42:32
 * @explain 后端主要使用类:R ResultCode
 *          首先是R,针对这个类我的考虑是其他类引用时会更加的方便,那么做泛型设计,静态的build都是个不错的选择。ResultCode 这个类的设计是将状态码和状态信息进行绑定,那么可以增加复用性。当需要新的message时,只要在ResultcodeEnum 新增一个枚举类型。看完这个类之后再下面讲讲枚举类的设计。
 */

@Data
@JsonInclude(JsonInclude.Include.NON_NULL)
public class R<T> {

    private Integer code;
    private String message;

    /**
     * data的总条数,在没有确定data类型时初始化为0显然不太合理。
     */
    private Integer total;
    private T data;

    public static <T> R<T> build(Integer code, String message, Integer total, T data) {
        return new R<>(code, message, total, data);
    }

    public static <T> R<T> build(ResultCode resultCode, String message, Integer total, T data) {
        return new R<>(resultCode, message, total, data);
    }

    public static <T> R<T> error(ResultCode resultCode) {
        return new R<>(resultCode);
    }

    public static <T> R<T> error(ResultCode resultCode, String message) {
        return new R<>(resultCode, message);
    }

    public static <T> R<T> success() {
        return new R<>(ResultCode.SUCCESS);
    }


    public static <T> R<T> client(T data) {
        return new R<>(data);
    }

    public static <T> R<T> server(Integer total, T data) {
        return new R<>(total, data);
    }


    /**
     * 有错误的情况下需要传递错误码 + 错误提示
     *
     * @param code
     * @param message
     */
    private R(Integer code, String message) {
        this.code = code;
        this.message = message;
    }

    private R(ResultCode resultCode, String message) {
        this.code = resultCode.getValue();
        this.message = message;
    }

    private R(ResultCode resultCode) {
        this.code = resultCode.getValue();
        this.message = resultCode.getMsg();
    }

    /**
     * 客户端分页,只需要数据 data
     *
     * @param data
     */
    private R(T data) {
        this.code = ResultCode.SUCCESS.getValue();
        this.message = ResultCode.SUCCESS.getMsg();
        this.data = data;
    }

    /**
     * 服务端分页,data + total
     *
     * @param total
     * @param data
     */
    private R(Integer total, T data) {
        this.code = ResultCode.SUCCESS.getValue();
        this.message = ResultCode.SUCCESS.getMsg();;
        this.total = total;
        this.data = data;
    }

    private R(Integer code, String message, Integer total, T data) {
        this.code = code;
        this.message = message;
        this.total = total;
        this.data = data;
    }

    private R(ResultCode resultCode, String message, Integer total, T data) {
        this.code = resultCode.getValue();
        this.message = message;
        this.total = total;
        this.data = data;
    }

    private R() {}
}

3.试用结果

    @ApiOperation(value = "添加视频流类型设置", response = VideoSetDO.class)
    @PostMapping("/category/add")
    public R add(@Valid @RequestBody VideoCategoryVO category) {
        // @Valid 是hibernate验证,详情请百度
        try {
            VideoCategoryDO videoCategoryDO = new VideoCategoryDO();
            BeanUtil.copyProperties(category, videoCategoryDO);
            this.videoSetManager.editCategory(videoCategoryDO, id);
            return R.client(category);
        } catch (Exception e) {
            e.printStackTrace();
            e.getMessage();
            return R.error(ResultCode.ERROR, e.getMessage());
        }

    }

返回结果

本文总结于网上博客 。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 微信小程序支付api-v3是微信提供的一种支付方式,它基于RESTful风格的API设计,使用HTTP协议传输数据,全部使用JSON格式,具有优秀的跨平台性能和安全性。本文将为大家提供微信小程序支付api-v3 php的完整代码。 微信小程序支付api-v3 php完整代码: 首先,需要获取商户的API密钥和证书文件,然后设置请求头信息,代码如下: $merchant_api_secret = 'Your Secret Key'; //商户API密钥 $merchant_cert_file = 'path/to/cert.pem'; //商户证书文件路径 $merchant_key_file = 'path/to/key.pem'; //商户密钥文件路径 $timestamp = time(); $nonce_str = uniqid(); $signature = generate_signature($merchant_api_secret, $timestamp, $nonce_str, $http_method, $http_uri, $query_string, $body); $header = array( 'Authorization: ' . $authorization, 'Accept: application/json', 'Content-Type: application/json', 'User-Agent: your-device', 'Wechatpay-Serial: your-certificate-serial-number', 'Wechatpay-Timestamp: ' . $timestamp, 'Wechatpay-Nonce: ' . $nonce_str, 'Wechatpay-Signature: ' . $signature, ); 然后,我们需要调用微信小程序支付api-v3接口,具体如下: $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $api_url); curl_setopt($ch, CURLOPT_HTTPHEADER, $header); curl_setopt($ch, CURLOPT_SSLCERTTYPE, 'PEM'); curl_setopt($ch, CURLOPT_SSLCERT, $merchant_cert_file); curl_setopt($ch, CURLOPT_SSLKEY, $merchant_key_file); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_TIMEOUT, 30); curl_setopt($ch, CURLOPT_CUSTOMREQUEST, $http_method); if (!empty($body)){ curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($body)); } $response = curl_exec($ch); $status_code = curl_getinfo($ch, CURLINFO_HTTP_CODE); if ($status_code !== 200){ throw new Exception('微信小程序支付api-v3调用错误,错误代码' . $status_code); } $response_payload = json_decode($response, true); curl_close($ch); 以上就是微信小程序支付api-v3 php的完整代码,通过以上代码可以实现微信小程序支付api-v3的接口调用,实现支付等操作。同时需要注意的是,具体代码需要根据自己的实际情况进行调整。 ### 回答2: 微信小程序支付API-v3是一套用于支付的接口,支持PHP语言,这里提供完整的代码实现。 在使用微信小程序支付API-v3前需要进行身份验证,将私钥转换为PKCS8格式和获取API证书,并将两者合成一个PEM格式的文件。接下来就可以创建支付订单并进行支付了。 以下是PHP代码的示例: ```php <?php require_once "wxpayloader.php"; $wxpayConfig = new WxPayConfig(); // 公众号ID $wxpayConfig->setAppId("your app id"); // 商户号 $wxpayConfig->setMchId("your mch id"); // 商户API秘钥 $wxpayConfig->setApiKey("your api key"); // 商户API证书路径 $wxpayConfig->setSslCertPath("path/to/your/apiclient_cert.pem"); // 商户API证书密钥路径 $wxpayConfig->setSslKeyPath("path/to/your/apiclient_key.pem"); // 微信支付平台API证书路径 $wxpayConfig->setSslRootCaPath("path/to/your/rootca.pem"); // 接口请求地址 $wxpayConfig->setApiUrl("https://api.mch.weixin.qq.com/"); // 验证商户API证书 $result = WxPayApi::sslVerify($wxpayConfig); if($result['result'] != 0) { die("SSL证书验证失败:" . $result['errmsg']); } // 创建订单 $out_trade_no = "20170525" . rand(10000, 99999); $total_fee = 1; $trade_type = "JSAPI"; // 交易类型为小程序支付 $notify_url = "http://your.domain.com/weixin/paynotify.php"; // 支付结果通知URL $wxpayData = new WxPayData(); $wxpayData->setBody("test"); $wxpayData->setOutTradeNo($out_trade_no); $wxpayData->setTotalFee($total_fee); $wxpayData->setTradeType($trade_type); $wxpayData->setNotifyUrl($notify_url); $wxpayData->setOpenid("your openid"); // 用户的openid,小程序通过wx.login获取 // 统一下单 $result = WxPayApi::unifiedOrder($wxpayConfig, $wxpayData); if($result['return_code'] != 'SUCCESS' || $result['result_code'] != 'SUCCESS') { die("统一下单失败:" . $result['err_code_des']); } // 获取微信小程序支付参数 $prepay_id = $result["prepay_id"]; $wxpayData = new WxPayData(); $wxpayData->setAppId($wxpayConfig->getAppId()); $wxpayData->setTimeStamp(time()); $wxpayData->setNonceStr(WxPayApi::generateNonceStr()); $wxpayData->setPackage("prepay_id=" . $prepay_id); $wxpayData->setSignType("RSA"); // 生成签名 $sign = WxPayApi::generateSignature($wxpayData, $wxpayConfig); // 将签名加到数据包中 $wxpayData->setPaySign($sign); // 返回小程序支付参数 echo json_encode($wxpayData->getValues()); ``` 以上代码首先创建了WxPayConfig对象,将商户号、API密钥、API证书路径等信息设置进去。然后创建订单数据包,通过WxPayApi::unifiedOrder方法提交到微信支付平台统一下单。如果成功,则获取预支付ID,按照微信小程序支付的规定生成签名,再将签名加到数据包中,最终返回给小程序,由小程序前端发起支付请求。 获取API证书和PKCS8格式私钥的方法,请参考微信支付平台官方文档。 ### 回答3: 微信小程序支付 API-v3 提供了一种安全、高效、简便的支付方式,帮助开发者更好地满足用户需求。以下是微信小程序支付 API-v3 PHP 完整代码。 首先,要使用微信小程序支付 API-v3,需要先在微信支付商户平台上注册并开通服务。 接下来,下载 PHP SDK 安装包,将下载得到的文件解压后,将文件夹内的文件复制到项目代码所在的目录中。 在代码中导入 SDK 中的类库: ```php require_once "lib/WxPay.Api.php"; require_once "lib/WxPay.Data.php"; ``` 接着,需要通过商户号和 API 密钥进行身份验证: ```php $config = new WxPayConfig(); $config->SetMerchantId("商户号"); $config->SetKey("API密钥"); ``` 然后,实例化一个统一下单对象,并设置相关支付参数: ```php $input = new WxPayUnifiedOrder(); $input->SetBody("商品描述"); // 商品描述 $input->SetAttach("附加数据"); // 附加数据 $input->SetOut_trade_no("商户订单号"); // 商户订单号 $input->SetNotify_url("回调URL"); // 回调URL $input->SetTotal_fee("总金额"); // 总金额(单位:分) $input->SetTrade_type("JSAPI"); // 交易类型 $input->SetOpenid("用户openid"); // 用户openid ``` 接着,调用统一下单 API 并获取支付参数: ```php $order = WxPayApi::unifiedOrder($config, $input); $prepayId = $order["prepay_id"]; $nonceStr = WxPayApi::getNonceStr(); $timeStamp = time(); $package = "prepay_id=" . $prepayId; $signType = "HMAC-SHA256"; $paySign = WxPayApi::getPaySign($config, $nonceStr, $package, $signType, $timeStamp); ``` 最后,在前端页面中使用获取到的支付参数调起微信支付即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值