好的,所以在一个stackoverflow男人的帮助下,我想出了一个加密英语的程序(主要是他)。这是使用Qt。但是现在它只是大写或小写。这是我需要修改的代码的一部分。
void translationForm::translate()
{
if(mode_comboBox->currentText() == "Encrypt")
{
QString str = lhs->toPlainText();
rhs->setText(str.toUpper());
}
else
{
QString str = lhs->toPlainText();
rhs->setText(str.toLower());
}
}
非常简单。而我的问题可能很简单,我无法弄明白。
这曾经是一个控制台程序。这是我用来加密它的代码。
int index=0;
while(str[index])
{
str[index]=(str[index]+1)%256;
index++;
}
std::cout << str;
但是出于某种原因,如果我把它放进去就行不通。那么我做错了什么?我把它贴在toPlainText()之后; line然后将setText替换为str。我该如何解决这个问题?
编辑(添加解密代码):
else {
int index=0;
while(str[index++]) {}
for(int i=0;i<index;i++)
{
str[i]-=1;
if(str[i]==-1)
{
str[i]=255;
}
}
}
答案 0 :(得分:0)
我猜,第二个文本块中的str
不是QString
。我建议您在Qt
中撰写时使用Qt
类型 - 它们非常易于使用。
工作代码块:
QByteArray encrypt(const QByteArray &str)
{
QByteArray ret;
foreach (char c, str)
ret.append((c + 1) % 256);
return ret;
}
...
rhs->setText(QString::fromAscii(encrypt(str.toUtf8())));
<强>更新强>:
解密功能:
QByteArray decrypt(const QByteArray &str)
{
QByteArray ret;
foreach (char c, str)
{
char r = c - 1;
if (r < 0)
r += 256;
ret.append(r);
}
return ret;
}
用法:
rhs->setText(QString::fromAscii(decrypt(str.toUtf8())));
对参数'1'进行解密 - 您可以轻松地将其更改为参数'10'。