I'm making a simple program that takes text entered in a text box, and takes a password that's in another text box, then does some sort of simple encryption on it and saves it to a file. Afterwards, a user should be able to open up the file again and provide the password that was used to encrypt it and it should spit out the original text.
Right now I'm taking the string. Separate it into a char array, then doing the same for the password. After that, I take the password, convert all those chars to integers, find the average value for all of them, and use it as an offset to the chars int he original text. Kind of like:
textChars[1]= (char)((int)textChars[1]+offset);
Then I can do the reverse for the encrypted string:
encryptedChars[1]= (char)((int)encryptedChars[1]-offset);
The problem is that characters have different values on different platforms so sometimes the offset will turn the char into some crazy number (like a negative value) which will just turn the char into a question mark.
I looked at the crypto library in the standard Java API, but I feel confused as to how the key works if it's just randomly generated every time I start the program.
What I need is two functions that look like String encrypt(String text,String Password)
which spits out the text encrypted with the password as a key to decrypting it, and String decrypt(String encryptedText, String Password)
which would spit out the original text (or gibberish if the password is junk)
Any help is really appreciated, this is really just a personal project so I don't need any fancy encryption methods.