Is that worth it to use some JS encryption library to make safe communication instead of SSL? I ask this because I want to secure my application built on Google App Engine and it doesn't let you to use your own domain for SSL requests. What are good ways to communicate securely with GAE? Thanks.
相关问题
- Is there a limit to how many levels you can nest i
- How to toggle on Order in ReactJS
- void before promise syntax
- java.lang.NullPointerException at java.io.PrintWri
- Keeping track of variable instances
You have to use https, but you can't use it on your own domain with appengine. They say that they will add that ability soon, though. We've been using the annoying https appspot domain assuming that they really will add support for https custom domains, but in the meantime none of our (~75) customers have complained about the appspot thing.
I guess the real question is how many people AREN'T customers because of the appspot thing... but I suspect it's a small number.
Javascript is a client side language, meaning it runs in the user's browser, so any user can alter, manipulate and disable it as they please; rendering your encryption useless.
EDIT: Don't you mean Java?
[See correction below]
It is possible to securely communicate with an authenticated server on google app engine with a custom domain, but it is a hassle. As some of the other answers indicate, you must be very careful how you implement the encryption to prevent man-in-the-middle attacks.
Here are the basic instructions for python, but you could could modify for java. Expect to spend at least a day or two getting something like this up and running.
Prerequisites:
Instructions:
Step 1: Offline, create a RSA public and private key pair. Here are pyCrypto instructions.
Step 2: Save the generated RSA public & private keys in a python file, be sure the private key is not publicly accessible.
Step 3: On the server, create a request that generates a javascript file. The javascript file should only transmits the public key to the client. For example, it would only return a file with this:
var public_key="[your public rsa key here]"
Step 4: In your
app.yaml
file, make sure that the generated javascript file is only served over SSL (i.e. setsecure: always
). See instructions here.Step 5: On the client, load the javascript file using ssl. However, instead of using your custom domain, use the appspot domain. For example, add this to your html file:
<script src="https://example.appspot.com/publicKey.js"></script>
The client will now have an authenticated RSA public key preventing man-in-the-middle attacks. Note: accessing other domains is normally prohibited by browsers to prevent XSS, but there is a loophole which allows you to load javascript files.
Step 6: On the client, generate a random private key. Use a javascript RSA library and the public key we got in step 4 to encrypt the random private key. Send the encrypted private key to the server.
Step 7: On the server, decrypt the random key generated on the client using the RSA private key.
At this point, both the server and the client have the same private key. Even better, because the original public key was transmitted over SSL, we can authenticate that the server is really who we believe it is (i.e. no man-in-the-middle).
Step 8: Now the server and client can encrypt and decrypt any data they want using the randomly generated private key and their respective AES libraries.
-- EDIT: CORRECTION --
Bruno's comment below is 100% correct, the above steps are insecure. Although the steps above do work to setup an authenticated session between client and server, the only way that the user would really know it was authenticated is if they checked the code to ensure that the public key was being loaded using https. A man-in-the-middle could serve the initial html page modify the
<script src="https://...
code to point to something else.Instead, take a look at wwwizer.com.
No, it's not worth it, because you have to send the Javascript code to the client somehow. The attacker could simply modify the Javascript to make it possible for him to read (or modify) all the communications, rendering all your protections useless. SSL really is the only option.