• 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)。之后应该就可以正常使用了。

  • 相关阅读:
    Selenium(Python)等待元素出现
    java文件的I/O
    Map的四种遍历方式
    模板类实现链表
    字符串相关库函数使用
    动态规划之背包问题
    最长递增子序列
    深度优先搜索(DFS),逃离迷宫
    素数环问题(递归回溯)
    枚举(百鸡问题)
  • 原文地址:https://www.cnblogs.com/h-wei/p/10565386.html
Copyright © 2020-2023  润新知