Securing webservices of PHP

前端 未结 2 1853
梦谈多话
梦谈多话 2021-01-03 08:58

I\'m developing a small project in android which is using php webservices\' call.

I want my webservices to be protected, however by using GET/POST request methods I

相关标签:
2条回答
  • 2021-01-03 09:19

    If you're new to encryption, you should go the simple route and just go with HTTPS, as suggested in comments.

    Also, as suggested in comments, don't send the passwords via GET from a web page because that shows in the address bar and passers by can read that off the screen.

    HTTPS (SSL/TLS) provides end to end encryption of the entire connection between the web server and the client. This allows you to send all your data in clear text and not worry about it because it's being encrypted at a lower level.

    Since it's not a web browser calling your web server, you don't even need to pay for an SSL certificate. You can create a self-signed certificate. Just ensure you verify the signature on every connection to prevent man in the middle attacks. This is a bit trickier though, so again, if you're new to this, just pay for the SSL certificate and let Android take care of the certificate verification for you.

    In response to your direct question:

    Encoding is not encryption, as you may have discovered. Base64 is encoding and provides no security.

    You cannot simply generate an RSA public/private key pair, encrypt data with the private key, and send it to your server. You have to first share your public key with the server. Well, anyone who sniffs the public key off the wire can decrypt it.

    You could potentially have the client generate a random symmetric key and encrypt it with the server's public key. The server would then decrypt it with the private key, and have a shared secret key to use to encrypt data and send it to you.

    The problem with that is an attacker could simply replay all your data to a server to see the same output. These random things need to be generated by the server to ensure they're actually random, so you're stuck with the server generating the key, but if the server simply encrypts with the private key, anyone with the public key could decrypt it.

    So, you'd need some method of securely deriving a shared secret key, some complicated mathematical way of sharing some data that both the server and the client could use to calculate the same shared key.

    You could do this yourself, but you'll be calling complicated procedures and functions, when you could just use SSL, which does the same thing for you.

    0 讨论(0)
  • 2021-01-03 09:25

    I think you can use POST web service to make it more secure and if possible then please don't encrypt parameter just encrypt value of parameter and then also if you face issue then try to retrive value using

    $_REQUEST['parameter_name']

    0 讨论(0)
提交回复
热议问题