[Webinar] Streamline your web hosting managementRegister Today

  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 1104
  • Last Modified:

Encryption in Visual C++


I've to do a simple assignment on encryption and I came across this article. I wish to try it using Visual C++.

TEA encrypts 64 data bits at a time using a 128 bit key.
What I understand from the article is strings must be converted into array of bytes.
1) Can we convert a string to an array of bytes?
2) Say I have CString m_strInput and int TEA[16]. Is it correct if I assign 64bits of user-input data into every element of TEA? I don't quite get how to convert the string and split them up into the array.

I guess that's all for now. I think once I get the solution to this one I can proceed to understanding how TEA works. I've never done encryption before, I'm quite loss on how to start coding.

Thank you in advance for your help and guidance.

1 Solution
I don't think you want to convert, rather just cast, i.e., look at the character string to be encrypted as an array of uints.

The easiest way to do this is with a union of the the string (char array) and a uint array:

char  cThing[128];
uint   uTHing[56];

Jaime OlivaresSoftware ArchitectCommented:
If you want to work with CString, then you have to convert (because buffer will be converted to binary and could have null characters), but it is simple.

CString str = "some data here";
CByteArray arr;

arr.RemoveAll();    // Optional, to reuse it.
for (int i=0; i<str.GetLength(); i++)

Now you can pass arr.GetData() to any function that requires it.
TEA is a block cipher and therefore not particuarly well suited to encrypting strings, because it requires that each encryption operation works on exactly 64 bit blocks.

If you want to encrypt a string then you need to use either

a) a padding system to make sure that the string is expanded so it is exactly divisible by a block size - typically one of the PKCS padding schemes are used.

b) use a steam cipher - by using CFB or OFB algorithms you can use a block cipher as a stream cipher - if you go down this route it is important to remember that you ALWAYS use the block cipher in encryption mode regardless of whether you are using encryption or decryption with the CFB/OFB algorithm
The new generation of project management tools

With monday.com’s project management tool, you can see what everyone on your team is working in a single glance. Its intuitive dashboards are customizable, so you can create systems that work for you.

virlinzAuthor Commented:
thanks for providing me the answers.
I don't quite understand how CByteArray works. Do we use it like the normal array? What's the difference between the CDWordArray and the other array family members?
Jaime OlivaresSoftware ArchitectCommented:
I thought you have discarded my answer, because it has not been accepted.
CByteArray is a Visual C++ MFC object that wraps and manages a simple byte array. It is similar to CDWordArray except that you fill it a byte at a time instead of a DWord (4 bytes) at a time.
As I said, you can use is by calling it's GetData member which returns you the pointer to the actual buffer (different from the pointer to the object itself).
The advantage of using a CArray derived class: you don't have to worry about memory allocation issues.
virlinzAuthor Commented:
btw sorry about the points. this is my first time posting a question so I got confused with the 'marking scheme' (I didn't read the FAQ first). I agree and accept all the answers. I'm really sorry about that :D
virlinzAuthor Commented:
Sorry about that Jaime. I thought I can accept all answers so I started pushing the button from the last answer :D
So for CByteArray, when copying using the for loop in ur example, str[0] means "s" while CDWordArray str[0]="some", am I right?
Jaime OlivaresSoftware ArchitectCommented:
Yes, you are right.
virlinzAuthor Commented:
ok.. say after I transfer all this into the array I want to convert them into hexadecimal numbers. How can I do that? I can't use the Format() cuz it will convert into hex but as a CString type. I want the hex to be stored as int.
Jaime OlivaresSoftware ArchitectCommented:
You can use Format() anyway as you expect because have to convert to hex every character, so you have to do a for... loop

CByteArray arr;

// some process who fills array here

CString hexString;
CString number;

for (int i=0; i<arr.GetSize(); i++) {
     number.Format("%02X", arr[i]);
     hexString += number;
virlinzAuthor Commented:
I tried run the codes. curious to see what is stored in every hexString element, I add a few lines after your codes

CString output;

I entered virlinz. I'm supposed to get  75 but instead only 7 was the output. How to get 75? Does this mean the hex string now takes two places (eg. hexString[0] and hexString[1]) for each converted char?
Jaime OlivaresSoftware ArchitectCommented:
If you want a hex string representation, it will take 2 bytes for each converted char.
But you simply can use the CByteArray directly. arr[0] will be 75 (or its decimal representation, that depend just of point of view). Numbers are not stored as decimals or hexas, them are allways stored as binaries, decimal or hexa is just a display option.

Featured Post

Learn to develop an Android App

Want to increase your earning potential in 2018? Pad your resume with app building experience. Learn how with this hands-on course.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now