SpringBoot2.0針對請求參數@RequestBody驗證統一攔截


title: "SpringBoot2.0針對請求參數@RequestBody驗證的統一攔截"
categories: SpringBoot2.0 Shiro
tags: SpringBoot2.0 Shirojava

author: LIUREN

SpringBoot2.0針對請求參數@RequestBody驗證統一攔截

針對SpringBoot2中請求參數統一進行攔截處理問題web

第一步:創建請求實體類RequetsUserEntity.java

RequetsUserEntity.java算法

/**
 * @Title: RequetsUserEntity.java
 * @Package io.renren.modules.wx.vo
 * @Description: 
 * Copyright: Copyright (c) 2019 www.codepeople.cn Inc. All rights reserved. 
 * Website: www.codepeople.cn 
 * @Author 劉仁
 * @DateTime 2019年4月12日 上午9:28:53
 * @version V1.0
 */

package io.renren.modules.wx.vo;

import java.io.Serializable;

import javax.validation.constraints.NotBlank;

import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;

/**
 * @ClassName: RequetsUserEntity
 * @Description: 
 * @Author 劉仁
 * @DateTime 2019年4月12日 上午9:28:53 
 */
@Data
@ApiModel(description = "RequetsUserEntity")
public class RequetsUserEntity implements Serializable{

    private static final long serialVersionUID = 8841143276870083920L;
    /**
     * appid
     */
    @ApiModelProperty(value = "appid")
    @NotBlank(message="不能爲空")
    private String appid;
    /**
     * code
     */
    @ApiModelProperty(value = "code")
    @NotBlank(message="不能爲空")
    private String code;
    /**
     * nickName
     */
    @ApiModelProperty(value = "微信暱稱")
    @NotBlank(message="不能爲空")
    private String nickName;
    /**
     * 0未知  1男性  2女性
     */
    @ApiModelProperty(value = "0未知  1男性  2女性")
    @NotBlank(message="不能爲空")
    private String gender;
    /**
     * en英文 zh_CN簡體中文   zh_TW繁體中文
     */
    @ApiModelProperty(value = "en英文 zh_CN簡體中文   zh_TW繁體中文")
    private String language;
    /**
     * 用戶所在城市
     */
    @ApiModelProperty(value = "用戶所在城市")
    private String city;
    /**
     * 用戶所在省份
     */
    @ApiModelProperty(value = "用戶所在省份")
    private String province;
    /**
     * 用戶所在國家
     */
    @ApiModelProperty(value = "用戶所在國家")
    private String country;
    /**
     * 用戶頭像圖片的 URL
     */
    @ApiModelProperty(value = "用戶頭像圖片的 URL")
    private String avatarUrl;
    /**
     * 使用 sha1( rawData + sessionkey ) 獲得字符串,用於校驗用戶信息,詳見 用戶數據的簽名驗證和加解密
     */
    @ApiModelProperty(value = "signature")
    @NotBlank(message="不能爲空")
    private String signature;
    /**
     * 不包括敏感信息的原始數據字符串,用於計算簽名
     */
    @ApiModelProperty(value = "rawData")
    @NotBlank(message="不能爲空")
    private String rawData;
    /**
     * 包括敏感數據在內的完整用戶信息的加密數據,詳見 用戶數據的簽名驗證和加解密
     */
    @ApiModelProperty(value = "encryptedData")
    @NotBlank(message="不能爲空")
    private String encryptedData;
    /**
     * 加密算法的初始向量,詳見 用戶數據的簽名驗證和加解密
     */
    @ApiModelProperty(value = "iv")
    @NotBlank(message="不能爲空")
    private String iv;
    /**
     * 登陸類型 1 微信醫生端小程序 2微信用戶端小程序 3微網站 4手機app 5微信公衆號
     */
    @ApiModelProperty(value = "1 微信醫生端小程序 2微信用戶端小程序 3微網站 4手機app 5微信公衆號")
    @NotBlank(message="不能爲空")
    private String loginType; 


}

第二步:創建Controller進行驗證

LoginController.javaspring

/**
 * @Title: WxLoginController.java
 * @Package io.renren.modules.wx.controller
 * @Description: 
 * Copyright: Copyright (c) 2019 www.codepeople.cn Inc. All rights reserved. 
 * Website: www.codepeople.cn
 * @Author 劉仁
 * @DateTime 2019年4月3日 下午3:34:44
 * @version V1.0
 */

package io.renren.modules.wx.controller;

import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import io.renren.common.utils.R;
import io.renren.modules.wx.vo.RequetsUserEntity;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;

/**
 * @ClassName: LoginController
 * @Description:
 * @Author 劉仁
 * @DateTime 2019年4月3日 下午3:34:44
 */
@Api(tags = "微信小程序受權登陸接口")
@RestController
@RequestMapping("/wx/user/{appid}")
@Slf4j
public class LoginController {

    @ApiOperation("微信小程序受權登陸")
    @PostMapping("/login")
    public R login(@Validated @RequestBody RequetsUserEntity req) {
        // TODO 實現本身的業務
        log.info("登陸成功");
        return R.ok("登陸成功");
    }

}

第三步:設置全局異常進行攔截

RRExceptionHandler.java數據庫

/**
 * Copyright (c) 2016-2019 人人開源 All rights reserved.
 *
 * https://www.renren.io
 *
 * 版權全部,侵權必究!
 */

package io.renren.common.exception;

import org.apache.shiro.authz.AuthorizationException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.dao.DuplicateKeyException;
import org.springframework.http.HttpStatus;
import org.springframework.validation.FieldError;
import org.springframework.web.bind.MethodArgumentNotValidException;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseStatus;
import org.springframework.web.bind.annotation.RestControllerAdvice;

import io.renren.common.utils.R;

/**
 * 異常處理器
 *
 * @author Mark sunlightcs@gmail.com
 */
@RestControllerAdvice
public class RRExceptionHandler {
    private Logger logger = LoggerFactory.getLogger(getClass());

    /**
     * 處理自定義異常
     */
    @ExceptionHandler(RRException.class)
    public R handleRRException(RRException e){
        R r = new R();
        r.put("code", e.getCode());
        r.put("msg", e.getMessage());

        return r;
    }

    @ExceptionHandler(DuplicateKeyException.class)
    public R handleDuplicateKeyException(DuplicateKeyException e){
        logger.error(e.getMessage(), e);
        return R.error("數據庫中已存在該記錄");
    }

    @ExceptionHandler(AuthorizationException.class)
    public R handleAuthorizationException(AuthorizationException e){
        logger.error(e.getMessage(), e);
        return R.error("沒有權限,請聯繫管理員受權");
    }

    @ExceptionHandler(Exception.class)
    public R handleException(Exception e){
        logger.error(e.getMessage(), e);
        return R.error();
    }

    @ExceptionHandler(MethodArgumentNotValidException.class)
    @ResponseStatus(HttpStatus.BAD_REQUEST)
    public R validationError(MethodArgumentNotValidException ex) {
        FieldError fieldError = ex.getBindingResult().getFieldError();
        logger.error(fieldError.getField()+fieldError.getDefaultMessage());
        return R.error(9999, fieldError.getField()+fieldError.getDefaultMessage());
    }
}

第四步:而後運行SpringBoot項目發送http請求,獲取返回信息

第五步:針對R.java類信息以下

R.javaapache

/**
 * Copyright (c) 2016-2019 人人開源 All rights reserved.
 *
 * https://www.renren.io
 *
 * 版權全部,侵權必究!
 */

package io.renren.common.utils;

import java.util.HashMap;
import java.util.Map;

/**
 * 返回數據
 *
 * @author Mark sunlightcs@gmail.com
 */
public class extends HashMap<String, Object> {
    private static final long serialVersionUID = 1L;

    public R() {
        put("code", 0);
        put("msg", "success");
    }

    public static R error() {
        return error(500, "未知異常,請聯繫管理員");
    }

    public static R error(String msg) {
        return error(500, msg);
    }

    public static R error(int code, String msg) {
        R r = new R();
        r.put("code", code);
        r.put("msg", msg);
        return r;
    }

    public static R ok(String msg) {
        R r = new R();
        r.put("msg", msg);
        return r;
    }

    public static R ok(Map<String, Object> map) {
        R r = new R();
        r.putAll(map);
        return r;
    }

    public static R ok() {
        return new R();
    }

    @Override
    public R put(String key, Object value) {
        super.put(key, value);
        return this;
    }
}

==================================================================小程序

博客地址https://www.codepeople.cn微信小程序

==================================================================springboot

相關文章
相關標籤/搜索