使用jquery调用webservice

时间:2015-07-22 11:07:23

标签: java jquery web-services jax-ws

我已经构建了一个java webservice,我试图用jquery ajax来调用它 我得到一个简单的输出..我得到的是调用WSDL时生成的HTML页面

这是JSP代码

checkLogin = function () {

             $.ajax({
                url : 'loginWS?method=checklogin',
                data : {
                    userName : $("#userName").val(),
                    password : $("#password").val()
                },
                success : function(responseText) {
                   $('#dvLoading').fadeOut(500);
                   alert(responseText);                       
                },
                error: function (err) {
                    $('#dvLoading').fadeOut(500);
                }
            });

这是java webservice

    @WebService(serviceName = "loginWS")
public class loginWS {

    @WebMethod(operationName = "checkLogin")
    @POST
    @Consumes({MediaType.APPLICATION_JSON})
    public String checkLogin(@WebParam(name = "userName") String userName, @WebParam(name = "password") String password) {

        if(userName.equalsIgnoreCase("admin") && password.equalsIgnoreCase("admin")){             
          return "success";
        }else{
            return "fail";
        }
    }

我得到的是以下结果

    <html>

<head><title>

Web Services

</title></head>

<body>

<h1>Web Services</h1>

<table width='100%' border='1'>

<tr>

<td>

Endpoint

</td>

<td>

Information

</td>

</tr>

<tr>

<td>

<table border="0"><tr><td>Service Name:</td><td>{http://login.services/}loginWS</td></tr><tr><td>Port Name:</td><td>{http://login.services/}loginWSPort</td></tr></table>

</td>

<td>

<table border="0"><tr><td>Address:</td><td>http://localhost:8081/CSHS/loginWS</td></tr><tr><td>WSDL:</td><td><a href="http://localhost:8081/CSHS/loginWS?wsdl">http://localhost:8081/CSHS/loginWS?wsdl</a></td></tr><tr><td>Implementation class:</td><td>services.login.loginWS</td></tr></table>

</td>

</tr>

</table>

</body>

</html>

如何获得简单的结果,如“成功”或“失败”

2 个答案:

答案 0 :(得分:1)

试试这个......

checkLogin = function () {
    $.ajax({
        url : 'loginWS?method=checklogin',
        data : JSON.stringify({
            userName : $("#userName").val(),
            password : $("#password").val()
        }),
        success : function(responseText) {
            $('#dvLoading').fadeOut(500);
            alert(responseText);                       
        },
        error: function (err) {
            $('#dvLoading').fadeOut(500);
            alert(err);
        }
    });
};

将对象作为数据传递,尽管在Web服务标头中将数据类型声明为JSON,但从未对我有用。使用JSON.stringify()将其作为字符串传递始终解决了我的问题。

这是使用C#Web服务,因此可能不相关。如果不是,我会删除这篇文章,而不是误导将来偶然发现的人。

答案 1 :(得分:1)

您的Web服务是JAX-WS Web服务。如果不创建客户端(即直接通过jQuery),则无法调用JAX-WS Web服务。

有两种方法可以解决这个问题:

  1. 为您的Web服务创建客户端(使用WSDL),然后创建简单的servlet,然后在服务器端调用您的Web服务。你可以通过jQuery调用这个Servlet。使用以下链接创建Web服务客户端:

    http://docs.oracle.com/javaee/6/tutorial/doc/bnayn.html

    或者

  2. 创建一个RESTful Web服务,您可以使用http(通过jQuery)直接调用它。对于REST Web服务,请参阅下面链接中描述的JAVA EE教程:

    https://docs.oracle.com/javaee/6/tutorial/doc/gipzz.html