• sql中base64解码、译码


    1、5.6版本及之后的版本的base64

      主要就是两个MySQL内部函数to_base64from_base64,使用也很简单,如下:

      1)先查看MySQL的版本:mysql> select version();   ----如果超过5.6的版本可以直接使用两个内部函数

      2)mysql> select to_base64('helloworld');    -----加密的过程

      3)mysql> select from_base64('aGVsbG93b3JsZA==');    ------ 解密的过程

    2、5.6之前的版本

      如果版本不够的情况下,可以写两个函数base64_encodebase64_decode。

      1)先创建一个基础表

    DROP TABLE IF EXISTS base64_data 
    CREATE TABLE base64_data (c CHAR(1) BINARY, val TINYINT) 
    INSERT INTO base64_data VALUES
    ('A',0), ('B',1), ('C',2), ('D',3), ('E',4), ('F',5), ('G',6), ('H',7), ('I',8), ('J',9),
    ('K',10), ('L',11), ('M',12), ('N',13), ('O',14), ('P',15), ('Q',16), ('R',17), ('S',18), ('T',19),
    ('U',20), ('V',21), ('W',22), ('X',23), ('Y',24), ('Z',25), ('a',26), ('b',27), ('c',28), ('d',29),
    ('e',30), ('f',31), ('g',32), ('h',33), ('i',34), ('j',35), ('k',36), ('l',37), ('m',38), ('n',39),
    ('o',40), ('p',41), ('q',42), ('r',43), ('s',44), ('t',45), ('u',46), ('v',47), ('w',48), ('x',49),
    ('y',50), ('z',51), ('0',52), ('1',53), ('2',54), ('3',55), ('4',56), ('5',57), ('6',58), ('7',59),
    ('8',60), ('9',61), ('+',62), ('/',63), ('=',0) 
      2)创建一个解密的函数

    DROP FUNCTION IF EXISTS input_pentaho_bod.BASE64_DECODE 
    CREATE FUNCTION BASE64_DECODE (input BLOB)
    RETURNS BLOB
    CONTAINS SQL
    DETERMINISTIC
    SQL SECURITY INVOKER
    BEGIN
    DECLARE ret BLOB DEFAULT '';
    DECLARE done TINYINT DEFAULT 0;

    IF input IS NULL THEN
    RETURN NULL;
    END IF;

    each_block:
    WHILE NOT done DO BEGIN
    DECLARE accum_value BIGINT UNSIGNED DEFAULT 0;
    DECLARE in_count TINYINT DEFAULT 0;
    DECLARE out_count TINYINT DEFAULT 3;

    each_input_char:
    WHILE in_count < 4 DO BEGIN
    DECLARE first_char CHAR(1);

    IF LENGTH(input) = 0 THEN
    RETURN ret;
    END IF;

    SET first_char = SUBSTRING(input,1,1);
    SET input = SUBSTRING(input,2);

    BEGIN
    DECLARE tempval TINYINT UNSIGNED;
    DECLARE error TINYINT DEFAULT 0;
    DECLARE base64_getval CURSOR FOR SELECT val FROM base64_data WHERE c = first_char;
    DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET error = 1;

    OPEN base64_getval;
    FETCH base64_getval INTO tempval;
    CLOSE base64_getval;

    IF error THEN
    ITERATE each_input_char;
    END IF;

    SET accum_value = (accum_value << 6) + tempval;
    END;

    SET in_count = in_count + 1;

    IF first_char = '=' THEN
    SET done = 1;
    SET out_count = out_count - 1;
    END IF;
    END; END WHILE;

    -- We've now accumulated 24 bits; deaccumulate into bytes

    -- We have to work from the left, so use the third byte position and shift left
    WHILE out_count > 0 DO BEGIN
    SET ret = CONCAT(ret,CHAR((accum_value & 0xff0000) >> 16));
    SET out_count = out_count - 1;
    SET accum_value = (accum_value << 8) & 0xffffff;
    END; END WHILE;

    END; END WHILE;

    RETURN ret;
    END 

      3)创建一个加密的函数

    DROP FUNCTION IF EXISTS input_pentaho_bod.BASE64_ENCODE 
    CREATE FUNCTION BASE64_ENCODE (input BLOB)
    RETURNS BLOB
    CONTAINS SQL
    DETERMINISTIC
    SQL SECURITY INVOKER
    BEGIN
    DECLARE ret BLOB DEFAULT '';
    DECLARE done TINYINT DEFAULT 0;

    IF input IS NULL THEN
    RETURN NULL;
    END IF;

    each_block:
    WHILE NOT done DO BEGIN
    DECLARE accum_value BIGINT UNSIGNED DEFAULT 0;
    DECLARE in_count TINYINT DEFAULT 0;
    DECLARE out_count TINYINT;

    each_input_char:
    WHILE in_count < 3 DO BEGIN
    DECLARE first_char CHAR(1);

    IF LENGTH(input) = 0 THEN
    SET done = 1;
    SET accum_value = accum_value << (8 * (3 - in_count));
    LEAVE each_input_char;
    END IF;

    SET first_char = SUBSTRING(input,1,1);
    SET input = SUBSTRING(input,2);

    SET accum_value = (accum_value << 8) + ASCII(first_char);

    SET in_count = in_count + 1;
    END; END WHILE;

    -- We've now accumulated 24 bits; deaccumulate into base64 characters

    -- We have to work from the left, so use the third byte position and shift left
    CASE
    WHEN in_count = 3 THEN SET out_count = 4;
    WHEN in_count = 2 THEN SET out_count = 3;
    WHEN in_count = 1 THEN SET out_count = 2;
    ELSE RETURN ret;
    END CASE;

    WHILE out_count > 0 DO BEGIN
    BEGIN
    DECLARE out_char CHAR(1);
    DECLARE base64_getval CURSOR FOR SELECT c FROM base64_data WHERE val = (accum_value >> 18);

    OPEN base64_getval;
    FETCH base64_getval INTO out_char;
    CLOSE base64_getval;

    SET ret = CONCAT(ret,out_char);
    SET out_count = out_count - 1;
    SET accum_value = accum_value << 6 & 0xffffff;
    END;
    END; END WHILE;

    CASE
    WHEN in_count = 2 THEN SET ret = CONCAT(ret,'=');
    WHEN in_count = 1 THEN SET ret = CONCAT(ret,'==');
    ELSE BEGIN END;
    END CASE;

    END; END WHILE;

    RETURN ret;
    END 

    4)穿件完成后就可以使用了,使用方法类似

      解密:select base64_decode('aGVsbG93b3JsZA==');。解密使用时,有可能会解不出来,因为返回值是BLOB格式的,所以需要用CAST(expr AS type)再重新转换一下。例:select cast((select base64_decode('aGVsbG93b3JsZA==')) as char)。之后应该就可以正常使用了。

  • 相关阅读:
    DevOps实施方法论,为什么大企业一定要使用DevOps?
    SpringCloudAlibaba基础入门,基于Nacos构建分布式与配置,Sentinel服务治理
    艾编程Java进阶架构师必看:15次架构演进详解
    实战笔记:来一起探究下Kafka是如何实现万亿级海量数据的高并发写入的?
    520疯狂之后我彻底蒙了,老板让我做技术选型,数据处理选kafka还是RocketMQ?
    如何实现Redis数据持久化以及内存管理之缓存过期机制
    SpringBoot源码深度解析
    分布式缓存Redis高级应用实战:为什么要用缓存机制
    全面上云实战教程:基于阿里云安装配置部署docker详解
    Solr学习笔记(2)—— solr-7.0.0 安装与目录说明
  • 原文地址:https://www.cnblogs.com/h-wei/p/10565386.html
Copyright © 2020-2023  润新知