Java接口签名如何实现
发表于:2025-11-14 作者:千家信息网编辑
千家信息网最后更新 2025年11月14日,这篇文章给大家分享的是有关Java接口签名如何实现的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、要求下图为具体要求二、流程1、线下分配appid和appsecret,针
千家信息网最后更新 2025年11月14日Java接口签名如何实现
这篇文章给大家分享的是有关Java接口签名如何实现的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
一、要求
下图为具体要求
二、流程
1、线下分配appid和appsecret,针对不同的调用方分配不同的appid和appsecret
2、加入timestamp(时间戳),10分钟内数据有效
3、加入流水号noncestr(防止重复提交),至少为10位。针对查询接口,流水号只用于日志落地,便于后期日志核查。 针对办理类接口需校验流水号在有效期内的唯一性,以避免重复请求。
4、加入signature,所有数据的签名信息。
三、实现
简单来说,调用者调用接口业务参数在body中传递,header中额外增加四个参数signature、appkey、timestamp、noncestr。
我们在后台取到四个参数,其后三个参数加上调用者分配的appSecret,使用字典排序并使用MD5加密后与第一个参数signature进行比对,一致既表示调用者有权限调用。
以下代码为接口验证签名的demo实现:
//引用jackson依赖 @Autowired private ObjectMapper objectMapper; @Value("${appsecret}") private String appSecret; /** * 验证签名 * @param preInfoItem * @return */ boolean checkSignature(PreInfoItem preInfoItem) throws JsonProcessingException, IllegalAccessException { String signature="signature"; String appkey="appkey"; String timestamp="timestamp"; String noncestr="noncestr"; HttpServletRequest request = ServletUtils.getRequest(); String headerSignature = request.getHeader(signature); String headerAppkey = request.getHeader(appkey); String headerTimestamp = request.getHeader(timestamp); String headerNoncestr = request.getHeader(noncestr); //因为需要排序,直接使用TreeMap Map parms=new TreeMap<>(); parms.put(appkey,headerAppkey); parms.put(timestamp,headerTimestamp); parms.put(noncestr,headerNoncestr); Map stringObjectMap = objectToMap(parms, preInfoItem); String s = buildSignature(stringObjectMap); //签名比对 if (s.equals(headerSignature)){ return true; } return false; } Map objectToMap(Map map,Object o){ Field[] declaredFields = o.getClass().getDeclaredFields(); for (Field field : declaredFields) { field.setAccessible(true); try { if (field.getName() instanceof String){ map.put(field.getName(),field.get(o)); } }catch (IllegalAccessException e){ throw new CustomException("对象转map异常"); } } return map; } private String buildSignature(Map maps){ String s2; try { StringBuffer s = null; String s1 = objectMapper.writeValueAsString(maps); //添加appSecret s.append(s1).append(appSecret); s2 = DigestUtils.md5DigestAsHex(s.toString().getBytes()); }catch (JsonProcessingException e){ throw new CustomException("map转json异常"); } return s2; } 感谢各位的阅读!关于"Java接口签名如何实现"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
接口
参数
流水
流水号
用者
分配
不同
有效
内容
数据
日志
更多
篇文章
排序
验证
不错
实用
一致
三个
下图
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
易语言怎么搭建代理服务器
气象局开展网络安全检查
服务器戴尔
网络安全识别现有的控制措施
学校服务器地址
药物数据库使用方法
数据库不可用请联系系统管理员
共享数据库无法访问
通信网络技术岗位
2003错误数据库
学校加强网络安全管理制度
网络安全管理与监察系统
如何提高办公软件开发能力
优化网络安全产业生态
小课堂网络安全法
家庭服务器安装什么系统
网络安全绘画简笔
医院临床网络安全管理
服务器数据安全措施
计算机网络技术中的噪音
国防科技大学教授谈互联网
服务器bios怎么优化
银行有网络安全保障吗
数据库连接池大小配置
软件开发之同行评审
软件开发工程师的职位
软件开发企业怎么做会计科目
嵌入式软件开发包含
网络安全工作紧急通知
如何提高网络安全