javascript - 创建密码扰码器

标签 javascript c code-conversion scramble

我正在尝试将密码加密器从 Javascript 复制到 C。它所做的是获取字母的 ASCII 字符代码、将其取整、划分,然后从给定列表中获取一个随机字符。

Javascript 版本:

function getScrambledPassword(pwd) {
    var cipher = ['k', 's', 'z', 'h', 'x', 'b', 'p', 'j', 'v', 'c', 'g', 'f', 'q', 'n', 't', 'm'];
    var result="";
    if (pwd == null)
        pwd = "";
    pwd = encodeURIComponent(pwd);
    //alert("encoded password: " + pwd);
    for(var i=0;i<pwd.length;i++) {
            var cc = pwd.charCodeAt(i);
        result += cipher[Math.floor(cc/16)] + cipher[cc%16];
    }
    //alert("scrambled password: " + result);
    return result;
}

正在运行的加扰器示例:https://jsfiddle.net/w5db66va/

到目前为止我做了什么:

#include <stdio.h>
#include <math.h>
#include <string.h>

static char *scramblePassword(char *pwd)
{
    char *cipher[] = {
        "k", "s", "z", "h",
        "x", "b", "p", "j",
        "v", "c", "g", "f",
        "q", "n", "t", "m"
    };

    char *result = "";
    for(int i=0; i < strlen(pwd); i++)
    {
        int cc = (int) pwd[i];
        printf("%d", cc);
        result + cipher[floor(cc/16)] + cipher[cc%16];
    }
    return *result;
}

int main(void)
{
    char *test[] = {"test", "testtwo", "testthree"};
    for (int i=0;i < sizeof(test); i++)
    {
        printf("Original: %s", test[i]);
        printf("Scrambled: %s", scramblePassword(test[i]));
    }
}

我遇到的问题是,当我运行 c 文件(编译后)时,它根本不会输出任何内容。我做错了什么,以至于我无法让它按预期运行?

最佳答案

继续评论,您的问题比您最初想象的要深一些。首先,您不希望 cipher 是一个字符串数组,您只是希望它是一个字符数组,例如:

    char cipher[] = "kszhxbpjvcgfqnm";

接下来,您不能返回在函数体内声明的数组。 result 的内存在 scramblePassword 返回时被销毁。您的选择是 (1) 在 scramblePassword 中动态分配 result(并在 main 中释放它),或 (2) 为 声明存储main 中的结果 并将其作为参数传递给 scramblePassword。例如:

#define MAX 32

static char *scramblePassword (char *pwd, char *result)
{
 ...
    return result;
}

int main(void)
{
    char result[MAX] = "";
    ...
        printf ("Scrambled: %s\n", scramblePassword (test[i], result));

最后,如果您的算法打算从 cipher 构建一个乱序字符数组,将导致选择超出 cipher 范围的索引,从而导致 未定义的行为。如果目的只是为 result[x] 赋值,而不管它是否是有效的可打印 ASCII 值,那么它可能没问题。但是,如果第一个是您的目标,则算法的结果必须始终产生一个在 cipher 范围内的值,例如像这样的东西:

         result[i] = cipher[((int)floor (cc / 16) + cc % 16) % sizeof cipher];

将所有这些部分放在一起,回想一下 mainint 类型并因此返回一个值,您可以这样做:

#include <stdio.h>
#include <math.h>
#include <string.h>

#define MAX 32

static char *scramblePassword (char *pwd, char *result)
{
    char cipher[] = "kszhxbpjvcgfqnm";
    int i;

    for (i = 0; i < (int)strlen (pwd); i++)
    {
        int cc = (int) pwd[i];
        // result[i] = cipher[(int)floor (cc / 16)] + cipher[cc % 16];
        result[i] = cipher[((int)floor (cc / 16) + cc % 16) % sizeof cipher];
    }
    result[i] = 0;  /* you MUST nul-terminate to use as a string */

    return result;
}

int main(void)
{
    char *test[] = {"test", "testtwo", "testthree"};
    char result[MAX] = "";

    for (int i = 0; i < (int)(sizeof test/sizeof *test); i++)
    {
        printf ("\nOriginal : %s\n", test[i]);
        printf ("Scrambled: %s\n", scramblePassword (test[i], result));
    }

    return 0;
}

示例使用/输出

这将导致可读的输出:

$ ./bin/pwscramble

Original : test
Scrambled: ffgf

Original : testtwo
Scrambled: ffgffmb

Original : testthree
Scrambled: ffgffmcff

我将留给您研究该算法实际应该做什么。如果您还有其他问题,请告诉我。

关于javascript - 创建密码扰码器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43143301/

相关文章:

c# - C到C#代码转换——数组作为参数

javascript - 由于键名复杂,无法访问 JavaScript 数组成员

javascript - ExtJS 网格速度慢,有 3000 多条记录

javascript - 根据动态生成的复选框多次显示相同的 div

javascript - 使用 Node.js 在进程终止时执行事件

java - Scala 中的方法执行难题

Visual Basic MidB$ 的 Java 等效项

创建嵌套 pthread

C do-while 循环

delphi - 如何将RETRIEVAL_POINTERS_BUFFER结构翻译为Delphi?