mirror of
				https://gitee.com/hhyykk/ipms-sjy.git
				synced 2025-11-04 04:08:43 +08:00 
			
		
		
		
	Merge remote-tracking branch 'origin/dev' into feature/springdoc
# Conflicts: # yudao-dependencies/pom.xml # yudao-framework/yudao-spring-boot-starter-web/pom.xml # yudao-framework/yudao-spring-boot-starter-web/src/main/java/cn/iocoder/yudao/framework/swagger/config/YudaoSwaggerAutoConfiguration.java # yudao-framework/yudao-spring-boot-starter-web/src/main/java/cn/iocoder/yudao/framework/swagger/core/SpringFoxHandlerProviderBeanPostProcessor.java # yudao-module-system/yudao-module-system-biz/src/main/java/cn/iocoder/yudao/module/system/controller/admin/captcha/CaptchaController.java
This commit is contained in:
		@@ -1,47 +1,61 @@
 | 
			
		||||
package cn.iocoder.yudao.module.system.controller.admin.captcha;
 | 
			
		||||
 | 
			
		||||
import cn.hutool.core.util.StrUtil;
 | 
			
		||||
import cn.hutool.extra.servlet.ServletUtil;
 | 
			
		||||
import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog;
 | 
			
		||||
import com.anji.captcha.model.common.ResponseModel;
 | 
			
		||||
import com.anji.captcha.model.vo.CaptchaVO;
 | 
			
		||||
import io.swagger.v3.oas.annotations.tags.Tag;
 | 
			
		||||
import io.swagger.v3.oas.annotations.Operation;
 | 
			
		||||
import com.anji.captcha.service.CaptchaService;
 | 
			
		||||
import io.swagger.annotations.Api;
 | 
			
		||||
import io.swagger.annotations.ApiOperation;
 | 
			
		||||
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 javax.annotation.Resource;
 | 
			
		||||
import javax.annotation.security.PermitAll;
 | 
			
		||||
import javax.servlet.http.HttpServletRequest;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * 验证码
 | 
			
		||||
 *
 | 
			
		||||
 * 问题:为什么不直接使用 anji 提供的 CaptchaController,而要另外继承?
 | 
			
		||||
 * 回答:管理使用 /admin-api/* 作为前缀,所以需要继承!
 | 
			
		||||
 *
 | 
			
		||||
 * @author 芋道源码
 | 
			
		||||
 */
 | 
			
		||||
@Tag(name = "管理后台 - 验证码")
 | 
			
		||||
@Api(tags = "管理后台 - 验证码")
 | 
			
		||||
@RestController("adminCaptchaController")
 | 
			
		||||
@RequestMapping("/system/captcha")
 | 
			
		||||
public class CaptchaController extends com.anji.captcha.controller.CaptchaController {
 | 
			
		||||
public class CaptchaController {
 | 
			
		||||
 | 
			
		||||
    @Resource
 | 
			
		||||
    private CaptchaService captchaService;
 | 
			
		||||
 | 
			
		||||
    @PostMapping({"/get"})
 | 
			
		||||
    @Operation(summary = "获得验证码")
 | 
			
		||||
    @ApiOperation("获得验证码")
 | 
			
		||||
    @PermitAll
 | 
			
		||||
    @OperateLog(enable = false) // 避免 Post 请求被记录操作日志
 | 
			
		||||
    @Override
 | 
			
		||||
    public ResponseModel get(@RequestBody CaptchaVO data, HttpServletRequest request) {
 | 
			
		||||
        return super.get(data, request);
 | 
			
		||||
        assert request.getRemoteHost() != null;
 | 
			
		||||
        data.setBrowserInfo(getRemoteId(request));
 | 
			
		||||
        return captchaService.get(data);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @PostMapping("/check")
 | 
			
		||||
    @Operation(summary = "校验验证码")
 | 
			
		||||
    @ApiOperation("校验验证码")
 | 
			
		||||
    @PermitAll
 | 
			
		||||
    @OperateLog(enable = false) // 避免 Post 请求被记录操作日志
 | 
			
		||||
    @Override
 | 
			
		||||
    public ResponseModel check(@RequestBody CaptchaVO data, HttpServletRequest request) {
 | 
			
		||||
        return super.check(data, request);
 | 
			
		||||
        data.setBrowserInfo(getRemoteId(request));
 | 
			
		||||
        return captchaService.check(data);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public static String getRemoteId(HttpServletRequest request) {
 | 
			
		||||
        String ip = ServletUtil.getClientIP(request);
 | 
			
		||||
        String ua = request.getHeader("user-agent");
 | 
			
		||||
        if (StrUtil.isNotBlank(ip)) {
 | 
			
		||||
            return ip + ua;
 | 
			
		||||
        }
 | 
			
		||||
        return request.getRemoteAddr() + ua;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user