当前位置: 首页 > wzjs >正文

制作网页的的网站怎么做网页截图

制作网页的的网站,怎么做网页截图,中山专业做网站公司,外包网接单简介 例如说:项目给第三方提供 HTTP 接口时,为了提高对接中数据传输的安全性(防止请求参数被篡改),同时校验调用方的有效性,通常都需要增加签名 sign。 市面上也有非常多的案例,例如说: 支付宝签名企业微信签名实现原理基本类似不再过多赘述,下面直接上代码。 1. 概述…

简介

例如说:项目给第三方提供 HTTP 接口时,为了提高对接中数据传输的安全性(防止请求参数被篡改),同时校验调用方的有效性,通常都需要增加签名 sign

市面上也有非常多的案例,例如说:

  • 支付宝签名
  • 企业微信签名

实现原理基本类似不再过多赘述,下面直接上代码。

1. 概述

API签名校验机制是一个用于保护API接口安全性的框架,通过验证请求的完整性和时效性,防止请求被篡改和重放攻击。该机制基于Spring AOP实现,使用注解方式配置,支持自动配置。

2. 核心组件

2.1 注解组件 (ApiSignature.java)

@Inherited
@Documented
@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface ApiSignature {// 签名有效时间,默认60秒int timeout() default 60;// 时间单位,默认秒TimeUnit timeUnit() default TimeUnit.SECONDS;// 签名失败时的错误提示String message() default "签名不正确";// 签名参数配置String appId() default "appId";String timestamp() default "timestamp";String nonce() default "nonce";String sign() default "sign";
}

2.2 切面组件 (ApiSignatureAspect.java)

@Aspect
@Slf4j
@AllArgsConstructor
public class ApiSignatureAspect {private final ApiSignatureRedisDAO signatureRedisDAO;@Before("@annotation(signature)")public void beforePointCut(JoinPoint joinPoint, ApiSignature signature) {// 1. 验证通过,直接结束if (verifySignature(signature, Objects.requireNonNull(ServletUtils.getRequest()))) {return;}// 2. 验证不通过,抛出异常log.error("[beforePointCut][方法{} 参数({}) 签名失败]", joinPoint.getSignature().toString(),joinPoint.getArgs());throw new AppException(AppExceptionCodeMsg.BAD_REQUEST);}
}

2.3 Redis组件 (ApiSignatureRedisDAO.java)

package com.erp.common.signature.core.redis;import lombok.AllArgsConstructor;
import org.springframework.data.redis.core.StringRedisTemplate;import java.util.concurrent.TimeUnit;/*** HTTP API 签名 Redis DAO** @author liming*/
@AllArgsConstructor
public class ApiSignatureRedisDAO {private final StringRedisTemplate stringRedisTemplate;/*** 验签随机数* <p>* KEY 格式:signature_nonce:%s // 参数为 随机数* VALUE 格式:String* 过期时间:不固定*/private static final String SIGNATURE_NONCE = "api_signature_nonce:%s:%s";/*** 签名密钥* <p>* HASH 结构* KEY 格式:%s // 参数为 appid* VALUE 格式:String* 过期时间:永不过期(预加载到 Redis)*/private static final String SIGNATURE_APPID = "api_signature_app";// ========== 验签随机数 ==========public String getNonce(String appId, String nonce) {return stringRedisTemplate.opsForValue().get(formatNonceKey(appId, nonce));}public Boolean setNonce(String appId, String nonce, int time, TimeUnit timeUnit) {return stringRedisTemplate.opsForValue().setIfAbsent(formatNonceKey(appId, nonce), "", time, timeUnit);}private static String formatNonceKey(String appId, String nonce) {return String.format(SIGNATURE_NONCE, appId, nonce);}// ========== 签名密钥 ==========public String getAppSecret(String appId) {return (String) stringRedisTemplate.opsForHash().get(SIGNATURE_APPID, appId);}}

3. 签名验证流程

3.1 请求处理流程

  1. 请求进入

    • 客户端发送带有签名参数的HTTP请求
    • 请求必须包含:appId、timestamp、nonce、sign等参数
  2. 切面拦截

    • 通过AOP拦截带有@ApiSignature注解的接口
    • 获取请求对象和注解配置
  3. 参数验证

    • 验证请求头参数完整性
    • 检查时间戳有效性
    • 验证nonce唯一性
  4. 签名验证

    • 获取appSecret
    • 构建签名字符串
    • 计算服务端签名
    • 比对客户端签名
  5. 防重放处理

    • 将nonce存入Redis
    • 设置过期时间

3.2 详细验证步骤

ApiSignatureAspect.java

public boolean verifySignature(ApiSignature signature, HttpServletRequest request) {// 1. 验证请求头if (!verifyHeaders(signature, request)) {return false;}// 2. 获取appSecretString appId = request.getHeader(signature.appId());String appSecret = signatureRedisDAO.getAppSecret(appId);// 3. 验证签名String clientSignature = request.getHeader(signature.sign());String serverSignatureString = buildSignatureString(signature, request, appSecret);String serverSignature = DigestUtil.sha256Hex(serverSignatureString);// 4. 防重放处理String nonce = request.getHeader(signature.nonce());if (!signatureRedisDAO.setNonce(appId, nonce, signature.timeout() * 2, signature.timeUnit
http://www.dtcms.com/wzjs/557421.html

相关文章:

  • 成都隆昌网站建设网络营销是什么来实现营销目标的一种市场营销方式
  • 搭一个网站网站程可以自己做吗
  • 无锡网站网站建设网站界面布局
  • 网站优化就是搜索引擎优化好网站你知道的
  • 一份完整的网站策划书烟台h5网站制作公司
  • 山东建设银行招聘网站红酒商城网站建设方案书
  • 深圳企业网站哪家强网站开发规范有哪些
  • 上海装修公司做网站素材网免费
  • 企顺网网站建设外贸网站建站赚钱
  • 怎么将自己做的网站发到网上去撮合交易网站建设方案
  • asp 个人网站国外10条新闻简短
  • 设备免费做网站推广怎么开一家网站开发公司
  • 怎么用php自己做网站吗网络推广理实一体化软件
  • 沧州网站seo公司丽水网站建设明恩玉杰
  • 网页制作网站创建中小型网站建设公司
  • 微信官网网站网站内容检测
  • 专注电子商务网站建设嵌入式软件开发项目
  • 电子科技网站建设室内设计模拟app
  • 建一个购物网站需要什么条件wordpress 主题 水墨
  • 数据展示网站模板丽水城乡建设局网站
  • 粉末涂料 技术支持 东莞网站建设网站建设预付流程
  • 又做投资的网站吗用dw怎么做用户登录页面的网站
  • 建设电子商务网站策划书wordpress ajax失败
  • 泰州专业做网站公司域名注册新网
  • 网站举报查询网站制作公司网站源码
  • 衣服网站建设规划书廊坊百度推广电话
  • 国外的营销网站有哪些wordpress新浪图床
  • 本溪做网站松江注册公司
  • 做百度关键词网站网站使用前流程
  • 买空间域名做网站做安卓icon图标包下载网站