How can I POST paramters via JavaScript to Java Servlet?
Here is my html code, which works:
<div id="loginPanel">
<form action="/login" method="POST" class="form">
<label>Login:</label>
<input type="text" name="login" id="login">
<label>Password:</label>
<input type="text" name="password" id="password">
<div id="loginLower">
<input type="checkbox"><label memory="memory">Remember me</label>
<input type="submit" value="Login">
</div>
</form>
</div>
And now, I want to hash password and POST to /login hashPassword with something like this:
<form onsubmit="post()">
<label>Login:</label>
<input type="text" name="login" id="login">
<label>Password:</label>
<input type="text" name="password" id="password">
<div id="loginLower">
<input type="checkbox"><label memory="memory">Remember me</label>
<input type="submit" value="Login">
</div>
</form>
<script src=".0.2/build/rollups/md5.js"></script>
<script>
function post(){
var passhash = CryptoJS.MD5(document.getElementById("password").value);
//post to /login login and passhash
}
</script>
I'd tried to use AJAX, JQuery but those solutions has problems with /login, because they call localhost:8080/?login in browser while I want to call Java Servlet: web.xml
<servlet>
<servlet-name>LoginServlet</servlet-name>
<servlet-class>pl./*...*/.LogoutServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>LoginServlet</servlet-name>
<url-pattern>/login/*</url-pattern>
</servlet-mapping>
How can I POST paramters via JavaScript to Java Servlet?
Here is my html code, which works:
<div id="loginPanel">
<form action="/login" method="POST" class="form">
<label>Login:</label>
<input type="text" name="login" id="login">
<label>Password:</label>
<input type="text" name="password" id="password">
<div id="loginLower">
<input type="checkbox"><label memory="memory">Remember me</label>
<input type="submit" value="Login">
</div>
</form>
</div>
And now, I want to hash password and POST to /login hashPassword with something like this:
<form onsubmit="post()">
<label>Login:</label>
<input type="text" name="login" id="login">
<label>Password:</label>
<input type="text" name="password" id="password">
<div id="loginLower">
<input type="checkbox"><label memory="memory">Remember me</label>
<input type="submit" value="Login">
</div>
</form>
<script src="http://crypto-js.googlecode./svn/tags/3.0.2/build/rollups/md5.js"></script>
<script>
function post(){
var passhash = CryptoJS.MD5(document.getElementById("password").value);
//post to /login login and passhash
}
</script>
I'd tried to use AJAX, JQuery but those solutions has problems with /login, because they call localhost:8080/?login in browser while I want to call Java Servlet: web.xml
<servlet>
<servlet-name>LoginServlet</servlet-name>
<servlet-class>pl./*...*/.LogoutServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>LoginServlet</servlet-name>
<url-pattern>/login/*</url-pattern>
</servlet-mapping>
Share
Improve this question
edited Apr 1, 2014 at 14:57
DivinaProportio
asked Apr 1, 2014 at 12:08
DivinaProportioDivinaProportio
2201 gold badge3 silver badges13 bronze badges
2
- The problem with this question is that you modified it after edit to be totally different question, actually, it is now 2 different questions. At first part you are requiring usage of passwordHash before form submit and at second part you are now using plain input values. First one would require tweaking with javascript and other doesnt. Make separate questions, this is madness – Mauno Vähä Commented Apr 1, 2014 at 14:51
- Ok, you have right! ;-) – DivinaProportio Commented Apr 1, 2014 at 14:56
2 Answers
Reset to default 3I admit that my answer this is partly a hunch (because it was long time ago I wrote it) but with JSP you should typically name form action to be name of the servlet configured in web.xml
I think your web.xml should be this:
<servlet>
<servlet-name>LoginServlet</servlet-name>
<servlet-class>pl./*...*/.LogoutServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>LoginServlet</servlet-name>
<url-pattern>/login</url-pattern>
</servlet-mapping>
And change your HTML to this:
<form action="LoginServlet" method="POST" class="form" id="loginForm">
For the JavaScript part if you submit form with jQuery you can modify your parameters which to post and omit posting of password (because it should not be needed if you want to post it as hashed) see below code for usage:
JavaScript (using jQuery):
// Attach a submit handler to the form
$("#loginForm").submit(function( event ) {
// Stop form from submitting normally
event.preventDefault();
// Get some values from elements on the page:
var $form = $( this );
// We want to customize what we post, therefore we format our data
var data = "login="+ $('#login').val() +"&passwordHash=" + CryptoJS.MD5($('#password').val());
// For debugging purposes... see your console:
// Prints out for example: login=myLoginName&passwordHash=a011a78a0c8d9e4f0038a5032d7668ab
console.log(data);
// The actual from POST method
$.ajax({
type: $form.attr('method'),
url: $form.attr('action'),
data: data,
success: function (data) {
console.log("Hey, we got reply form java side, with following data: ");
console.log(data);
// redirecting example..
if(data === "SUCCESS") {
window.location.replace("http://stackoverflow.");
}
}
});
});
Finally, at Java side you will need doPost()
method which captures login
and passwordHash
value etc.
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String login = request.getParameter("login");
String password = request.getParameter("passwordHash");
//
// Do what ever you want with login and passwordHash here...
//
// Because we are using ajax we need to respond to it stating whether we can redirect or not to new location, see lines below
// Content type of the response - You could also return application/json for example (which would be better in this case)
response.setContentType("text/plain"); // Using text/plain for example
response.setCharacterEncoding("UTF-8");
// Change this as you like - it can also be url or anything else you want...
response.getWriter().write("SUCCESS");
}
Read more about using json response: json response with jsp
Have you tried jQuery POST method specifying your web.xml as url? You need also prevent the default submit event.
https://api.jquery./jQuery.post/
function post(e){
e.preventDefault();
$.post( "/web.xml" , you_data, function(data, textStatus, jqXHR){
});
}