如何做亚马逊备案的网站,东莞网站建设dgjcwl,主流的网站开发工具,如何创建网站页面一#xff1a;token 简介 Token#xff1a;访问令牌access token, 用于接口中, 用于标识接口调用者的身份、凭证#xff0c;减少用户名和密码的传输次数。一般情况下客户端(接口调用方)需要先向服务器端申请一个接口调用的账号#xff0c;服务器会给出一个appId和一个key, …一token 简介 Token访问令牌access token, 用于接口中, 用于标识接口调用者的身份、凭证减少用户名和密码的传输次数。一般情况下客户端(接口调用方)需要先向服务器端申请一个接口调用的账号服务器会给出一个appId和一个key, key用于参数签名使用注意key保存到客户端需要做一些安全处理防止泄露。 Token的值一般是UUID服务端生成Token后需要将token做为key将一些和token关联的信息作为value保存到缓存服务器中(redis)当一个请求过来后服务器就去缓存服务器中查询这个Token是否存在存在则调用接口不存在返回接口错误一般通过拦截器或者过滤器来实现Token分为两种 API Token(接口令牌): 用于访问不需要用户登录的接口如登录、注册、一些基本数据的获取等。获取接口令牌需要拿appId、timestamp和sign来换sign加密(timestampkey) USER Token(用户令牌): 用于访问需要用户登录之后的接口如获取我的基本信息、保存、修改、删除等操作。获取用户令牌需要拿用户名和密码来换 关于Token的时效性token可以是一次性的、也可以在一段时间范围内是有效的具体使用哪种看业务需要。 一般情况下接口最好使用https协议如果使用http协议Token机制只是一种减少被黑的可能性其实只能防君子不能防小人。 一般token、timestamp和sign 三个参数会在接口中会同时作为参数传递每个参数都有各自的用途。 二timestamp 简介 timestamp: 时间戳是客户端调用接口时对应的当前时间戳时间戳用于防止DoS攻击。当黑客劫持了请求的url去DoS攻击每次调用接口时接口都会判断服务器当前系统时间和接口中传的的timestamp的差值如果这个差值超过某个设置的时间(假如5分钟)那么这个请求将被拦截掉如果在设置的超时时间范围内是不能阻止DoS攻击的。timestamp机制只能减轻DoS攻击的时间缩短攻击时间。如果黑客修改了时间戳的值可通过sign签名机制来处理。 DoS DoS是Denial of Service的简称即拒绝服务造成DoS的攻击行为被称为DoS攻击其目的是使计算机或网络无法提供正常的服务。最常见的DoS攻击有计算机网络带宽攻击和连通性攻击。 DoS攻击是指故意的攻击网络协议实现的缺陷或直接通过野蛮手段残忍地耗尽被攻击对象的资源目的是让目标计算机或网络无法提供正常的服务或资源访问使目标系统服务系统停止响应甚至崩溃而在此攻击中并不包括侵入目标服务器或目标网络设备。这些服务资源包括网络带宽文件系统空间容量开放的进程或者允许的连接。这种攻击会导致资源的匮乏无论计算机的处理速度多快、内存容量多大、网络带宽的速度多快都无法避免这种攻击带来的后果。 Pingflood: 该攻击在短时间内向目的主机发送大量ping包造成网络堵塞或主机资源耗尽。 Synflood: 该攻击以多个随机的源主机地址向目的主机发送SYN包而在收到目的主机的SYN ACK后并不回应这样目的主机就为这些源主机建立了大量的连接队列而且由于没有收到ACK一直维护着这些队列造成了资源的大量消耗而不能向正常请求提供服务。 Smurf该攻击向一个子网的广播地址发一个带有特定请求如ICMP回应请求的包并且将源地址伪装成想要攻击的主机地址。子网上所有主机都回应广播包请求而向被攻击主机发包使该主机受到攻击。 Land-based攻击者将一个包的源地址和目的地址都设置为目标主机的地址然后将该包通过IP欺骗的方式发送给被攻击主机这种包可以造成被攻击主机因试图与自己建立连接而陷入死循环从而很大程度地降低了系统性能。 Ping of Death根据TCP/IP的规范一个包的长度最大为65536字节。尽管一个包的长度不能超过65536字节但是一个包分成的多个片段的叠加却能做到。当一个主机收到了长度大于65536字节的包时就是受到了Ping of Death攻击该攻击会造成主机的宕机。 TeardropIP数据包在网络传递时数据包可以分成更小的片段。攻击者可以通过发送两段或者更多数据包来实现TearDrop攻击。第一个包的偏移量为0长度为N第二个包的偏移量小于N。为了合并这些数据段TCP/IP堆栈会分配超乎寻常的巨大资源从而造成系统资源的缺乏甚至机器的重新启动。 PingSweep使用ICMP Echo轮询多个主机。 三sign 简介 nonce随机值是客户端随机生成的值作为参数传递过来随机值的目的是增加sign签名的多变性。随机值一般是数字和字母的组合6位长度随机值的组成和长度没有固定规则。 sign: 一般用于参数签名防止参数被非法篡改最常见的是修改金额等重要敏感参数 sign的值一般是将所有非空参数按照升续排序然后tokenkeytimestampnonce(随机数)拼接在一起然后使用某种加密算法进行加密作为接口中的一个参数sign来传递也可以将sign放到请求头中。接口在网络传输过程中如果被黑客挟持并修改其中的参数值然后再继续调用接口虽然参数的值被修改了但是因为黑客不知道sign是如何计算出来的不知道sign都有哪些值构成不知道以怎样的顺序拼接在一起的最重要的是不知道签名字符串中的key是什么所以黑客可以篡改参数的值但没法修改sign的值当服务器调用接口前会按照sign的规则重新计算出sign的值然后和接口传递的sign参数的值做比较如果相等表示参数值没有被篡改如果不等表示参数被非法篡改了就不执行接口了。 四防止重复提交 对于一些重要的操作需要防止客户端重复提交的(如非幂等性重要操作)具体办法是当请求第一次提交时将sign作为key保存到redis并设置超时时间超时时间和Timestamp中设置的差值相同。当同一个请求第二次访问时会先检测redis是否存在该sign如果存在则证明重复提交了接口就不再继续调用了。如果sign在缓存服务器中因过期时间到了而被删除了此时当这个url再次请求服务器时因token的过期时间和sign的过期时间一直sign过期也意味着token过期那样同样的url再访问服务器会因token错误会被拦截掉这就是为什么sign和token的过期时间要保持一致的原因。拒绝重复调用机制确保URL被别人截获了也无法使用如抓取数据。 对于哪些接口需要防止重复提交可以自定义个注解来标记。 注意所有的安全措施都用上的话有时候难免太过复杂在实际项目中需要根据自身情况作出裁剪比如可以只使用签名机制就可以保证信息不会被篡改或者定向提供服务的时候只用Token机制就可以了。如何裁剪全看项目实际情况和对接口安全性的要求。 五使用流程 接口调用方(客户端)向接口提供方(服务器)申请接口调用账号申请成功后接口提供方会给接口调用方一个appId和一个key参数 客户端携带参数appId、timestamp、sign去调用服务器端的API token其中sign加密(appId timestamp key) 客户端拿着api_token 去访问不需要登录就能访问的接口 当访问用户需要登录的接口时客户端跳转到登录页面通过用户名和密码调用登录接口登录接口会返回一个usertoken, 客户端拿着usertoken 去访问需要登录才能访问的接口 sign的作用是防止参数被篡改客户端调用服务端时需要传递sign参数服务器响应客户端时也可以返回一个sign用于客户度校验返回的值是否被非法篡改了。客户端传的sign和服务器端响应的sign算法可能会不同。 六示例代码 1. dependency dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-data-redis/artifactId/dependencydependencygroupIdredis.clients/groupId