java如何保证数据安全_前后端分离后API交互如何保证数据安全性?

如何保证API调用时数据的安全性?

1、通信使用https

2、请求签名,防止参数被篡改

3、身份确认机制,每次请求都要验证是否合法  (每次请求带上token)

4、APP中使用ssl pinning防止抓包操作

5、对所有请求和响应都进行加解密操作

6、等等方案…….

三、对所有请求和响应都进行加解密操作

方案有很多种,当你做的越多,也就意味着安全性更高,今天我跟大家来介绍一下对所有请求和响应都进行加解密操作的方案,即使能抓包,即使能调用我的接口,但是我返回的数据是加密的,只要加密算法够安全,你得到了我的加密内容也对我没什么影响。

像这种工作最好做成统一处理的,你不能让每个开发都去关注这件事情,如果让每个开发去关注这件事情就很麻烦了,返回数据时还得手动调用下加密的方法,接收数据后还得调用下解密的方法。

为此,我基于Spring Boot封装了一个Starter, 内置了AES加密算法。GitHub地址如下:

https://github.com/yinjihuan/spring-boot-starter-encrypt

先来看看怎么使用,可以下载源码,然后引入即可,然后在启动类上增加@EnableEncrypt注解开启加解密操作:

cf56a32b149bcd6a7eebd2e1aad24b26.png

增加加密的key配置:

cb73f830f22a71118cfb37235c6ac72c.png

spring.encrypt.key:加密key,必须是16位

spring.encrypt.debug:是否开启调试模式,默认为false,如果为true则不启用加解密操作

为了考虑通用性,不会对所有请求都执行加解密,基于注解来做控制

响应数据需要加密的话,就在Controller的方法上加@Encrypt注解即可。

a72ebc21f666dbd3f3c348b3b07c26a7.png

当我们访问/list接口时,返回的数据就是加密之后base64编码的格式。

还有一种操作就是前段提交的数据,分为2种情况,一种是get请求,这种暂时没处理,后面再考虑,目前只处理的post请求,基于json格式提交的方式,也就是说后台需要用@RequestBody接收数据才行, 需要解密的操作我们加上@Decrypt注解即可。

87644ada4d79b2c3fb4abd9790ad771c.png

加了@Decrypt注解后,前端提交的数据需要按照AES加密算法,进行加密,然后提交到后端,后端这边会自动解密,然后再映射到参数对象中。

上面讲解的都是后端的代码,前端使用的话我们以js来讲解,当然你也能用别的语言来做,如果是原生的安卓app也是用java代码来处理。

前端需要做的就2件事情:

1、统一处理数据的响应,在渲染到页面之前进行解密操作

2、当有POST请求的数据发出时,统一加密

js加密文件请参考我GitHub中encrypt中的aes.js,crypto-js.js,pad-zeropadding.js

我们以axios来作为请求数据的框架,用axios的拦截器来统一处理加密解密操作

首先还是要封装一个js加解密的类,需要注意的是加密的key需要和后台的对上,不然无法相互解密,代码如下:

412610afdf47526e7eeb7a802bd31442.png

axios拦截器中统一处理代码:

f40fba0296efcea1a784a63e8b9b5933.png

到此为止,我们就为整个前后端交互的通信做了一个加密的操作,只要加密的key不泄露,别人得到你的数据也没用,问题是如何保证key不泄露呢?

服务端的安全性较高,可以存储在数据库中或者配置文件中,毕竟在我们自己的服务器上,最危险的其实就时前端了,app还好,可以打包,但是要防止反编译等等问题。

如果是webapp则可以依赖于js加密来实现,下面我给大家介绍一种动态获取加密key的方式,只不过实现起来比较复杂,我们不上代码,只讲思路:

加密算法有对称加密和非对称加密,AES是对称加密,RSA是非对称加密。之所以用AES加密数据是因为效率高,RSA运行速度慢,可以用于签名操作。

我们可以用这2种算法互补,来保证安全性,用RSA来加密传输AES的秘钥,用AES来加密数据,两者相互结合,优势互补。

其实大家理解了HTTPS的原理的话对于下面的内容应该是一看就懂的,HTTPS比HTTP慢的原因都是因为需要让客户端与服务器端安全地协商出一个对称加密算法。剩下的就是通信时双方使用这个对称加密算法进行加密解密。

1、客户端启动,发送请求到服务端,服务端用RSA算法生成一对公钥和私钥,我们简称为pubkey1,prikey1,将公钥pubkey1返回给客户端。

2、客户端拿到服务端返回的公钥pubkey1后,自己用RSA算法生成一对公钥和私钥,我们简称为pubkey2,prikey2,并将公钥pubkey2通过公钥pubkey1加密,加密之后传输给服务端。

3、此时服务端收到客户端传输的密文,用私钥prikey1进行解密,因为数据是用公钥pubkey1加密的,通过解密就可以得到客户端生成的公钥pubkey2

4、然后自己在生成对称加密,也就是我们的AES,其实也就是相对于我们配置中的那个16的长度的加密key,生成了这个key之后我们就用公钥pubkey2进行加密,返回给客户端,因为只有客户端有pubkey2对应的私钥prikey2,只有客户端才能解密,客户端得到数据之后,用prikey2进行解密操作,得到AES的加密key,最后就用加密key进行数据传输的加密,至此整个流程结束。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基于SpringBoot+Vue的入校申报审批系统是一个前后端分离的应用程序,旨在简化校园内外部人员入校申请和审批流程。该系统由后端SpringBoot框架提供RESTful API服务,前端Vue.js框架负责构建用户界面。整个系统设计注重用户体验、安全性和扩展性。 后端SpringBoot框架负责处理业务逻辑、数据库交互以及安全认证等功能。它利用了SpringBoot的自动配置、依赖注入等特性来简化开发流程,并使用JPA(Java Persistence API)与数据库进行交互,使得对数据库的操作更加简便、高效。 前端Vue.js框架则通过组件化的方式构建了一个响应式的用户界面,使得系统在不同设备上均能良好展示。Vue的双向数据绑定和虚拟DOM技术提升了界面渲染的效率,同时它的路由管理功能也方便了不同视图之间的切换。 系统的主要功能包括: 用户注册与登录:外部访客和学校工作人员可以注册并登录系统。 申请表单填写:访客填写个人信息、访问目的、预计访问时间等详细信息。 审批流程:工作人员审核访客信息,并根据规定执行批准或拒绝操作。 状态追踪:访客和工作人员均可实时查看申请的状态和历史记录。 数据统计:系统提供后台管理功能,用于统计分析入校申请数据。 源码包含完整的前端Vue项目文件和后端SpringBoot项目文件,以及相关的配置文件、数据库脚本等。部署说明文档详细描述了如何配置环境、启动应用和进行基本维护。演示视频则展示了系统的实际运行情况和操作流程。 总之,这个入校申报审批系统的设计与实现提供了一个完整的解决方案,适用于需要管理校园访客的学校或机构。它不仅提高了工作效率,还确保了校园安全,并且可以根据具体需求进行定制和扩展。
Java前后端分离OA系统是一种新型的软件开发模式,具有许多优势。在这种模式下,前端与后端分离,通过API进行数据交互和通信。 首先,Java作为后端语言,具有强大的处理能力和丰富的开发工具。它可以处理复杂的业务逻辑和数据库操作,并提供高性能的服务。后端可以使用Spring Boot等框架来快速开发和部署,提高开发效率和系统响应速度。 其次,前端可以使用各种主流的Web技术,如Vue.js、React等,进行界面开发和用户交互。前端通过调用后端提供的API,获取后端的数据并展示给用户。这种分离使得前端和后端可以独立进行开发和部署,互不影响。同时,前端可以根据需求自由选择适合的技术栈,并且可以实现页面的快速渲染和响应。 此外,前后端分离还可以提高系统的可扩展性和维护性。由于前后端独立,可以单独进行功能扩展或修复bug,而不会对整个系统造成影响。同时,前后端的分离还可以提高团队的协作效率,前端和后端可以同时进行开发,并可以很容易地进行接口对接和集成测试。 最后,前后端分离还可以提高系统的安全性。通过API进行数据交互,可以减少对外暴露的接口和数据,减少系统被攻击的风险。同时,前后端分离的架构也方便对前端和后端的权限控制和身份验证。 综上所述,Java前后端分离OA系统具有许多优势,可以提高开发效率、系统性能和可维护性,同时提升系统的安全性。这种模式在现代软件开发中越来越受欢迎,将在未来得到更广泛的应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值