zoukankan      html  css  js  c++  java
  • 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)。之后应该就可以正常使用了。

  • 相关阅读:
    Adding a prefix header to an iOS project
    DZ论坛常见基本设置问题
    DZ论坛如何去掉“今日”“昨日”发帖数显示?
    Discuz源码
    怎样使Firefox的新建标签页为空白页
    discuz论坛
    TK域名首次注册教程(咸干花生)
    氪星年货 #1:那些来自大牛的真知灼见
    慢性子
    life and penis
  • 原文地址:https://www.cnblogs.com/h-wei/p/10565386.html
Copyright © 2011-2022 走看看