Java接口签名如何实现
发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,这篇文章给大家分享的是有关Java接口签名如何实现的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、要求下图为具体要求二、流程1、线下分配appid和appsecret,针
千家信息网最后更新 2025年02月01日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 Mapparms=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安全错误
数据库的锁怎样保障安全
成都应用软件开发大概多少钱
网络安全从业人员资质
数据库中是内连接快还是外连接快
南京crm软件开发代码
监利县天气预报软件开发
包头市润恒城互联网加科技
京东网络技术支持
软件开发品牌w开头
显卡问题网络安全模式
授课数据库有三个基本表
贵公司南京软件开发公司
私有云数据库
网络安全的汽车公司
莱西市勤荔铎软件开发部
怎么做动态网站的数据库
服务器机柜过滤风扇批发价
喜氏互联网科技 融资
奥西400服务器管理员账号
存储服务器更换硬盘后检测不到
开票显示更新数据库失败
软件开发工程师职业方向
mysql数据库分数
大专生网络技术
卡斯柯软件开发社招
数据库三种赋值方式
网络安全的演讲稿200字
什么软件开发汉字
T-sql数据数据库备份
网络技术学习好物分享
天龙八部私服登录器数据库