zoukankan      html  css  js  c++  java
  • 对称加密,API加密

    用于API加密,双方约定好signature_key对请求的参数进行处理

    处理步骤如下

    1. 把请求的数据生成为key=>value的形式,然后拼接生成arg_key
    2. arg_key加上双方约定的signature_key进行md5()加密
    3. 取得加密后的某一段字符
    4. 请求接口时在提交的数据中带上客户端生成token
    5. 服务端对客户端提交的数据生成token,然后进行对比
      /**
       * 对称加密
       * @param string $type
       * @return string
       */
      protected function symmetryEncrypt($type = 'POST')
      {
          $signature_key = 'abc123';
          $arg_key = '';
          $data = $type == 'POST' ? $_POST : $_GET;
          unset($data['token']);
          foreach ($data as $key => $value) {
              $arg_key .= $key . '=' . $value . '|';
          }
          return substr(md5($signature_key . $arg_key), 4, 4);
      }
      
      /**
       * 验证对称加密
       * @param string $type
       * @return bool|IlluminateHttpJsonResponse
       */
      protected function validateSymmetry($type = 'POST')
      {
          $data = $type == 'POST' ? $_POST : $_GET;
          if (!isset($data['token'])) {
              abort(403, 'Permission denied');
          }
          $symmetry_key = $this->symmetryEncrypt($type);
          if ($data['token'] != $symmetry_key) {
              abort(403, 'Permission denied');
          }
      }
  • 相关阅读:
    java 事务
    JPA概述以及它和Hibernate之间的关系
    [转]JavaWeb之 Servlet执行过程 与 生命周期
    j2EE的web.xml详解
    安装PyTorch 0.4.0
    [转]springmvc常用注解标签详解
    hibernate的dialect大全
    Hibernate快速入门
    DBUtils使用详解
    用户密码初始化
  • 原文地址:https://www.cnblogs.com/yhdsir/p/5181783.html
Copyright © 2011-2022 走看看